A potentially dangerous Request.Form value was detected from the client

        我的报错页面:

A potentially dangerous Request.Form value was detected from the client_第1张图片

       原因:在提交之前的一个页面用到span+contendeditable属性,当输入enter时增加<p>标签,所以用如下方式解决:

if (event.keyCode == 13)
  {
   var textRange = document.selection.createRange();
   textRange.text = "\r\n";
   textRange.select();
   event.returnValue = false;
  } 

      但是,当输入回车时,再取text属性时去掉了回车符,用html属性取值时,多了<br>的style属性,就是style属性中的内容被检测到风险报错。

      报错原因:用户在页面上提交表单到服务器时,服务器会检测到一些潜在的输入风险,例如使用富文本编辑器控件(RichTextBox、FreeTextBox、CuteEditor等)编辑的内容中包含有HTML标记或脚本标记,ASP.NET页面会抛出一个"A potentially dangerous Request.Form value was deceted from the client"的异常。这个是ASP.NET页面为了防范页面注入功能的一种保护机制,要取消这种保护,常规的做法是在.aspx文件的<%@Page %>部分加入ValidateRequest="false"属性。但是从.NET 4.0开始你可能需要多修改一个地方,在网站的web.config文件中加入这行配置[Path就是你要提交的页面的路径]:

	<location path="Include/CrimeMapping/Chart/CrimeAnalysis_ThematicMapFrame.aspx">
		<system.web>
			<compilation debug="true" targetFramework="4.0"/>
			<httpRuntime requestValidationMode="2.0"/>
		</system.web>
	</location>

      同时,你还需要确保页面上用户输入的部分不会存在任何注入攻击的代码,常用的做法是使用Encode处理。

你可能感兴趣的:(Web.Config,ValidateRequest)