[+] Typo
1. Information Gathering
- 포트 스캔하고
data:image/s3,"s3://crabby-images/3bc07/3bc077948615053de1599e217bdbe7eaec538eda" alt=""
data:image/s3,"s3://crabby-images/908ec/908ecde02e100fff39570688fe0956944c30d01c" alt=""
- hosts 등록하고
data:image/s3,"s3://crabby-images/2d021/2d021ed15dc0a9141adb26026091e2859d67492e" alt=""
- 디렉터리 검색해 보고
: 80
data:image/s3,"s3://crabby-images/17969/1796979e4750fc57488b43b9cba3839e021fd7c2" alt=""
: 8080
data:image/s3,"s3://crabby-images/9bcc0/9bcc0f605a8f6f7412a4b340c3b304f5d2a8a98b" alt=""
사진 설명을 입력하세요.
: 8081
data:image/s3,"s3://crabby-images/571d3/571d36f991636a9f505ea88922c10a0ee3bb3a2b" alt=""
- 하나씩 붙어보고
: 80
data:image/s3,"s3://crabby-images/b9c69/b9c698228a36cb03e4715993b84ff2020c3e4192" alt=""
- 기본 계정 테스트해보면
admin / admin
admin / password
root / root
root / password
user / user
user / password
: 이 중 하나 되는데
data:image/s3,"s3://crabby-images/67ba5/67ba587923a24f8784558cae75638a2ab37e3f09" alt=""
: 권한이 제한됨
: 8080 phpinfo
data:image/s3,"s3://crabby-images/32b1d/32b1d92fc9d2013eef506820a2811f6ea1b2247f" alt=""
: 계정 정보는 없음
: 8081
data:image/s3,"s3://crabby-images/bb3e6/bb3e694e28b65cd44ed36efe7b909eb82d25dc33" alt=""
: 로그인 시도
root / root
root / password
admin / admin
admin / password
root / admin
data:image/s3,"s3://crabby-images/55e5c/55e5c76e947b5d0156efed7bb0a64d99ea1e4d3f" alt=""
로그인 성공 후
필요한 정보 다 모음
이놈이랑 80이랑 연동되어 있는 것으로 보이니
관리자 계정 정보 확인 후 80에 로그인 시도.
2. Exploitation
DB 뒤져보면 계정 정보 확인이 가능하며
data:image/s3,"s3://crabby-images/e0d65/e0d65e85ef7311d836999eebc44446fa4bf33b91" alt=""
argon2 해싱 알고리즘
(https://www.lesstif.com/security/argon2-password-hashing-95879198.html)
으로 비번이 저장되어 있는데
온라인 argon2 해시 생성기를 통해
새로운 비번 생성 후
(ttps://argon2.online/)
data:image/s3,"s3://crabby-images/6455d/6455d467fb970bb59df6e001461eb579ecde2be2" alt=""
해당 부분을 임의의 값으로 변경해 준 뒤
data:image/s3,"s3://crabby-images/bd9a9/bd9a9bd0e4a05dd380159560a1c32c4fba217279" alt=""
admin / takudaddy
80에서 붙어보면
data:image/s3,"s3://crabby-images/ab335/ab335da5f5d6d9286b654719ea2993472921a6e3" alt=""
admin으로 로그인 성공!
php 스크립트를 업로드해 보면
data:image/s3,"s3://crabby-images/24f07/24f079bca6f3d7c5c701a97e69d369ce7e8c82e8" alt=""
data:image/s3,"s3://crabby-images/e8fbd/e8fbdaa1de8842490c843550b7526cd7968e81fc" alt=""
확장자 검증 로직이 있어 필터링 됨!
관리자 세팅 메뉴 들어가면
블랙리스트 등록된 확장자 확인이 가능하고
data:image/s3,"s3://crabby-images/cc541/cc541dddf238c5677bd103eca70996a8bd179a44" alt=""
삭제 후 등록하면 성공!
data:image/s3,"s3://crabby-images/790d5/790d55466f8033c9d1f9861aba5bade7c96e4ad0" alt=""
리스너 기동 후
파일 호스팅 하면
data:image/s3,"s3://crabby-images/219b8/219b82219f4bae78066654091485a2bcef41137a" alt=""
data:image/s3,"s3://crabby-images/c9210/c9210b61624fec20f6da4e967f1831ada1738489" alt=""
침투 성공
3. Privilege Escalation
data:image/s3,"s3://crabby-images/35164/351640c803f6021691daa6df67471edf2b53d112" alt=""
data:image/s3,"s3://crabby-images/6582a/6582a744055b8b1b975b2b4925c5b9ecd0217dd6" alt=""
apache2-restart에 Set UID 걸려있고
root 권한으로 실행되는데 파일 살펴보면
아파치를 실행시키는 명령어가 포함되어 있음
/tmp에
변조된 service 파일 생성 후
환경 변수 설정해 준 뒤
해당 파일을 실행시키면
root로 쉘이 실행될 것.
data:image/s3,"s3://crabby-images/171c9/171c916df31c4a919c20340f6ccf532788a9db8a" alt=""
data:image/s3,"s3://crabby-images/bfef5/bfef5ff3d121cd014d75c1311d71df30cbde53cf" alt=""
끝