主页 > 互联网  > 

解决方法:从客户端(---<Ahref=“http://l...“)中检测到有潜在危险的Request.Form

解决方法:从客户端(---<Ahref=“http://l...“)中检测到有潜在危险的Request.Form
从客户端(-----<A href="http://l...")中检测到有潜在危险的 Request.Form 值。

解决方法:应该是不同的.net Framework版本对代码的校验不同,造成在高版本操作系统(即高.net Framework版本校验)不兼容,可以在网站IIS管理中更改应用程序池,一般是从.net Framework 4.0 改为.net Framework2.0.

更改以上内容后,如果出现以下

错误提示:未知的服务器标记“asp:ScriptManager”

则需要在web.config中修改:

要加入下面内容:

<pages validateRequest="false">       <controls>         <add tagPrefix="asp" namespace="System.Web.UI" assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>         <add tagPrefix="asp" namespace="System.Web.UI.WebControls" assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35"/>       </controls>     </pages>

重启IIS网站服务,然后登陆问题就解决了。

网上相关资料如下,其实都是乱抄,下面几乎没有作用,可做理解参考:

=================================================================

说明: 请求验证过程检测到有潜在危险的客户端输入值,对请求的处理已经中止。该值可能指示危及应用程序安全的尝试,如跨站点的脚本攻击。通过在 Page 指令或 配置节中设置 validateRequest=false 可以禁用请求验证。但是,在这种情况下,强烈建议应用程序显式检查所有输入。  

异常详细信息: System.Web.HttpRequestValidationException: 从客户端(ftbContent="<P><A href="http://l...")中检测到有潜在危险的 Request.Form 值

以上为系统报错信息。原因是,在 ASP.NET 1.1 中,@Page 指令上的 ValidateRequest 属性被打开后,将检查以确定用户没有在查询字符串、Cookie 或表单域中发送有潜在危险性的 HTML 标记。如果检测到这种情况,将引发异常并中止该请求。该属性默认情况下是打开的;您无需进行任何操作就可以得到保护。如果您想允许 HTML 标记通过,必须主动禁用该属性。

解决办法:

方法一、修改.aspx文件

在.aspx文件中加入validateRequest="false",形如:

<%@ Page validateRequest="false" language="c#" Codebehind="WriteNews.aspx.cs" AutoEventWireup="false" Inherits="News.WriteNews" %>

方法二、配置web.config文件 <?xml version="1.0" encoding="utf-8" ?> <configuration>       <system.web>

    <!--  WriteNews.aspx使用内容编辑框时必须添加该语句,否则无法 Request值     -->  <pages validateRequest="false"/>

   </system.web> </configuration>

推荐使用方法一。

标签:

解决方法:从客户端(---<Ahref=“http://l...“)中检测到有潜在危险的Request.Form由讯客互联互联网栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“解决方法:从客户端(---<Ahref=“http://l...“)中检测到有潜在危险的Request.Form