.Net站点设置多个路由对应同一个Action
需求:有些浏览器会屏蔽带有Ad字样的路径,此时需要创建多个路由指向同一个Action。
例如:
原来:http://lalalalalala.org:1506/api/advert/common 现在需要增加另一个请求路径 http://lalalalalala.org:1506/api/guanggao/common
1、.Net Core中追加这样的路径比较简单,如下
文章图片
只需要增加在Controller和Action增加Route特性标签,便能得到下面四个路径,然后他们指向的都是Get方法. 可以在swagger中查看:
文章图片
2. 在DotNet Freamwork项目下:
某个系统是webapi 1,不具有特性路由功能,所以不能像.net core 一样通过加标签的方式进行重命名。
方法一:可以参考下面的解决方式,我在注册路由的地方,将需要进行增加路由的方法,都增加了一个配置。
文章图片
在swagger中查看的效果如下:
文章图片
方法二:升级成webapi2,然后使用特性路由方式。
1.升级【webapi 1】到【WebApi 2】,如下升级到最新
文章图片
其中不升级 WebHost 会出现下面的异常
文章图片
2.手动添加特性路由的配置代码,如下图,添加如下代码到默认的路由上面: config.MapHttpAttributeRoutes();
文章图片
* 这里注意下,特性路由要在普通路由规则上面。如果把特性路由放在默认路由的下面,编译不会出错,但是在运行时候就会出现找不到Action 的问题,如下图:
{
"Message": "找不到与请求 URI“http://localhost:21094/api/Default2/Get?id=2”匹配的 HTTP 资源。",
"MessageDetail": "未找到与名为“Default2”的控制器匹配的类型。"
}
3.开始修改controller
文章图片
【.Net站点设置多个路由对应同一个Action】通过 ~/api/xxx/yyy 可以重写路由前缀
文章图片
补充:Webapi2 里面跨域问题 在第二步升级了webapi之后,在前端请求的时候,会出现跨域问题。解决可以参考我下面的做法:
1.升级或者安装nuget
文章图片
然后在配置的地方添加如下代码: config.EnableCors();
文章图片
config.EnableCors() 里面可以指定 跨域的Domain、Header以及Methond ,但是广告系统原来在web.config进行了设置,所以这里启用一下就可以了。
文章图片
启动程序此时还是会出现一个问题:
当前端使用Ajax进行跨域请求的时候,会先试探性的发一个Option请求,然后得到对应的跨域信息,如上面红框中的配置。 当发现允许请求的时候,此时就进行下一步真实的请求。
问题在于这个Option请求返回Code要是200,前端才认为是正常的。但是直接升级webapi之后,Option请求返回是404 not found。 即使带着这些配置的跨域信息也不能被前端所处理。
所以在 每个请求的开始,增加一个判断,将这个方法绑定到BeginRequest事件上。
文章图片
然后跨域请求的第一次Option请求返回都是200,并且带着刚刚红框中的信息。
到此这篇关于.Net站点设置多个路由对应同一个Action的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
推荐阅读
- ASP.NET实现Repeater控件的数据绑定
- 《.netCore|《.netCore + Vue框架搭建之旅》前端篇(微前端架构设计)
- C#/VB.NET:|C#/VB.NET: 将Word或Excel文档转化为Text
- Android|Android 7.0 语言设置爬坑
- linux|使用putty设置基于 SSH 密钥的身份验证
- Windows|压缩文件如何设置密码(/ 如何破解压缩文件密码?)
- .net|.net 温故知新(【6】Linq是什么)
- Oracle|Oracle主键自增设置
- 职场|工位设置一对一摄像头引发热议,没有「摸鱼自由」比 996 更反人性
- 安装SQLServer2012和设置SA登陆