注册 登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

xian827991006

专注于DotNet编程,QlikView开发,网站seo,各种软件工具,互联网

 
 
 

日志

 
 
关于我

爱看书、爱探索的人. 目前关注与QlikView开发,推荐一个QlikView资源站。www.qlikviewcn.com

ASP.Net4中实现自定义的请求验证  

2011-09-09 09:18:33|  分类: 精彩推荐 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

导读:在.Net4中有个System.Web.Util.RequestValidator类,该类是自定义请求验证的基类。我们可以通过实现一个继承自该基类的类,从而实现自己的请求验证过程,比如对提交的表单数据,查询字符串等等进行验证。

1. 请求验证什么?

首先,请看下图:

上图中,是我们常见一个ASP.Net错误提示.由于ASP.Net默认情况是把请求验证(validateRequest)设置是为true,从而使得ASP.Net会对提交的信息进行检查,这在一定程度上有效的阻止了某些危险攻击,比如:跨站脚本攻击(XSS/CSS)。

但是,也存在以下问题:

有时候,我们允许用户输入某些特殊时,如果按照请求验证(validateRequest)默认设置true,那么当用户输入我们允许的特殊字符时,就会出现如上图所示的错误提示,阻止了用户输入.此时,我们必须将请求验证设置为false,才能允许用户输入特殊字符。可是,一旦把请求验证设置为false,那么ASP.Net就不会对请求验证了,这样其潜在危险就超过了我们的控制范围.

虽然,我们可以在某些页面做特殊处理,以便阻止这些潜在的危险.可以,随着项目扩大,也许要处理的页面就会增长.显然,我们需要灵活、方便、更好的方式进行处理.那么现在在ASP.NET4就为我们提供了一个可以集中处理的自定义扩展点。

2.RequestValidator

在.Net4中有个System.Web.Util.RequestValidator类,该类是自定义请求验证的基类.我们可以通过实现一个继承自该基类的类,从而实现自己的请求验证过程.

目前,可以验证的请求由枚举类RequestValidatorSource提供,可枚举项具体如下:

1. QueryString 查询字符串。

IsValidRequestString方法的collectionKey参数设置为集合中查询字符串参数的名称。

IsValidRequestString方法的value参数设置为集合中查询字符串参数的值。

2. Form窗体值

IsValidRequestString方法的collectionKey参数设置为集合中窗体参数的名称。

IsValidRequestString方法的value参数设置为集合中窗体参数的值。

3. Cookies请求Cookie。

IsValidRequestString方法的collectionKey参数设置为集合中的Cookie的名称。

IsValidRequestString方法的value参数设置为集合中的值。

4.Files上载的文件。

IsValidRequestString方法的collectionKey参数设置为集合中已上载文件的名称。

IsValidRequestString方法的value参数设置为集合中已上载文件的值。

5. RawUrl原始URL。(域后的URL部分。)

IsValidRequestString方法的collectionKey参数设置为null。(RawUrl不是值集合。)

IsValidRequestString方法的value参数设置为RawUrl字段的值。

6. Path虚拟路径。

IsValidRequestString方法的 collectionKey参数设置为null(Path不是值的集合)。

IsValidRequestString方法的value参数设置为Path字段的值。

7. PathInfo HTTP PathInfo字符串(URL路径的扩展)。

IsValidRequestString方法的collectionKey参数设置为null(PathInfo不是值的集合)。

IsValidRequestString方法的value参数设置为PathInfo字段的值。

8.Headers请求标头。

IsValidRequestString方法的collectionKey参数设置为集合中HTTP头的名称。

IsValidRequestString方法的value参数设置为集合中HTTP头的值。

通过以上这些枚举我们基本上就能对常见提交的数据进行统一请求验证处理,比如:忽略某些特殊的数据或者处理某些特殊的数据或者提供一个友好的错误页面等。

3.实现自定义请求验证

下面演示如何实现一个自定义验证类,对每个查询字符串验证.步骤如下:

1.继承RequestValidator类,只需要重写IsValidRequestString方法,如下:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Web.Util;

namespace WebApplication1

{

public class myRequestValidator:RequestValidator

{

protected override bool IsValidRequestString(HttpContext context, string value, RequestValidationSource requestValidationSource, string collectionKey, out int validationFailureIndex)

{

validationFailureIndex = -1;

if (requestValidationSource == RequestValidationSource.QueryString) //对查询字符串进行验证

{

if (value.Contains("<"))//检查是否包含<,当然也可以检查其他特殊符号,或者忽略某些特殊符号.

{

context.Response.Redirect("~/Error.aspx",true);//直接转到自定义的错误页面.

return false;

}

}

return base.IsValidRequestString(context, value, requestValidationSource, collectionKey, out validationFailureIndex);

}

}

}

2.在web.config中设置请求验证类型为自定义的类型.如下: <configuration>

<system.web>

<compilation debug="true" targetFramework="4.0" />

<httpRuntime requestValidationType="WebApplication1.myRequestValidator" />

</system.web>

</configuration>

现在,我们通过修改url来提交带<特殊符号的页面时,将会被定向到自定义的错误页面,而不是默认错误提示.如下:

如下图所示,并没有出现默认的错误提示,而是到了我们自己提供一个错误页面

最后,ASP.Net4为我们提供很多扩展点,可以很方便进行扩展,使得我们的应用程序更加灵活可控。

转自:http://sd.csdn.net/a/20110720/301936.html

  评论这张
 
阅读(822)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018