我爱Aspx >> Asp.Net >> URL编码与SQL注入说到url编码,你或许会想起N年前的url编码漏洞。可惜我是“生不逢时”啊,我接触网络时,那个漏洞早就绝迹咯。
言归正传,URL 编码是什么东东呢?看看我从网上抄的定义:
引用: url编码是一种浏览器用来打包表单输入的格式。浏览器从表单中获取所有的name和其中的值 ,将它们以name/value参数编码(移去那些不能传送的字符, 将数据排行等等)作为URL的一部分或者分离地发给服务器。不管哪种情况, 在服务器端的表单输入格式样子象这样:
theName=Ichabod+Crane&gender=male&status=missing&headless=yes
URL编码遵循下列规则: 每对name/value由&符分开;每对来自表单的name/value由=符分开。如果用户没有输入值给这个name,那么这个name还是出现,只是无值。任何特殊的字符(就是那些不是简单的七位ASCII,如汉字)将以百分符%用十六进制编码,当然也包括象 =, &, 和 % 这些特殊的字符。
呵呵,明白了吧,其实url编码就是一个字符ascii码的十六进制。不过稍微有些变动,需要在前面加上“%”。比如“\”,它的ascii码是92,92的十六进制是5c,所以“\”的url编码就是\。那么汉字的url编码呢?很简单,看例子:“胡”的ascii码是-17670,十六进制是BAFA,url编码是“%BA%FA”。呵呵,知道怎么转换的了吧。
URL编码平时我们是用不到的,因为IE会自动将你输入到地址栏的非数字字母转换为url编码。所以对于浏览器来说http://blog.csdn.net/l%61ke2与http://blog.csdn.net/lake2是等效的(注意,第一个url我用%61替换了a)。呵呵,或许你已经想起了,有人提出数据库名字里带上“#”以防止被下载,因为IE遇到#就会忽略后面的字母。破解方法很简单——用url编码#替换掉#。我本来企图利用url编码来躲过注射检查的,不过失败了,因为服务器端会将url编码转换成字符的。
Ҷƪл˵?
SQL Server 2005 Reporting Serv..[08-01]
SQL Server 2005—有关开发的10个..[08-01]
SQL Server 2005—数据库管理10个..[08-01]
.net2.0中使用SqlBulkCopy进行大..[08-01]
查询数据库表和字段sql语句[08-01]
将文本文件导入Sql server数据库[08-01]
连接到 SQL Server 2005 时出现的..[08-01]
Oracle:一条SQL实现将多行数据并..[08-01]
用asp.net还原与恢复sqlserver数..[08-01]
问题“未于信任SQL Server连接相..[08-01]
为什么PHP令人不爽(对于大型系统..[08-01]
Word成功能强大的媒体播放器[08-01]
Photoshop特效:融化的透明胶体字[08-01]
Photoshop精彩特效:玻璃砖墙材质..[08-01]
初谈ADO.NET中利用DataAdapter进..[08-01]
使Div内内容可编辑[08-01]
WPS表格2005排序功能全接触[08-01]
入门:Linux 2.6 内核的嵌入式系统..[08-01]
Photoshop字体特效:鲜艳缤纷彩斑..[08-01]
Dreamweaver教程:层及其应用[08-01]