多一个“点”给IIS与ASP.NET带来的问题

【IIS】

一个网站如果用的是IIS(假设没有在前端7层负载均衡中对这种场景进行特殊处理),只要在浏览器地址栏中输入这个网站的域名并加上“.”,比如:www.cnblogs.com. ,就会引发“Bad Request - Invalid Hostname”错误:

www.cnblogs.com.

由于这个错误信息是IIS底层直接返回的,如果只从IIS的角度,你没有任何方法可以对这个错误信息进行定制与处理,包括微软自己。

www.microsoft.com.

要解决这个问题,只能在IIS前端加上非基于IIS的7层负载均衡(或反向代理),比如Nginx、Tengine,然后针对这个场景对主机名进行重写或者重定向、显示自定义错误信息。

我们目前虽然用了基于Tengine的7层负载均衡(阿里云SLB),但是SLB并没有提供针对这个问题的解决方案,所以只能束手无策。

【ASP.NET】

 如果一个网站用的是ASP.NET(假设没有对以“.”结尾的URL进行重写),只要在一个URL之后加上“.”,ASP.NET中所有的自定义错误设置都形同虚设。

结尾点号引发的404错误

微软msdn博客站点也有这个问题:

asp.net url end with dot

要解决这个问题,需要借助IIS的URL重写组件(比如Url Rewrite Module)针对这种情况进行URL重写。

而我们用Url Rewrite Module解决这个问题的过程中发现竟然只能Rewrite,不能Redirect,

Url Rewrite Rule 

如果Action type改为Redirect,依然会显示之前的错误页面。

这两个历史悠久的问题更让我们对ASP.NET vNext多了一份期待。

【更新】

之前写的URL重写规则不能处理以多个点结局的情况,改进后的重写规则如下:

<rule name="end_with_dot" stopProcessing="true">
    <match url="(.*)[^.]\.+$" />
    <action type="Rewrite" url="{R:1}" />
</rule>
posted @ 2014-06-23 13:41  dudu  阅读(4864)  评论(41编辑  收藏  举报