[Hack the box] #3 Cicada
Sea를 풀 때 정말 정말 짜증났다
Medium난이도를 풀고 싶었으나......Useer Rated Difficulty가 좀 낮아보이길래..
Cicada를 도전해본다.
뜻을 검색해보니 매미인 것 같다.
그림에도 매미가 있넹
data:image/s3,"s3://crabby-images/8d4e8/8d4e8e0ad8314211d1c126e985a12a8c06b4076d" alt=""
Join machine을 눌러 ip가 나왔다. 드가자
data:image/s3,"s3://crabby-images/b1f81/b1f810d18406537e0d93705edce4e8f9130df04f" alt=""
침투 테스트의 기본 tmux을 열어준다.
data:image/s3,"s3://crabby-images/1d6c7/1d6c7c1372f4c3e049142b00ebfb150223b9bdc9" alt=""
포트가 열린게 심상치 않다. 구글에 검색해보니 AD 모듈인 것 같다. OS는 Windows 이고...또 ldap를 사용하고...어떻게 해야하지?
data:image/s3,"s3://crabby-images/6c788/6c788d35aba8427ac9ea90ab6058f8b309992321" alt=""
일단 어디부터 접근해야할지 모르겠어서 -sV 옵션을 주고 서버 정보를 수집했다.
data:image/s3,"s3://crabby-images/10f68/10f6803e83bd8e50f8bc077b199abc9ef90b619c" alt=""
88번 포트는 Kerberos가 사용하는 포트인 것 같다.
https://0xmh.tistory.com/24
이 링크를 통해 알아봤는데, Kerberos에는 Kerberoasting이라는 걸 시도해볼 수 있는 것 같다. 근데 이건 포스트 익스플로잇 공격이라 계정 정보를 한 개 알고 있다는 가정 하에 이용할 수 있어 처음 시도해볼만한 건 아닌 것 같다.
https://blog.sunggwanchoi.com/kor-keobeoroseuting-kerberoasting/
LDAP
ldapsearch를 진행했는데 결과가 자꾸 안 떴다. 뭐가 문제인 걸까?
이건 ladpsearch를 이용한 널 세션 가능 여부 체크라고 하는데 실패.
data:image/s3,"s3://crabby-images/ca505/ca50578f4749f4e61e59311756bce46cb0ab56b6" alt=""
ladp 계정 브루트포스도 실패
data:image/s3,"s3://crabby-images/fa689/fa68958c103bf187394212a286109d3eeca9de0e" alt=""
ladp 관련 nmap 스크립트도 실패
data:image/s3,"s3://crabby-images/2c38a/2c38a350edbb95f4a2db8b5480a728618f9d2ee1" alt=""
타쿠대디분 블로그에서 본 nslookup을 입력해봐도 time out 에러가 난다.
data:image/s3,"s3://crabby-images/2a588/2a58890541c3b077b61832e7d84c974ee117a3c5" alt=""
아래 명령을 통해 널 세션 바인딩이 가능한지 알아보자.
인터넷에서 쉽게 검색되는 구문들과 조금 변경되었다. -H 옵션을 줘야 하고 ldap:// 아래로 주소를 줘야 에러가 나지 않는다. ip만 기입했을 경우 Coud not parse LDAP URI 어쩌구 에러가 난다.
ldapsearch -H ldap://10.10.11.35 -x -s base namingcontexts
data:image/s3,"s3://crabby-images/34d8e/34d8e639d7ca767e6882f39a0b2d6e441fbf96e9" alt=""
data:image/s3,"s3://crabby-images/17e70/17e704a46cc1fc944bc226a25f07268adab27ecc" alt=""
SMB 연결 시도
??? 아니 다시 포트스캔을 해보니 445가 open 되어 있었다. 뭐지 ㅡㅡ
data:image/s3,"s3://crabby-images/70c1f/70c1f338d061d6347155c8e8aafb3e2545ad6a8d" alt=""
이게 막혀있는 줄 알고 ldapsearch로만 어떻게든 해보려고 했었던건데
이제 smbclinet를 한번 해볼 수 있을 것 같다.
아래 명령어를 통해 여러 가지 share가 확인이 된다.
smbclient -N -L \\10.10.11.35
data:image/s3,"s3://crabby-images/e1790/e179049ec8f5436f772df43a3a21db7150a4978c" alt=""
여러 가지 share중 HR 이라는 share에 kali에 비밀번호 없이 enter를 쳐도 연결되었다.
다른 share에도 연결은 가능했으나 ls 명령어 입력 시 access denied가 출력되는 것이 대부분이었다.
data:image/s3,"s3://crabby-images/0fe18/0fe1863cba556ea21b6fe240874e9980f4e863b1" alt=""
get 명령어를 통해 공유 폴더에서 저 txt 파일을 받아주자.
data:image/s3,"s3://crabby-images/eae97/eae978ba94b56c54292634ab8ce7ae1637b2de59" alt=""
잘 다운받아졌다.
data:image/s3,"s3://crabby-images/39e43/39e43a1b6c27b520d22f5014fb9e7941d3838d55" alt=""
Cicada 코퍼레이션에서 신입사원에서 보내는 안내 메시지인 것 같다.
내용에 default password가 존재한다.
Cicada$M6Corpb*@Lp#nZp!8
그런데 이걸 어떻게 써야 하지?
data:image/s3,"s3://crabby-images/45f74/45f74fe436525a0c0c5f9292e69dcfe60688842b" alt=""
https://seahippocampus.tistory.com/236
호스트 기반 모의 해킹 - SMB 취약점 진단
seahippocampus.tistory.com
전에 SMB 취약점 진단 공부했을 때에 배웠던 걸 써봐야겠다.
그다음으로 해볼만한 enum4linux를 써볼 것이다.
enum4linux -a "IP 주소"
-a 옵션을 주면 정보를 싹 다 알아봐준다.
data:image/s3,"s3://crabby-images/6f2e2/6f2e2d3b88b8c164dce9d94244a173d74cadec99" alt=""
아까 해봤던 것처럼 Null session도 유효하다...그런덴 이거 외엔 소득이 없었다.
data:image/s3,"s3://crabby-images/db636/db636815501355ac6e0341ba17a831e22b7ccce6" alt=""
smbcacls를 실행하니 뭔가가 떴다. david...sarah등 사람 이름이 보인다.
data:image/s3,"s3://crabby-images/2687a/2687a72a0fd3197e25b11212a550fa84040de271" alt=""
msfconsole로 smb_version 체크도 해보았다.
data:image/s3,"s3://crabby-images/48a0f/48a0f5e4993e312ac8333926aa48e5b08b48713e" alt=""
data:image/s3,"s3://crabby-images/a878f/a878fea2ff406b0688d09561973e572bc227f66a" alt=""
소용이 없었다...
netexec
SMB 침투 시에 guest나 anonymous로 접근할 수 있는 지를 파악하는 것도 중요하다고 한다.
어라 가능한 것 같다 전에 본 HR에서 READ가 가능한 걸 리스팅해준다.
data:image/s3,"s3://crabby-images/1cb5e/1cb5eefe0e65a6d8e850e67cec46e9501dae293a" alt=""
spider_plus 모듈도 사용이 가능한 것 같다.
data:image/s3,"s3://crabby-images/76072/76072118a698105a403f3723376fc691e73e85aa" alt=""
RID 사이클링
data:image/s3,"s3://crabby-images/41386/4138624a04ca23808309ec55b6e65479c7d39844" alt=""
아래 명령어를 입력하여 username.txt를 생성해준다.
netexec smb 10.10.11.35 -u guest -p '' --rid-brute 1000 | awk '{print $6}'| cut -d "\\" -f 2 >> username.txt
cat으로 읽어보자
data:image/s3,"s3://crabby-images/fb380/fb38072b9bf14b6717b8cd5b752789cfecf9bede" alt=""
어라 근데 위쪽 결과엔 david.orelious나 emily 같은 이름이 있는데
data:image/s3,"s3://crabby-images/c8be1/c8be1db6aeeb7b82a907fbefbb12410e62b29211" alt=""
username.txt에선 거기까지 저장이 되지 않았다 뭐지?
data:image/s3,"s3://crabby-images/59771/597711070dc30061ca89ee9707ce2bbb20f9e84a" alt=""
구글에 getnpusers.py를 검색 후 github에서 코드를 다운받아주자.
data:image/s3,"s3://crabby-images/11e11/11e11ce2e5e7a944aff9cf4b82f31f4bdde76e36" alt=""
data:image/s3,"s3://crabby-images/4b9bb/4b9bbc582f1b288f133ebf16615eeddaca2070b8" alt=""
아까 HR share에서 획득했던 초기 비밀번호를 가진 계정인 michael.wrightson을 찾았습니다 ㅋㅋㅋ
data:image/s3,"s3://crabby-images/691d5/691d59a51b0b916f791ad4ea23b5184197a7cf2a" alt=""
enum4linux의 Users 결과에서 david.orelious의 분실 시 비밀번호를 획득할 수 있었다.
aRt$Lp#7t*VQ!3
data:image/s3,"s3://crabby-images/e3b0d/e3b0dfce57341c07b00bd7cdab7474a94a936858" alt=""
획득한 david.orelious의 계정 정보를 통해 다시 한번 enum4linux를 해줍시다
data:image/s3,"s3://crabby-images/c7887/c78871c737e5e9fc19847d41d099cd3e11fbe8c4" alt=""
david.orelious의 권한을 보니 guest나 michael에 비해 DEV share에서 listing이 가능하군요
data:image/s3,"s3://crabby-images/52362/52362de9e729dec874b500a62fe6d0a43bb0b016" alt=""
아래 명령어로 DEV share에 접근해봅시다.
smbclient "//10.10.11.35/DEV" -U 'david.orelious'
data:image/s3,"s3://crabby-images/0922b/0922b5dd27917f39806eae78a464ed0cbeea9475" alt=""
get으로 Backup_script.ps1을 다운받은 후 읽어보니 emily.oscars의 계정 정보를 획득했습니다
Q!3@Lp#M6b*7t*Vt
data:image/s3,"s3://crabby-images/1a5ae/1a5ae16bc37f6ce88decd9706ce88b19289ca0a9" alt=""
data:image/s3,"s3://crabby-images/a337c/a337cef2c8280c13e76ba82bee3f124a0e6f20ec" alt=""
emily는 ADMIN$ share에 접근이 가능한 것 같네요
data:image/s3,"s3://crabby-images/a0348/a03482961b9fc6ed8840e3e373234bb701a16199" alt=""
evil-winrm이라는 툴을 이용해 shell에 접속해줍니다.
data:image/s3,"s3://crabby-images/a83d0/a83d0e969b7ca4ca7dcbefa621d4e5be3509c44a" alt=""
data:image/s3,"s3://crabby-images/0cc84/0cc842e57ff36353f0eabb45b6b1ffa81dd4ed83" alt=""
data:image/s3,"s3://crabby-images/150ad/150ada2af28e229b712eaa7edec4b9bd10d24a4f" alt=""
user flag 해결!
data:image/s3,"s3://crabby-images/e8940/e89400d97cd9eb9343d62bc067a454d496e2aaa5" alt=""
ROOT 플래그
진짜 AD 모듈 처음해봐서 유저도 사람들의 흔적을 따라 따라 풀었는데 아직 root가 남았다니...
emily.oscars.CICADA 디렉토리에서 나갔더니 Administrator 디렉토리가 있었다.
data:image/s3,"s3://crabby-images/c7b18/c7b18788215b3e15d696a889b9edc8f56f00db44" alt=""
그러고 Desktop 폴더에 root.txt 가 있었으나 역시나 cat으로는 Permission denied가 떴다.
data:image/s3,"s3://crabby-images/a7305/a7305a232da657489c253b47caf136a7bd50c38d" alt=""
whoami /priv 명령어를 통해 권한을 살펴보면,
SeBackupPrivilege권한이 있다. 상당히 위험한 권한이라고 한다.
data:image/s3,"s3://crabby-images/c30b8/c30b8735f91dd84d510cbb3f39c50b9806e3a24f" alt=""
Temp 디렉토리로 이동해보면 sam 과 system 파일이 있습니다.
data:image/s3,"s3://crabby-images/450fd/450fd452c0a6e84ece531526bd1d50f1ecb7efca" alt=""
이걸 해야 한다는데 왜 난 잘 안 됐지?
data:image/s3,"s3://crabby-images/7b6d2/7b6d229f42f8f305d0fa320d1eae3d7ea1b2c28c" alt=""
reg save를 입력하고 가만히 있으면 되는 건지 안되는건지 알 수가 없다 ㅋㅋ
data:image/s3,"s3://crabby-images/e25e0/e25e09708dc0995888efd5c5e53350a601772043" alt=""
일단 download 해보기로함.
data:image/s3,"s3://crabby-images/d136e/d136e77f6d9a4cb56a1cb14a3c2d3585c6291a18" alt=""
sam도 다운이 잘되었고 download system도 잘되는 것 같다.
data:image/s3,"s3://crabby-images/e329d/e329de1d7cab4f910eabe8421e1cf4fc1eb4c61d" alt=""
ls로 확인해보니 잘 다운로드 되었네요
data:image/s3,"s3://crabby-images/4fd04/4fd04fb434465e47548c8806ec808dfe7f958aee" alt=""
아래 명령어를 통해 NT 해쉬값을 획득해봅시다. Administrator 항목에 뒤쪽 값이 NT 해쉬입니다.
impacket-secretsdump -sam sam -system system LOCAL
data:image/s3,"s3://crabby-images/d6abe/d6abe290050a3f3fccd0f72957a9d9224289b8b2" alt=""
NT 해시를 의미하는 -H 플래그를 이용해서 Administrator 계정으로 로그인을 해줍시다.
로그인 성공!!
data:image/s3,"s3://crabby-images/ba8b4/ba8b40911a612972e878484bd2cecb8d1ecef779" alt=""
이제 root.txt를 읽어서 root 플래그를 획득했습니다
data:image/s3,"s3://crabby-images/9d21c/9d21c69ba1eeb2663e4e747f952f4996e4830905" alt=""
휴,,,,,,역대급 난감했던 Windows 서버 모의침투였던 것 같습니다
이게 어떻게 easy 냐고...
그래도 많이 배울 수 있어 만족합니다.
data:image/s3,"s3://crabby-images/481c7/481c784fcaa2f190f5ee8056b2253bb12d58b707" alt=""
AD공략:https://takudaddy.tistory.com/557
Hack the box 모의해킹 침투 Sizzle : https://0xmh.tistory.com/24
Hackthebox 다른 박스 writeup : https://arth0s.medium.com/hackthebox-rebound-write-up-insane-ab8eb3679bff
Hackthebox cicada writeup : https://codingwoo.tistory.com/25