如何:通过将HTML编码应用于字符串来防止Web应用程序中的脚本漏洞
当用户可以将可执行代码(或脚本)添加到您的应用程序中时,会发生大多数脚本攻击。默认情况下,ASP.NET提供请求验证,如果表单发布包含任何HTML,则会引发错误。
您可以通过以下方式帮助防止脚本漏洞利用:
1,对表单变量,查询字符串变量和cookie值执行参数验证。此验证应包括两种类型的验证:验证变量可以转换为预期类型(例如,转换为整数,转换为日期时间等),以及验证预期范围或格式。例如,应使用Int32.TryParse方法检查旨在为整数的表单post变量,以验证变量是否为整数。此外,应检查结果整数以验证该值是否在预期的值范围内。
2,将值写回到响应时,将HTML编码应用于字符串输出。这有助于确保任何用户提供的字符串输入将在浏览器中呈现为静态文本,而不是可执行脚本代码或解释的HTML元素。
HTML编码使用HTML保留字符转换HTML元素,以便显示而不是执行它们。
将HTML编码应用于字符串
在显示字符串之前,请调用HtmlEncode方法。 HTML元素将转换为浏览器将显示的字符串表示形式,而不是解释为HTML。
以下示例说明了HTML编码。在第一种情况下,用户输入在显示之前被编码。在第二种情况下,来自数据库的数据在显示之前被编码。
注意:这个示例只有在通过添加@Page属性ValidateRequest="false"来禁用页面中的请求验证时才能工作。不建议在生产应用程序中禁用请求验证,因此请确保在查看此示例之后再次启用请求验证。
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e _
As System.EventArgs) Handles Button1.Click
Label1.Text = Server.HtmlEncode(TextBox1.Text)
Label2.Text = _
Server.HtmlEncode(dsCustomers.Customers().CompanyName)
End Sub
如何:通过将HTML编码应用于字符串来防止Web应用程序中的脚本漏洞的更多相关文章
- 如何:通过对字符串应用 HTML 编码在 Web 应用程序中防止脚本侵入
		
大多数脚本利用发生在用户可以将可执行代码(或脚本)插入您的应用程序时. 默认情况下,ASP.NET 提供请求验证.只要窗体发送包含任何 HTML,该验证都会引发错误. 您可以使用下列方法防止脚本利用: ...
 - ***PHP各种编码的汉字字符串截取
		
虽然PHP有现成的截取字符串函数substr(),但是这个函数不能对汉字字符串进行截取,要实现这种效果还需要我们自己去编写相应的函数.汉字有多种编码,比如GB2312,UTF-8等,汉字字符串的截取需 ...
 - 字符串编码、Base64字符串 互转
		
/// <summary> /// 将字符串编码为Base64字符串 /// </summary> /// <param name="str"& ...
 - asp.net使用unescape读取js escape编码过的字符串
		
escape() 是JavaScript的编码函数 例子:var esstring=escape("helloworld"); 为了防止数据传输读取中出现乱码现象,字符串往往要用J ...
 - curl_escape ---> 使用URL 编码给定的字符串
		
curl_escape (PHP 5 >= 5.5.0) curl_escape — 使用 URL 编码给定的字符串 说明¶ string curl_escape ( resource $ch ...
 - php查询mysql中的json编码后的字符串内容的方法
		
问题 mysql里存的是json编码后的字符串,其中中文会被转为unicode码,所以直接查询是查询不到的. mysql里的查询如 like "%\u6211\u662f%" 也是 ...
 - 【java】乱码处理+编码转化+判断字符串编码方式
		
之前有一篇是修改IDE的编码,服务器的编码等处理乱码,但是在所有环境因素上,保证了编码方式之后,也会有前台传递给后台[get方式提交]传递给后台的编码方式是非UTF-8的,也会有例如FTP服务器的编码 ...
 - 编码和解码(字符串与byte[]之间的转换)
		
资源来自互联网http://www.cnblogs.com/dabaopku/archive/2012/02/27/2370446.html 非常蛋疼的事情, google 和 baidu 在编码是分 ...
 - java安全编码指南之:字符串和编码
		
目录 简介 使用变长编码的不完全字符来创建字符串 char不能表示所有的Unicode 注意Locale的使用 文件读写中的编码格式 不要将非字符数据编码为字符串 简介 字符串是我们日常编码过程中使用 ...
 
随机推荐
- git 源码学习(init-db) 提交版本号 083c516331
			
写在前面的废话: 学完git之后,还是感觉云里雾里的,于是乎,就想到了通过学习git源码,来加深git的熟练度,同时学习一下c语言编程. git源码学习,逐步分析 这篇帖子是逐步分析git源码的,将g ...
 - JavaWeb基础—Servlet重要对象
			
一.ServletConfig对象 当servlet配置了初始化参数后(<init-param> <param-name> <param-value>),web容器 ...
 - 打开CDQ的大门&BZOJ3262
			
题目传送门 第一次接触CDQ分治,感谢YZ大佬的教导. CDQ分治就是一种奇特的分治方法,它用左区间的区间信息来更新右区间. 设CDQ(L,R,l,r)表示递归到区间[L,R],区间的值为[l,r]. ...
 - CF 700 E. Cool Slogans
			
E. Cool Slogans 链接 题意: 给定一个字符串S,从中选出k个子串a[1],a[2]...a[k],满足a[i]在a[i+1]中出现了两次(可以重叠),求最大的k. 分析: 建出SAM, ...
 - 【windows】窗口锁定状态如何关机
			
在锁定界面下方有一个——切换用户,点击,过一会右下角就有一个红色的圆圈,就可以关机了.
 - 复杂值vs原始值&&内存空间
			
写在前面 最近在读<JavaScript启示录>,这本书不是JavaScript的详尽的参考指南,但是把对象作为了解JavaScript的透镜,受益匪浅. 那么我们先来聊一下JavaScr ...
 - js,jsp里将数据库Date类型获取出来后格式化显示于界面
			
js:new Date(rowdata.updateTime).format("yyyy-MM-dd hh:mm:ss") jsp: <fmt:formatDate valu ...
 - 【DOS】COPY命令
			
一:文件复制COPY 指令说明:复制一个或更多文件到指定位置,可以合并文件 语法:COPY [/A/B] source[/A|/B] [+source [/A|/b] [+...]][destinat ...
 - hdu1754 I Hate It(线段树单点更新,区间查询)
			
传送门 有更新单个学生成绩和查询某个区间内学生成绩最大值两种操作 线段树代码 #include<bits/stdc++.h> using namespace std; +; using n ...
 - VRRP+tunnel+IP SLA+Track实现冗余切换
			
IP SLA(Internet Protocol Service-Level Agreement)互联网服务等级协议,本实验里通过发送测试报文,测试下一跳是否可达,结合Track实现冗余静态路由的切换 ...