时间:2021-05-19
一:场景
出于某种理由,需要由asp.net引擎处理所有可能出现的无效URL的Request。
二:现状
对于无效URL,一般会由IIS返回404错误。当然,也可以自定义Custom Error Page,但是在这种情况下,并不能处理原URL所代表的Request的数据(如表单数据)。或许我们想直接在Application_BeginRequest中处理该请求,但是,如果我们的IIS已经处理了“Verify that file Exists”,则实际上该请求根本不会被Application_BeginRequest命中(Fire)。
三:解决方案
1:准备好web.config,进行如下配置:
复制代码 代码如下:
<location path="FolderTest">
<system.web>
<httpHandlers>
<add verb="*" path="*" type="YourNamespace.YourHandler"/>
</httpHandlers>
</system.web>
<system.webServer>
<handlers>
<add name="testyou" verb="*" path="*" type="younamespace.youHandler" resourceType="Unspecified"/>
</handlers>
</system.webServer>
</location>
有几点需要说明:
1)熟悉system.web和system.webServer的朋友一定知道,后者是针对iis7及以上的集成模式的配置项,如果不满足此宿主条件,则IIS会自动忽略此配置,采用前者的配置节点。
2)经过此配置后,iis7及以上的集成模式的站点已经能够处理FolderTest路径下的所有404 Request了。
3)resourceType="Unspecified",是用来处理标示处理所有请求的,包括file and folder等等,如果我们处理的是文件url,则不需要此配置属性。
4)path=”*”,表明这是一个wildcard httphandler。
5)如果我们不是要处理子目录下所有请求,如上文配置中的FolderTest,而是要处理根目录下的所有404请求,则去掉location配置节。
2:现在来处理iis7及以上的集成模式的情况
比如,不幸我们还在使用II6,则应该在IIS中配置“Verify that file Exists”为非构选状态。以iis6为例,我们可进行如下操作:
1:)打开站点配置节点
点击Configuration之。
2:)然后,在出现的界面中的下半部分,即“Wildcard application maps”部分,点击“Insert”,出现如下图:
把aspnet_isapi.dll配置进去,然后不要钩选“Verify that file exists”,OK之。
至此,整个世界清静了。你可以在你的HttpHandler中处理任何想要的Request的数据了,比如表单数据,哪怕客户端提交的是一个不存在的URL。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近在使用画布处理图像像素时用到了file上传控件,发现了file上传控件的两个兼容性问题。一个是file上传控件在火狐下无法通过css改变width,另一个是
家有没发现在C盘或者其他系统盘的根目录下存在如FOUND.000、FOUND.001或者FOUND.002这类的文件夹,大小都是0字节,十分奇怪,这些文件是病毒
通过之前的学习,我知道中间件可以预处理http请求并返回相应页面(比如出现404异常,可以返回一个自己编写的异常界面,而非默认使用的白板404页面,很难看)。其
永远不要把消极的一面展现给顾客,即便你的网站出现404错误页面之时。一些旅游企业很认真地在处理这个问题,并花费了许多精力来打造一些有创意的/有趣的404错误页面
在网站建设中有非常多的细节需要注意,尤其对于新站长而言,有些细节会容易被忽略,细节处理的不当也会使用户的体验大打折扣,例如404页面的设计。HTTP404错误是