asp.net routing html文件不能访问,ASP.NET MVC 阻止通过URL访问服务器上的静态资源文件...

背景

在默认情况下,MVC框架是支持对服务器静态资源的访问的,我们在项目根目录下新建一个Content文件夹,然后添加一个命名为“StaticContent.html”的html文件,如下图所示:

b76362a261b0538f0b5d02e0d8ddf1c5.png

StaticContent.html中的代码如下图所示:

This is the static html file(~/Content/StaticContent.html)

运行项目,输入URL,可以看到能访问到这个文件:

f9a8738e67b0715b376ec24d60b9ba47.png

为磁盘文件定义路由

为了安全考虑,希望用户不能访问某些文件夹,我们可以增加如下代码:

public static void RegisterRoutes(RouteCollection routes)

{

routes.RouteExistingFiles = true;

}

这段代码告诉MVC框架,对于静态文件我们也要走路由机制(默认情况下,MVC框架发现请求的文件存在于服务器上时,会绕过路由机制,直接读取文件)

然后新建一条更具体的静态路由,映射文件路径请求,如下图所示:

public static void RegisterRoutes(RouteCollection routes)

{

routes.RouteExistingFiles = true;

routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

routes.MapMvcAttributeRoutes();

//映射到Customer控制器上的List方法

routes.MapRoute("DiskFile","Content/StaticContent.html",new { controller = "Customer",action = "List"});

routes.MapRoute(

name: "Default",

url: "{controller}/{action}/{id}",

defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }

);

}

再次运行项目, 还是能访问到,如下图所示:

129445b0b8b67f157e8f7ac440edeb5b.png

配置应用程序服务器

以上这么做还不够,需要配置应用程序服务器。首先启动MVC项目,在右下角找到 IIS Express,如下图所示:

b438db9dbb7fd963c063a4bf579172bb.png

右键点击, 选择“显示所有应用程序”后,如下图所示:

69f3852ed2a2d0a10cdbfa935d2cb171.png

单击网站名称后,在出现的配置一栏中,再次点击配置,如下图所示:

0b5ed3146dd0378b0b6458cb941678a2.png

在打开的文件中,搜索“UrlRoutingModule-4.0” 关键字,如下图所示:

73f46d2493ae617579be206307c1eb48.png

将preCondition属性设置为空字符串,如下图所示:

在VS中重新运行项目,让修改后的配置生效,并导航到/content/StaticContent.html,可以看到映射已经生效:

82c1d3216b4cd8734ba250ef40ff5e0a.png

当然,可以自己修改Customer控制器下List方法返回的页面代码,增加个提示,比如“无法访问资源文件”什么的。

注意IIS 和 IIS Express的处理方式是有区别的,如果你的程序发布到IIS上,需要在web.config中添加如下代码,否则静态文件还是会交由IIS处理,而不会被路由。如下图所示:

.......

绕过路由系统

到这里还没结束,以上方法禁止了对所有资源文件的访问。如果现在去请求scripts文件夹下的静态js文件,能看到如下图所示:

1f4f831bde52ad0afc8357938c8a2ca7.png

如果希望排除某些资源文件 ,绕过路由系统,可以用以下代码:

public class RouteConfig

{

public static void RegisterRoutes(RouteCollection routes)

{

routes.RouteExistingFiles = true;

routes.IgnoreRoute("Scripts/{*pathInfo}");

}

}

在这种情况下,URL模式将匹配任何两个片段的URL,第一个片段是“Scripts”,第二个片段{*pathInfo}是所有路径的意思。

IgnoreRoute方法在RouteCollection中创建了一个条目,在RouteCollection中路由处理程序是StopRoutingHandler类的一个实例,而不是MvcRouteHandler类。路由系统被硬编码以识别这个处理程序。如果传递给IgnoreRoute方法的URL模式匹配,那么后面的路由将不会被计算,就像匹配一个普通的路由一样。

再次访问JS文件,成功,如下图所示:

966e6da06b1ce32f8f313555aae26ff4.png

本文结束 ,部分参考来自这篇文章

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值