前言( l' l- Z6 n6 f6 ~. |
* R4 ?2 f- _& ]9 c4 G[color=#333333 !important]这篇文章主要说的是我在这次内部测试的任务中,如何一步步获取应用系统最高权限,总的来说,是各种小漏洞的组合拳。因是内部系统,所以打码稍微严重些。
. o. T; L% ?; l3 ]1 j q; A' u正文: g# J8 q9 Z( A, M. L8 P
7 B6 r! u6 ?. k" B. x5 O! a. v
[color=#333333 !important]在兴(suo)致(ran)盎(wu)然(wei)的某一工作日,突然接到领导的指示,要对内部的运维平台进行渗透测试。
% E0 V) f3 Q$ r) q0 j; V1 ?[color=#333333 !important]  }0 a# h. J% \
[color=#333333 !important]在收到消息的第二天,我精(wan)神(ban)抖(wu)擞(nai)的开始了我的工作。要到测试地址后,我一看,卧槽,果然不出所料,只有一个登陆框。
+ u ^# l# A/ Y! D2 l[color=#333333 !important] + y, R5 j8 h. {5 w2 ?. @. {! y2 X
[color=#333333 !important]对于这种系统,我在心里告诉自己,不要慌,办法总比困难多,随便找两个低危漏洞交差了事,并且又想到,这是生产系统,全国几十个分公司都实时在用,可不能搞瘫痪了,最终我说服自己不扫描、不测影响业务的漏洞,这样一想,我心里立马更坚定了只找两个低位漏洞交差的想法。我果然是聪敏人!!: ~ O0 V+ O3 k. _' w
开始3 J A1 X* e) g1 M
' Q& g1 _! m8 _6 l& {5 X: d* G w/ Z' x[color=#333333 !important]好的,接下来我就简单的收集了些信息1 ]1 p: |1 ]" e, t( J# I
[color=#333333 !important]首先用google插件wapplyzer,查看了当前系统的信息
; m8 ?" ~" r8 n2 {[color=#333333 !important] 
, o- Q% \2 L: U; c: q! c[color=#333333 !important]为了不被防火墙拉黑,nmap简单的跑了一下,就是探测一些常见的端口,看看管理员有没有部署一些用于测试的垃圾站。。。。结果可想而知。4 Q8 A0 t+ p1 Q- v! _ h
[color=#333333 !important] 
0 X" Y% {4 s Y+ L9 I[color=#333333 !important]还跑过系统目录,钟馗也看了下等等,没什么有用信息,就不贴图了。5 b# G3 k% T( s9 y: y! {. Z
[color=#333333 !important]看来确实要对主站完全手工了,只能打开神器burp分析数据包,尽量挖一些逻辑上的漏洞。# u. `1 _# n4 f3 T' g* ^ X2 s
[color=#333333 !important]我看了登录框,没验证码,首先想到的肯定是对admin账号先爆破一波。然而:当我输入几次登录信息后,发现用户名密码错误提示是一样的,且有5次错误锁定策略,那肯定就不能直接进行爆破了。
7 \% ]9 {% r: E! j) P[color=#333333 !important]
0 \$ u- k+ v; b8 V6 n% n) }- ?& x[color=#333333 !important]接着看网页源码也没什么有用信息,但看包竟然是明文传输的,这种情况下,采用单次撞库是最合适的手段。
7 }5 U- z$ v# y }4 ]2 q[color=#333333 !important]  ; \ i2 @9 B) j/ P0 r
[color=#333333 !important]接下来就是祭出burp,抓包,撞库,用topname10000进行撞库,幸好没用tonname500,要不然可能就凉了
* e3 o0 k4 B |2 d( R g# m[color=#333333 !important] 
% E! W6 r# j$ H, f6 B4 {[color=#333333 !important]运气不错啊,一万里面总算还有两个成功的,看来后台的弱口令总是会有漏网之鱼。* S5 m! q+ `/ v; @1 Z; w
[color=#333333 !important]到这,我觉得我的工作已经算是超额了,可以交差了。但想着将要面对领导那慈祥的眼神,我只能瑟瑟发抖的再接着往下测。
* V8 R0 p8 o! [9 P: D3 P[color=#333333 !important]登录wu**这个账号到系统里面,发现这个账号权限很低,不行,满足不了自己的需求,再尝试登录另一个账号,苍天有眼,竟然有新建账号的权限,看来是个当官的了。。。
7 F- ?5 q0 `/ s- F[color=#333333 !important]  0 R7 L: r1 ^0 W7 [( |
[color=#333333 !important]接下来就是对账号新建功能一系列的尝试,过程就略了。。。。只说结果。
* d6 {- u" I K0 ][color=#333333 !important]在新建账号发现在选择角色处,某一个角色权限竟然比自己使用的账号的权限还要高,果断就建了一个账号systemtest。; ~+ Q" J: p* G
[color=#333333 !important] " j$ p- @% I, ~/ \0 v4 F
[color=#333333 !important]然后再登录systemtest发现,有更多的模块,而其中一项竟然是角色管理,而这个角色管理可以新建一个角色,并且新建角色尽然可以选择拥有所有模块的权限,以我的作风,那必须立马盘它。' v5 s& v) K3 m n- P( b" T: d
[color=#333333 !important] : `! ^0 [; i+ V3 i" R
[color=#333333 !important]到此,感觉到浑身充满了力量,这么容易就拿下了最高权限?迫不及待的我立马新建了一个角色,一个账号systemtest2,登录。。。
+ t7 B( M6 e! O+ E[color=#333333 !important]
9 d, a" d& {% N& p* n+ ]) ^( [' F[color=#333333 !important]噗。。看到这画面,我就蒙了,现实果然给了我一个狠狠的耳刮子,这个权限竟然只有某一个分公司的最高权限,而不是系统总部的最高权限,这可不行,都到这了,一定要拿下总部的最高权限。
! d$ X4 V& _: {& B4 k0 ~# m% D# D[color=#333333 !important]接着,我又开始目的性很强的功能分析与寻找,其实就是胡乱点击,过程就略了…..最终我在查看用户信息的时候发现,发现一个很有特色的参数,而这个参数很像用户的ID值1 F9 S x: d- T0 m5 J8 a
[color=#333333 !important]
# s" ]$ P8 I; R" |2 t+ W) o2 L[color=#333333 !important]以我的聪(cai)明(shu)才(xue)智(qian)立马感觉这参数有戏,果不其然,我一访问,就感觉发现了新大陆一样 t* s3 s- A4 x7 R+ n7 i6 k
[color=#333333 !important] / M$ N2 g) m/ h5 o$ \; ^
[color=#333333 !important]遍历340这个值,就可以直接修改个人信息啊。然后我经过测试,顺利的发现了admin账号的信息! N4 e2 s' v- @- \& X5 }- W7 ]" I
[color=#333333 !important] : t0 |/ \0 z$ M0 j$ @$ s3 g+ Y
[color=#333333 !important]到了这一步,我就要举一反三了,既然可以修改用户信息,那是不是也可以越权修改用户密码呢?带着这个疑问,我直接到修改个人密码功能的地方,果然可以越权访问修改密码的URL。。 t* L; L, h) L: A1 S3 R
[color=#333333 !important]
! u- q& F; f0 s% U. [4 V& l( z4 X[color=#333333 !important]接下来就是要必须解决旧密码的问题,只能去尝试是否可以绕过,没办法,只有抓包分析了。
' [, S5 `, @, j0 H* o- o[color=#333333 !important]咦。。。当我在输入旧密码后,准备输入新密码时,系统竟然会先对旧密码进行判定,我就在想这很可能可以绕过旧密码验证0 v% c# `* u9 F2 R, q3 l: ^: Z
[color=#333333 !important] 4 S- d$ K, K7 O( m$ u- N9 Q
[color=#333333 !important]我马上进行了抓包,果不其然,判定条件就以true/false来判定的,到了这,我感觉我要成功了,有点开始飘了,看来可以交差了。我把response结果改为true,长度改为4,果然成功绕过了验证。哈哈….
7 h: }" J8 B$ h4 R[color=#333333 !important] . D% u: j/ L# k. @
[color=#333333 !important]那接下来就一切顺利了,修改了admin密码,并成功登陆,看到了所有分公司的数据。。。。。。。
% G& Z r2 x5 z[color=#333333 !important] , \0 f, H% T( T9 B& S- c0 U, M
[color=#333333 !important]至此,就一切结束了,可以交差了。' t$ a F* _& u/ z& T5 \
[color=#333333 !important]测试的工作嘛,到这就结束了,至于拿shell,后渗透这些什么的,就再慢慢弄算了。。先把报告除了再说。" Y5 w1 I9 J/ a# ?% I
结语
) }5 r7 i8 A/ a# \" m. e P* x- L' O3 n. o0 Q; p. Q
[color=#333333 !important]拿下系统的最高权限并不是仅仅单靠某一漏洞,而是靠的各种小漏洞的组合拳,首先是明文传输,这就有了撞库的机会,然后是有弱口令,撞库才会成功,然后功能设计上也有缺陷,低权限的账号怎么能新建高权限的账号呢?设计者这就应该挨板子了,再然后才有越权访问admin信息,再有原密码的绕过,这一系列小漏洞单独来说不严重,但一旦结合起来,就出现了很严重的安全事件,在进行安全防护工作时,应尽量考虑周全,任何一个弱点都可能成为黑客的突破口。
, l& g; `9 W5 b/ V/ }5 J% s[color=#333333 !important]*本文原创作者:jin16879,本文属FreeBuf原创奖励计划,未经许可禁止转载/ l& q- o. O3 ^1 `9 H8 n
9 Z: K' T! J9 } Y" t# R, [ y! G1 m
精彩推荐' ^; E3 S1 C) u7 w) N, Q! O( k8 r9 b

1 E% K4 ^% A) w3 }
$ m3 V: |3 u% v" A" g- @( k' [! g" F4 a# V" e
X i% T$ F/ L1 |' l! R' {# W8 t4 E- N2 g2 d( `9 O* R5 K2 U
1 O. w, \6 k( R2 Z8 V: H+ l来源:http://mp.weixin.qq.com/s?src=11×tamp=1568725204&ver=1858&signature=DxJVEBSwOthYKl*uBSD3zgNSK1sAzJafqmvmUeqFNMujmJXWZUpUnY2b*l2RcPqdf52-nadXzBAqh*TwTm1cLX-AomPN2watgbpYzoHVMxp4P1Ax7M*5F3kLSuq5mFjP&new=1
2 I% j3 G1 \, X$ M! ~免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |