ASP.NET 4.0请求验证

在客户端文本框中输入HTML标签等危险内容点提交,会出现脚本错误:

消息: Sys.WebForms.PageRequestManagerParserErrorException: 未能分析从服务器收到的消息。

 

修改方法如下:

<system.web>
    <httpRuntime requestValidationMode="2.0" />
    <pages validateRequest="false"></pages>
</system.web>

 

深入:

validateRequest=“false”是关闭验证

但在 4.0 中还多了一个 requestValidationMode,这是什么意思呢?

requestValidationMode 有两个值:

  • 2.0 仅对网页启用请求验证。是启用还是关闭取决于 validateRequest。
  • 4.0 默认值。任何 HTTP 请求都会启用请求验证,也就是说不光是网页,还包括 Cookie 等。此时强制启用,不管 validateRequest 为何值。

由于 requestValidationMode="4.0" 是强制启用,所以我们会发现在 .NET Framework 4.0 中仅靠设置 validateRequest 是关闭不了请求验证的,还得将 requestValidationMode 设置为 2.0。

ASP.NET中的请求验证特性提供了某一等级的保护措施防止XSS攻击,之前版本的ASP.NET的请求验证是默认启动的,但是他仅仅应用于ASP.NET页面中(.aspx文件和.aspx.cs文件)。

而在ASP.NET4中,请求验证默认对所有类型的请求启动,因为它在BeginRequest被调用之前启动,结果就是对所有资源的请求都要经过请求验证,而不仅仅在.aspx文件和他们的类文件中,甚至包括web service和自定义的httphandler。同样,在自定义httpmodules读取http请求的时候,同样要经过请求验证。

 

更多:

如果开启验证,仍然可以在服务器端捕获HttpRequestValidationException异常并加以处理(未验证)

    protected void Page_Error(object sender, EventArgs e)
    {
        Exception ex = Server.GetLastError();
        if (ex is HttpRequestValidationException)
        {
            //处理异常
            Server.ClearError();
        }
    }

转载于:https://www.cnblogs.com/sohobloo/archive/2012/10/04/2711219.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: CefSharp是一款基于Chromium开发的.NET WinForms和WPF控件库。它提供了一个简便的方法来嵌入现代web浏览器特性到.NET应用程序中。CefSharp支持.NET 4.0以及更高版本。CefSharp提供了使用Chromium实现浏览器功能,从而可以让.NET开发者在自己的应用程序中集成现代浏览器的能力,包括强大的JavaScript引擎,HTML5,CSS3等功能。通过CefSharp,开发者可以在无需离开.NET环境的情况下,拥有一个现代的web浏览器功能。CefSharp不仅仅是一个浏览器控件库,它也提供了一些辅助功能,例如JavaScript绑定,3D WebGL渲染等。此外,CefSharp还支持拦截浏览器行为,从而可以自定义应用程序的行为,例如响应鼠标和键盘操作,在浏览器内渲染HTML页面,诸如此类。短而言之,CefSharp 是一个优秀的.NET浏览器控件库。它提供了在.NET应用程序中嵌入现代化浏览器特性的途径,提高了应用程序的用户体验。CefSharp提供了大量的功能,从JavaScript到WebGL,从激活事件到深入挖掘浏览器对象模型,在.NET应用程序开发中,CefSharp可谓是浏览器控件库的首选! ### 回答2: CefSharp是一种基于谷歌开源项目Chromium的.NET封装,允许开发人员使用C#或VB.NET实现基于Chromium的浏览器应用程序。它提供了一个完整的浏览器控件,可以简化开发人员在.NET平台上实现基于Chromium的浏览器应用程序的难度。随着.NET技术的不断更新,CefSharp在.NET4.0上也得到了广泛应用。CefSharp与.NET4.0的结合简化了开发人员的工作,极大地提高了浏览器应用程序的开发效率。CefSharp的.NET4.0版本拥有更好的性能和更多的功能,同时也可以比以前更方便地进行升级更新。 CefSharp.NET4.0版本支持多种框架,包括WinForms、WPF和ASP.NET等。使用CefSharp,在.NET平台上构建浏览器应用程序简单而容易,尤其是在Windows操作系统上,因为CefSharp针对Windows操作系统进行了优化。因此,如果你想在.NET平台上开发一个功能强大且易于使用的浏览器应用程序,CefSharp.NET4.0可能是一个很好的选择。 ### 回答3: CefSharp是一个.NET开源项目,旨在提供对Google Chrome的Cef库的完全绑定,从而允许在.NET应用程序中嵌入浏览器功能。它为开发人员提供了一个强大的框架,可以在应用程序的用户界面中嵌入Web浏览器。CefSharp十分灵活,因此可以非常容易地在自己的.NET项目中进行定制和扩展。 CefSharp支持x86和x64操作系统架构,支持多进程,具有低延迟的渲染速度。除此之外,CefSharp还提供了许多有用的功能,如JavaScript交互,拖放,字体渲染等等。CefSharp还提供了一个非常完整和详细的文档,其中包含了完整的API和使用示例。 CefSharp 现在已经支持了 .NET 4.0。因此,.NET开发者现在能够更容易地使用CefSharp,使他们能够将浏览器内核集成到他们的应用程序中。CefSharp .NET 4.0是稳定和经过深入测试的版本,提供了许多新特性和改进。通过使用CefSharp,.NET开发者可以在他们的应用程序中实现跨平台Web浏览器功能,从而使应用程序更加灵活和强大。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值