* c9 W) t8 T$ L$ O2 L9 ^ 注:各位同仁,今天晚上主要防止被限号来凑个数字,这篇文章本来是给一个机构做科普的,所以写的有点怎么说,反正土司的人看了会骂哈哈,大家凑合的看,文中哪怕有那么一点半点东西,能给大家带来启发,那么我这个文章就没白发,所以大佬们轻点喷哈哈,嘴下留情哈哈。 1、POST注入猜解网站管理员账号密码 通过awvs扫描发现存在注入,直接在avws下的Scans---target下点击你扫描的过目标如图:6 ~+ j. y+ A) H {! K- c @* V
然后点vulnerabilities,如图:2 m3 h; c: q; \0 Z: H
点SQL injection会看到HTTPS REQUESTS,如图:
1 A7 {5 p( X2 o3 M! M
7 I- j6 q4 Q& Z- {; K- B: b7 U
获取到http的数据包,如下: POST /Product/ProductHandler.ashx HTTP/1.1 Host: www.test.cn Cache-Control: no-cache Accept: text/plain, /; q=0.01 Origin: http://www.test.cn User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.16 Safari/537.36 X-Requested-With: XMLHttpRequest Referer: http://www.test.cn/ Accept-Language: en-us,en;q=0.5 X-Scanner: Netsparker Accept-Encoding: gzip, deflate Content-Length: 157 Content-Type: application/x-www-form-urlencoded; charset=UTF-8" m$ x# o2 w) i/ F' t: s& C. e
5 |( r" J9 r2 e& i/ M3 w5 ^$ \: I% C+ G7 F+ ~. A1 E: B- z Type=GetProductList&pageIndex=3&pageSize=5&productType=*&supplierType=1 把以上post包保存到sqlmap根目录下,保存为1.txt,注入参数提前用awvs已经识别,注入参数是productType,注入命令为: sqlmap.py -r 1.txt --level 5 --risk 3 -p productType --dbms=mssql -D cci -T Zy_user -C u_loginname,u_loginpassword –dump 此sqlmap命令的意思是读取数据库cci下Zy_user表的用户名密码列名,dump就是保存下来的意思,会保存在./sqlmap/output下,以excel表格的格式保存着下载下来的表的内容。 注入用户名密码加密值如图:
2 i8 k" |3 S4 J2 ?
2、通过对bin目录dll进行反编译解密管理员加密值登录后台 通过前面的sql注入可获取网站后台账号和密码加密值,为了更深入的测试网站后台是否存在其他漏洞,需要黑盒测试模拟黑客攻击进一步测试,故对网站目录bin目录下的dll进行反编译来获取加密密匙,最终成功解密密码。 把bin目录下的dll全部加载到Reflector中,然后通过跟踪常用用户密码相关的类函数,得出如下结果:
; B. [0 j/ `7 a- u
4 ~3 b* o z0 v& c 得知密钥是fkue且为des加密,接着定位encrypt类函数找出其解密方式如图:
9 {8 K6 d% ?/ f4 i: [
! A* T3 ]2 I2 R) F% x. T
解密方式是把fkue使用md5进行加密,然后取32位md5加密值的前8位作为加密密钥,如图:* s' \ U: z; f5 Y
' G2 L9 m6 J: k7 J9 x. ~: p
. D$ ~! E* A" t* S$ H& U. j7 B
通过在线解密网站解密得知加密密钥就是:1110AF03。 前面sql注入步骤已经成功获取admin的加密值,如图:
- }3 a& ^! l' G- X. x5 _9 b1 ]5 `* |4 O6 X9 y, r w- ~% T
5 n& R4 K" L" U9 f! k u
解密admin管理员密码如图:
% D# x4 n3 K: G t
3 z( z0 W+ z0 Y. x
* O& W6 _* s' A# u5 C 然后用自己写了个解密工具,解密结果和在线网站一致5 a7 ]; E p1 k8 |# Z% r R
/ @. K5 n9 I) I; y( L1 A7 L0 B
5 z8 Y4 f. p4 l _ r( o! [3 V1 L
解密后的密码为:123mhg,./,登陆如图:
* @* F: r$ t4 a" ~5 U
3、后台上传绕过漏洞getwebshell如图: 登陆后台后,在添加信息处,会有上传图片的功能,随后使用burpsuite抓包如下图:
# x$ W4 a" d& ~
0 s- S, x# d3 T+ v9 h" E9 p: P2 [* n
绕过上传限制,只需要把包里的filename的1.jpg改为1.aspx,即可成功上传webshell,如下图:
2 @1 z7 B$ h# z
访问webshell如下图:
# f0 T9 _( q: a- l+ ]9 J
4、前台任意上传漏洞getwebshell 在目标站前台有注册账号功能,注册成功后,同样在上传图片处可直接上传webshell,链接为http://www.test.cn/userRegister.aspx,登录如图:
! f8 C1 |& D# u% D) u1 e0 k0 Z* r
! P3 {: h2 L" s7 g4 r5 \& a 在上传证件或者头像的处可直接上传aspx 后缀的webshell,上传成功后,点右键-属性,可查看上传后的webshell路径为:http://www.test.cn/Admin/upload/demo.aspx 然后登录如图:7 z: v; j& L- m& A6 W
4 U, f; b A- X4 K4 ~ N4 m3 {& Q1 F6 h3 r/ v6 i- F/ m
1 ~- |* p v. C$ e' ^$ E
6 Y; l/ J) x8 `0 e8 ] 通过查看网站路径下的web.config文件得到mssql数据库配置账号为sa的密码并且以windows身份认证配置的系统登录账号密码如图:
' q g; I2 \( Z% y5 v1 U9 [5 L
$ H0 e7 Y$ P( H9 q
8 b% i/ G# s) x" _ \0 H( K 可直接利用mssql sa权限执行系统命令添加管理员账号密码或者直接利用Windows登录密码webshell下利用lcx内网端口转发登陆3389。
; W' a1 y) R, {4 Z5 b2 g& G总结:一套程序不应该只考虑其美观与功能强大,是要在满足安全的前提下再同时满足美观与功能。建议各个单位在系统上线之前,条件允许的情况下,首先进行白盒测试,其次进行黑盒测试,再次进行灰盒测试。如果通过白、黑、灰发现安全问题,那么就要再进行一轮这样的测试,直到系统难以被发现安全问题,然后再进行上线。特别是一些政府、企事业单位,数据面涉及基础人口等敏感数据,一旦遭到黑客攻击被泄露,给国家带来的损失是无法挽回的。好了以上就是今天分享的渗透内容,谢谢大家的收看!
; N: j+ A* z+ b. R5 s
| 欢迎光临 中国网络渗透测试联盟 (https://cobjon.com/) | Powered by Discuz! X3.2 |