Linux Privilege Escalation
Last updated
Last updated
Learn & practice AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Learn & practice GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
운영 중인 OS에 대한 지식을 얻기 시작합시다.
만약 PATH
변수 내의 어떤 폴더에 쓰기 권한이 있다면 일부 라이브러리나 바이너리를 탈취할 수 있습니다:
환경 변수에 흥미로운 정보, 비밀번호 또는 API 키가 있습니까?
커널 버전을 확인하고 권한 상승에 사용할 수 있는 취약점이 있는지 확인하십시오.
좋은 취약한 커널 목록과 이미 컴파일된 익스플로잇을 여기에서 찾을 수 있습니다: https://github.com/lucyoa/kernel-exploits 및 exploitdb sploits. 다른 컴파일된 익스플로잇을 찾을 수 있는 사이트: https://github.com/bwbwbwbw/linux-exploit-binaries, https://github.com/Kabot/Unix-Privilege-Escalation-Exploits-Pack
그 웹에서 모든 취약한 커널 버전을 추출하려면 다음과 같이 할 수 있습니다:
도움이 될 수 있는 커널 익스플로잇 검색 도구는 다음과 같습니다:
linux-exploit-suggester.sh linux-exploit-suggester2.pl linuxprivchecker.py (피해자에서 실행, 커널 2.x에 대한 익스플로잇만 확인)
항상 Google에서 커널 버전을 검색하세요, 아마도 귀하의 커널 버전이 어떤 커널 익스플로잇에 기록되어 있을 것이며, 그러면 이 익스플로잇이 유효하다는 것을 확신할 수 있습니다.
Linux 권한 상승 - Linux Kernel <= 3.19.0-73.8
취약한 sudo 버전을 기반으로 합니다:
You can check if the sudo version is vulnerable using this grep. 이 grep을 사용하여 sudo 버전이 취약한지 확인할 수 있습니다.
From @sickrov
이 취약점이 어떻게 악용될 수 있는지에 대한 예시는 HTB의 smasher2 박스를 확인하세요.
Docker 컨테이너 내부에 있다면 탈출을 시도할 수 있습니다:
Docker Security마운트된 것과 마운트 해제된 것을 확인하고, 어디서 왜 그런지 확인하세요. 만약 어떤 것이 마운트 해제되어 있다면, 그것을 마운트하고 개인 정보를 확인해 볼 수 있습니다.
유용한 바이너리 나열
또한 어떤 컴파일러가 설치되어 있는지 확인하십시오. 이는 커널 익스플로잇을 사용해야 할 경우 유용하며, 이를 사용할 머신(또는 유사한 머신)에서 컴파일하는 것이 권장됩니다.
설치된 패키지 및 서비스의 버전을 확인하십시오. 권한 상승을 위해 악용될 수 있는 오래된 Nagios 버전(예:)이 있을 수 있습니다… 더 의심스러운 설치된 소프트웨어의 버전을 수동으로 확인하는 것이 좋습니다.
SSH를 통해 머신에 접근할 수 있다면, openVAS를 사용하여 머신에 설치된 구식 및 취약한 소프트웨어를 확인할 수 있습니다.
이 명령어들은 대부분 쓸모없는 많은 정보를 보여줄 것이므로, 설치된 소프트웨어 버전이 알려진 취약점에 취약한지 확인할 수 있는 OpenVAS와 같은 애플리케이션을 사용하는 것이 권장됩니다.
어떤 프로세스가 실행되고 있는지 살펴보고, 어떤 프로세스가 필요 이상으로 권한이 있는지 확인하세요 (예: root로 실행되는 tomcat?).
항상 가능한 electron/cef/chromium 디버거가 실행 중인지 확인하세요. 이를 악용하여 권한을 상승시킬 수 있습니다. Linpeas는 프로세스의 명령줄에서 --inspect
매개변수를 확인하여 이를 감지합니다.
또한 프로세스 바이너리에 대한 권한을 확인하세요, 누군가를 덮어쓸 수 있을지도 모릅니다.
pspy와 같은 도구를 사용하여 프로세스를 모니터링할 수 있습니다. 이는 자주 실행되는 취약한 프로세스를 식별하거나 특정 요구 사항이 충족될 때 매우 유용할 수 있습니다.
서버의 일부 서비스는 메모리 내에 자격 증명을 평문으로 저장합니다. 일반적으로 다른 사용자의 프로세스 메모리를 읽으려면 루트 권한이 필요하므로, 이는 보통 이미 루트일 때 더 많은 자격 증명을 발견하고자 할 때 유용합니다. 그러나 일반 사용자로서 자신이 소유한 프로세스의 메모리를 읽을 수 있다는 점을 기억하세요.
현재 대부분의 머신은 기본적으로 ptrace를 허용하지 않습니다. 이는 권한이 없는 사용자가 소속된 다른 프로세스를 덤프할 수 없음을 의미합니다.
파일 _/proc/sys/kernel/yama/ptrace_scope_는 ptrace의 접근성을 제어합니다:
kernel.yama.ptrace_scope = 0: 모든 프로세스는 동일한 uid를 가진 한 디버깅할 수 있습니다. 이것이 ptracing이 작동하던 고전적인 방식입니다.
kernel.yama.ptrace_scope = 1: 부모 프로세스만 디버깅할 수 있습니다.
kernel.yama.ptrace_scope = 2: 오직 관리자만 ptrace를 사용할 수 있으며, 이는 CAP_SYS_PTRACE 권한이 필요합니다.
kernel.yama.ptrace_scope = 3: 어떤 프로세스도 ptrace로 추적할 수 없습니다. 설정 후에는 ptracing을 다시 활성화하려면 재부팅이 필요합니다.
FTP 서비스의 메모리에 접근할 수 있다면 (예를 들어) 힙을 가져와 그 안의 자격 증명을 검색할 수 있습니다.
주어진 프로세스 ID에 대해, maps는 해당 프로세스의 가상 주소 공간 내에서 메모리가 어떻게 매핑되어 있는지를 보여줍니다; 또한 각 매핑된 영역의 권한도 보여줍니다. mem 가상 파일은 프로세스의 메모리 자체를 노출합니다. maps 파일에서 우리는 어떤 메모리 영역이 읽을 수 있는지와 그 오프셋을 알 수 있습니다. 우리는 이 정보를 사용하여 mem 파일로 이동하고 모든 읽을 수 있는 영역을 파일로 덤프합니다.
/dev/mem
은 시스템의 물리적 메모리에 접근을 제공합니다. 커널의 가상 주소 공간은 /dev/kmem을 사용하여 접근할 수 있습니다.
일반적으로 /dev/mem
은 root와 kmem 그룹만 읽을 수 있습니다.
ProcDump는 Windows의 Sysinternals 도구 모음에서 클래식 ProcDump 도구를 재구성한 Linux 버전입니다. https://github.com/Sysinternals/ProcDump-for-Linux에서 다운로드하세요.
프로세스 메모리를 덤프하려면 다음을 사용할 수 있습니다:
https://github.com/hajzer/bash-memory-dump (root) - _루트 요구 사항을 수동으로 제거하고 귀하가 소유한 프로세스를 덤프할 수 있습니다
https://www.delaat.net/rp/2016-2017/p97/report.pdf의 스크립트 A.5 (루트가 필요함)
인증 프로세스가 실행 중인 것을 발견하면:
프로세스를 덤프할 수 있습니다(프로세스의 메모리를 덤프하는 다양한 방법을 찾으려면 이전 섹션을 참조하십시오) 그리고 메모리 내에서 자격 증명을 검색할 수 있습니다:
도구 https://github.com/huntergregal/mimipenguin은 메모리에서 평문 자격 증명을 훔치고 일부 잘 알려진 파일에서 가져옵니다. 제대로 작동하려면 루트 권한이 필요합니다.
GDM 비밀번호 (Kali Desktop, Debian Desktop)
gdm-password
Gnome Keyring (Ubuntu Desktop, ArchLinux Desktop)
gnome-keyring-daemon
LightDM (Ubuntu Desktop)
lightdm
VSFTPd (활성 FTP 연결)
vsftpd
Apache2 (활성 HTTP 기본 인증 세션)
apache2
OpenSSH (활성 SSH 세션 - Sudo 사용)
sshd:
예약된 작업이 취약한지 확인하십시오. 루트에 의해 실행되는 스크립트를 이용할 수 있을지도 모릅니다 (와일드카드 취약점? 루트가 사용하는 파일을 수정할 수 있습니까? 심볼릭 링크를 사용할 수 있습니까? 루트가 사용하는 디렉토리에 특정 파일을 생성할 수 있습니까?).
예를 들어, /etc/crontab 안에서 PATH를 찾을 수 있습니다: PATH=/home/user:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
(사용자 "user"가 /home/user에 대한 쓰기 권한을 가지고 있는 것을 주목하세요)
이 crontab 안에서 root 사용자가 경로를 설정하지 않고 어떤 명령이나 스크립트를 실행하려고 하면, 예를 들어: * * * * root overwrite.sh 그렇다면, 다음을 사용하여 root 쉘을 얻을 수 있습니다:
루트에 의해 실행되는 스크립트가 명령어 안에 “*”를 포함하고 있다면, 이를 이용해 예상치 못한 일을 발생시킬 수 있습니다 (예: 권한 상승). 예:
경로가 /some/path/* 와 같이 와일드카드가 앞에 오면 취약하지 않습니다 (심지어 ./* 도 그렇습니다).
와일드카드 악용 기법에 대한 더 많은 정보를 보려면 다음 페이지를 읽어보세요:
Wildcards Spare tricks루트에 의해 실행되는 크론 스크립트를 수정할 수 있다면, 매우 쉽게 쉘을 얻을 수 있습니다:
루트에 의해 실행되는 스크립트가 당신이 완전한 접근 권한을 가진 디렉토리를 사용한다면, 그 폴더를 삭제하고 당신이 제어하는 스크립트를 제공하는 다른 폴더에 대한 심볼릭 링크 폴더를 생성하는 것이 유용할 수 있습니다.
1분, 2분 또는 5분마다 실행되는 프로세스를 검색하기 위해 프로세스를 모니터링할 수 있습니다. 이를 활용하여 권한을 상승시킬 수 있습니다.
예를 들어, 1분 동안 0.1초마다 모니터링하고, 덜 실행된 명령어로 정렬한 후, 가장 많이 실행된 명령어를 삭제하려면 다음과 같이 할 수 있습니다:
다음과 같이 사용할 수 있습니다 pspy (이것은 시작하는 모든 프로세스를 모니터링하고 나열합니다).
주석 뒤에 캐리지 리턴을 넣어 크론 작업을 생성하는 것이 가능합니다 (줄 바꿈 문자가 없이), 그리고 크론 작업이 작동합니다. 예시 (캐리지 리턴 문자를 주목하세요):
.service
파일을 쓸 수 있는지 확인하세요. 쓸 수 있다면, 서비스가 시작, 재시작 또는 중지될 때 백도어를 실행하도록 수정할 수 있습니다 (아마도 기계가 재부팅될 때까지 기다려야 할 것입니다).
예를 들어, **ExecStart=/tmp/script.sh
**와 함께 .service 파일 안에 백도어를 생성하세요.
서비스에 의해 실행되는 바이너리에 쓰기 권한이 있는 경우, 이를 백도어로 변경할 수 있으므로 서비스가 다시 실행될 때 백도어가 실행됩니다.
systemd에서 사용되는 PATH를 확인할 수 있습니다:
만약 경로의 폴더 중 어느 곳에서든 쓰기가 가능하다면, 권한 상승을 할 수 있을지도 모릅니다. 다음과 같은 서비스 구성 파일에서 사용되는 상대 경로를 검색해야 합니다:
그런 다음, 쓸 수 있는 systemd PATH 폴더 내에 상대 경로 바이너리와 같은 이름의 실행 파일을 생성하고, 서비스가 취약한 작업(Start, Stop, Reload)을 실행하라고 요청받으면 귀하의 백도어가 실행됩니다 (비특권 사용자는 일반적으로 서비스를 시작/중지할 수 없지만 sudo -l
을 사용할 수 있는지 확인하십시오).
man systemd.service
로 서비스에 대해 더 알아보세요.
타이머는 **.service**
파일이나 이벤트를 제어하는 **.timer**
로 끝나는 systemd 유닛 파일입니다. 타이머는 달력 시간 이벤트와 단조 시간 이벤트에 대한 기본 지원이 있어 비동기적으로 실행될 수 있으므로 cron의 대안으로 사용할 수 있습니다.
다음 명령어로 모든 타이머를 나열할 수 있습니다:
타이머를 수정할 수 있다면, 시스템의 일부인 systemd.unit(예: .service
또는 .target
)을 실행하도록 만들 수 있습니다.
문서에서 유닛이 무엇인지 읽을 수 있습니다:
이 타이머가 만료될 때 활성화할 유닛. 인수는 ".timer"가 아닌 유닛 이름입니다. 지정하지 않으면 이 값은 접미사를 제외하고 타이머 유닛과 동일한 이름을 가진 서비스로 기본 설정됩니다. (위 참조.) 활성화되는 유닛 이름과 타이머 유닛의 유닛 이름은 접미사를 제외하고 동일하게 명명하는 것이 좋습니다.
따라서 이 권한을 악용하려면 다음이 필요합니다:
쓰기 가능한 바이너리를 실행하는 일부 systemd 유닛(예: .service
) 찾기
상대 경로를 실행하는 일부 systemd 유닛을 찾고, systemd PATH에 대해 쓰기 권한이 있어야 합니다(해당 실행 파일을 가장하기 위해)
타이머에 대해 더 알아보려면 man systemd.timer
를 참조하세요.
타이머를 활성화하려면 루트 권한이 필요하며 다음을 실행해야 합니다:
Note the timer is activated by creating a symlink to it on /etc/systemd/system/<WantedBy_section>.wants/<name>.timer
Unix Domain Sockets (UDS)는 클라이언트-서버 모델 내에서 동일하거나 다른 머신 간의 프로세스 통신을 가능하게 합니다. 이들은 컴퓨터 간 통신을 위해 표준 Unix 설명자 파일을 사용하며, .socket
파일을 통해 설정됩니다.
Sockets can be configured using .socket
files.
Learn more about sockets with man systemd.socket
. Inside this file, several interesting parameters can be configured:
ListenStream
, ListenDatagram
, ListenSequentialPacket
, ListenFIFO
, ListenSpecial
, ListenNetlink
, ListenMessageQueue
, ListenUSBFunction
: 이러한 옵션은 다르지만 소켓이 어디에서 수신 대기할지를 나타내기 위해 요약됩니다 (AF_UNIX 소켓 파일의 경로, 수신 대기할 IPv4/6 및/또는 포트 번호 등)
Accept
: 부울 인수를 받습니다. true인 경우, 각 수신 연결에 대해 서비스 인스턴스가 생성되며, 연결 소켓만 전달됩니다. false인 경우, 모든 수신 대기 소켓 자체가 시작된 서비스 유닛에 전달되며, 모든 연결에 대해 하나의 서비스 유닛만 생성됩니다. 이 값은 단일 서비스 유닛이 모든 수신 트래픽을 무조건 처리하는 데이터그램 소켓 및 FIFO에 대해 무시됩니다. 기본값은 false입니다. 성능상의 이유로, Accept=no
에 적합한 방식으로만 새로운 데몬을 작성하는 것이 권장됩니다.
ExecStartPre
, ExecStartPost
: 수신 대기 소켓/FIFO가 생성되고 바인딩되기 전후에 실행되는 하나 이상의 명령줄을 받습니다. 명령줄의 첫 번째 토큰은 절대 파일 이름이어야 하며, 그 다음에 프로세스에 대한 인수가 옵니다.
ExecStopPre
, ExecStopPost
: 수신 대기 소켓/FIFO가 닫히고 제거되기 전후에 실행되는 추가 명령입니다.
Service
: 수신 트래픽에 대해 활성화할 서비스 유닛 이름을 지정합니다. 이 설정은 Accept=no인 소켓에 대해서만 허용됩니다. 기본적으로 소켓과 동일한 이름을 가진 서비스로 설정됩니다 (접미사가 대체됨). 대부분의 경우, 이 옵션을 사용할 필요는 없습니다.
쓰기 가능한 .socket
파일을 찾으면 [Socket]
섹션의 시작 부분에 ExecStartPre=/home/kali/sys/backdoor
와 같은 내용을 추가할 수 있으며, 그러면 소켓이 생성되기 전에 백도어가 실행됩니다. 따라서 기계가 재부팅될 때까지 기다려야 할 것입니다.
&#xNAN;Note that the system must be using that socket file configuration or the backdoor won't be executed
쓰기 가능한 소켓을 식별하면 (지금은 Unix 소켓에 대해 이야기하고 있으며 구성 .socket
파일에 대해 이야기하는 것이 아닙니다), 해당 소켓과 통신할 수 있으며 아마도 취약점을 악용할 수 있습니다.
악용 예시:
Socket Command InjectionHTTP 요청을 수신 대기하는 소켓이 있을 수 있습니다 (저는 .socket 파일이 아니라 유닉스 소켓으로 작동하는 파일에 대해 이야기하고 있습니다). 다음을 통해 확인할 수 있습니다:
If the socket responds with an HTTP request, then you can communicate with it and maybe exploit some vulnerability.
Docker 소켓은 일반적으로 /var/run/docker.sock
에 위치하며, 보안이 필요한 중요한 파일입니다. 기본적으로 root
사용자와 docker
그룹의 구성원이 쓸 수 있습니다. 이 소켓에 대한 쓰기 권한을 가지면 권한 상승이 발생할 수 있습니다. 다음은 이를 수행하는 방법과 Docker CLI를 사용할 수 없는 경우의 대체 방법에 대한 설명입니다.
If you have write access to the Docker socket, you can escalate privileges using the following commands:
These commands allow you to run a container with root-level access to the host's file system.
Docker CLI를 사용할 수 없는 경우에도 Docker 소켓을 Docker API와 curl
명령어를 사용하여 조작할 수 있습니다.
Docker 이미지 목록: 사용 가능한 이미지 목록을 가져옵니다.
컨테이너 생성: 호스트 시스템의 루트 디렉토리를 마운트하는 컨테이너를 생성하기 위한 요청을 보냅니다.
새로 생성된 컨테이너를 시작합니다:
컨테이너에 연결: socat
을 사용하여 컨테이너에 연결을 설정하고, 그 안에서 명령을 실행할 수 있습니다.
socat
연결을 설정한 후, 호스트 파일 시스템에 대한 루트 수준 액세스를 통해 컨테이너 내에서 직접 명령을 실행할 수 있습니다.
docker 그룹에 속해 있기 때문에 docker 소켓에 대한 쓰기 권한이 있는 경우 권한 상승을 위한 더 많은 방법이 있습니다. docker API가 포트에서 수신 대기 중인 경우 이를 타겟으로 삼을 수 있습니다.
docker에서 탈출하거나 이를 남용하여 권한을 상승시키는 더 많은 방법을 확인하세요:
Docker Securityctr
명령을 사용할 수 있는 경우 권한 상승을 위해 이를 남용할 수 있습니다:
runc
명령을 사용할 수 있는 경우 권한 상승을 위해 이를 남용할 수 있습니다:
D-Bus는 애플리케이션이 효율적으로 상호 작용하고 데이터를 공유할 수 있도록 하는 정교한 프로세스 간 통신(IPC) 시스템입니다. 현대 Linux 시스템을 염두에 두고 설계되어 다양한 형태의 애플리케이션 통신을 위한 강력한 프레임워크를 제공합니다.
이 시스템은 기본 IPC를 지원하여 프로세스 간 데이터 교환을 향상시키며, 향상된 UNIX 도메인 소켓을 연상시킵니다. 또한 이벤트나 신호를 브로드캐스트하여 시스템 구성 요소 간의 원활한 통합을 촉진합니다. 예를 들어, Bluetooth 데몬에서 수신 전화에 대한 신호가 음악 플레이어를 음소거하도록 할 수 있어 사용자 경험을 향상시킵니다. 또한 D-Bus는 원격 객체 시스템을 지원하여 애플리케이션 간의 서비스 요청 및 메서드 호출을 간소화하여 전통적으로 복잡했던 프로세스를 간소화합니다.
D-Bus는 허용/거부 모델에서 작동하며, 정책 규칙의 누적 효과에 따라 메시지 권한(메서드 호출, 신호 전송 등)을 관리합니다. 이러한 정책은 버스와의 상호 작용을 지정하며, 이러한 권한을 악용하여 권한 상승을 허용할 수 있습니다.
/etc/dbus-1/system.d/wpa_supplicant.conf
에 있는 정책의 예는 root 사용자가 fi.w1.wpa_supplicant1
으로부터 메시지를 소유하고, 전송하고, 수신할 수 있는 권한을 자세히 설명합니다.
지정된 사용자나 그룹이 없는 정책은 보편적으로 적용되며, "기본" 컨텍스트 정책은 다른 특정 정책에 의해 다루어지지 않는 모든 경우에 적용됩니다.
D-Bus 통신을 열거하고 악용하는 방법을 여기에서 배우십시오:
D-Bus Enumeration & Command Injection Privilege Escalation네트워크를 열거하고 머신의 위치를 파악하는 것은 항상 흥미롭습니다.
항상 접근하기 전에 상호작용할 수 없었던 머신에서 실행 중인 네트워크 서비스를 확인하세요:
트래픽을 스니핑할 수 있는지 확인하세요. 가능하다면, 자격 증명을 잡을 수 있을 것입니다.
당신이 누구인지, 어떤 권한이 있는지, 시스템에 어떤 사용자가 있는지, 어떤 사용자가 로그인할 수 있는지, 그리고 어떤 사용자가 루트 권한을 가지고 있는지 확인하십시오:
일부 Linux 버전은 UID > INT_MAX를 가진 사용자가 권한을 상승시킬 수 있는 버그의 영향을 받았습니다. 더 많은 정보: 여기, 여기 및 여기.
이용하기: systemd-run -t /bin/bash
루트 권한을 부여할 수 있는 그룹의 구성원인지 확인하세요:
Interesting Groups - Linux Privesc클립보드에 흥미로운 내용이 있는지 확인하세요 (가능한 경우)
환경의 어떤 비밀번호를 알고 있다면 해당 비밀번호를 사용하여 각 사용자로 로그인해 보세요.
많은 소음을 내는 것에 신경 쓰지 않고 su
와 timeout
바이너리가 컴퓨터에 존재한다면, su-bruteforce를 사용하여 사용자를 무차별 대입 공격할 수 있습니다.
Linpeas도 -a
매개변수를 사용하여 사용자 무차별 대입 공격을 시도합니다.
$PATH의 어떤 폴더 안에 쓸 수 있는 권한이 있다면, 쓰기 가능한 폴더 안에 백도어를 생성하여 권한을 상승시킬 수 있습니다. 이 백도어는 다른 사용자(이상적으로는 root)에 의해 실행될 명령의 이름을 가져야 하며, 당신의 쓰기 가능한 폴더보다 이전에 위치한 폴더에서 로드되지 않아야 합니다.
sudo를 사용하여 일부 명령을 실행할 수 있도록 허용되었거나, suid 비트가 설정되어 있을 수 있습니다. 다음을 사용하여 확인하세요:
일부 예상치 못한 명령은 파일을 읽거나 쓸 수 있거나 심지어 명령을 실행할 수 있게 해줍니다. 예를 들어:
Sudo 구성은 사용자가 비밀번호를 모르고 다른 사용자의 권한으로 일부 명령을 실행할 수 있도록 허용할 수 있습니다.
이 예제에서 사용자 demo
는 root
로 vim
을 실행할 수 있으며, 이제 루트 디렉토리에 ssh 키를 추가하거나 sh
를 호출하여 셸을 얻는 것이 간단해졌습니다.
이 지시어는 사용자가 무언가를 실행하는 동안 환경 변수를 설정할 수 있도록 허용합니다:
이 예제는 HTB 머신 Admirer를 기반으로 하며, 스크립트를 루트로 실행하는 동안 임의의 파이썬 라이브러리를 로드하기 위해 PYTHONPATH 하이재킹에 취약했습니다:
다른 파일로 점프하거나 심볼릭 링크를 사용합니다. 예를 들어 sudoers 파일에서: hacker10 ALL= (root) /bin/less /var/log/*
만약 와일드카드가 사용된다면 (*), 훨씬 더 쉬워집니다:
대응책: https://blog.compass-security.com/2012/10/dangerous-sudoers-entries-part-5-recapitulation/
sudo 권한이 단일 명령에 경로를 지정하지 않고 부여된 경우: hacker10 ALL= (root) less PATH 변수를 변경하여 이를 악용할 수 있습니다.
이 기술은 suid 바이너리가 경로를 지정하지 않고 다른 명령을 실행할 때도 사용할 수 있습니다 (항상 이상한 SUID 바이너리의 내용을 _strings_로 확인하세요).
만약 suid 바이너리가 경로를 지정하여 다른 명령을 실행한다면, suid 파일이 호출하는 명령과 같은 이름의 함수를 내보내기 시도할 수 있습니다.
예를 들어, suid 바이너리가 _/usr/sbin/service apache2 start_를 호출한다면, 함수를 생성하고 내보내기를 시도해야 합니다:
그런 다음, suid 바이너리를 호출하면 이 함수가 실행됩니다.
LD_PRELOAD 환경 변수는 로더가 모든 다른 라이브러리, 표준 C 라이브러리(libc.so
)를 포함하여 로드하기 전에 로드할 하나 이상의 공유 라이브러리(.so 파일)를 지정하는 데 사용됩니다. 이 프로세스를 라이브러리 프리로딩이라고 합니다.
그러나 시스템 보안을 유지하고 이 기능이 악용되는 것을 방지하기 위해, 특히 suid/sgid 실행 파일과 관련하여 시스템은 특정 조건을 강제합니다:
로더는 실제 사용자 ID(ruid)가 유효 사용자 ID(euid)와 일치하지 않는 실행 파일에 대해 LD_PRELOAD를 무시합니다.
suid/sgid가 있는 실행 파일의 경우, suid/sgid인 표준 경로의 라이브러리만 프리로딩됩니다.
권한 상승은 sudo
로 명령을 실행할 수 있는 능력이 있고 sudo -l
의 출력에 env_keep+=LD_PRELOAD 문구가 포함되어 있는 경우 발생할 수 있습니다. 이 구성은 LD_PRELOAD 환경 변수가 지속되고 sudo
로 명령을 실행할 때 인식되도록 하여, 잠재적으로 상승된 권한으로 임의의 코드가 실행될 수 있게 합니다.
/tmp/pe.c로 저장하세요.
그런 다음 컴파일하세요:
마지막으로, 권한 상승 실행
공격자가 LD_LIBRARY_PATH 환경 변수를 제어하는 경우 유사한 권한 상승이 남용될 수 있습니다. 왜냐하면 그는 라이브러리가 검색될 경로를 제어하기 때문입니다.
비정상적으로 보이는 SUID 권한을 가진 바이너리를 발견했을 때, .so 파일이 제대로 로드되고 있는지 확인하는 것이 좋은 방법입니다. 이는 다음 명령어를 실행하여 확인할 수 있습니다:
예를 들어, _"open(“/path/to/.config/libcalc.so”, O_RDONLY) = -1 ENOENT (No such file or directory)"_와 같은 오류가 발생하면 취약점이 존재할 가능성을 나타냅니다.
이를 이용하기 위해, _"/path/to/.config/libcalc.c"_라는 C 파일을 생성하고 다음 코드를 포함시킵니다:
이 코드는 컴파일되고 실행되면 파일 권한을 조작하고 상승된 권한으로 셸을 실행하여 권한을 상승시키는 것을 목표로 합니다.
위의 C 파일을 공유 객체(.so) 파일로 컴파일하려면:
마지막으로, 영향을 받은 SUID 바이너리를 실행하면 익스플로잇이 트리거되어 시스템 손상이 발생할 수 있습니다.
이제 우리가 쓸 수 있는 폴더에서 라이브러리를 로드하는 SUID 바이너리를 찾았으므로, 해당 폴더에 필요한 이름으로 라이브러리를 생성합시다:
오류가 발생하면 다음과 같은 메시지가 표시됩니다.
that means that the library you have generated need to have a function called a_function_name
.
GTFOBins는 공격자가 로컬 보안 제한을 우회하기 위해 악용할 수 있는 Unix 바이너리의 선별된 목록입니다. GTFOArgs는 명령에 인수만 주입할 수 있는 경우에 대한 동일한 목록입니다.
이 프로젝트는 제한된 셸을 탈출하고, 권한을 상승시키거나 유지하고, 파일을 전송하고, 바인드 및 리버스 셸을 생성하며, 기타 포스트 익스플로잇 작업을 용이하게 하기 위해 악용될 수 있는 Unix 바이너리의 합법적인 기능을 수집합니다.
gdb -nx -ex '!sh' -ex quit sudo mysql -e '! /bin/sh' strace -o /dev/null /bin/sh sudo awk 'BEGIN {system("/bin/sh")}'
sudo -l
에 접근할 수 있다면, 도구 FallOfSudo를 사용하여 어떤 sudo 규칙을 악용할 수 있는지 확인할 수 있습니다.
sudo 접근 권한은 있지만 비밀번호가 없는 경우, sudo 명령 실행을 기다린 후 세션 토큰을 탈취하여 권한을 상승시킬 수 있습니다.
권한 상승을 위한 요구 사항:
이미 "sampleuser" 사용자로 셸을 가지고 있음
"sampleuser"가 지난 15분 이내에 **sudo
**를 사용하여 무언가를 실행했음 (기본적으로 이는 비밀번호 없이 sudo
를 사용할 수 있게 해주는 sudo 토큰의 지속 시간입니다)
cat /proc/sys/kernel/yama/ptrace_scope
는 0임
gdb
에 접근 가능 (업로드할 수 있어야 함)
(일시적으로 ptrace_scope
를 활성화하려면 echo 0 | sudo tee /proc/sys/kernel/yama/ptrace_scope
를 사용하거나 /etc/sysctl.d/10-ptrace.conf
를 영구적으로 수정하고 kernel.yama.ptrace_scope = 0
으로 설정할 수 있습니다)
이 모든 요구 사항이 충족되면, 다음 링크를 사용하여 권한을 상승시킬 수 있습니다: https://github.com/nongiach/sudo_inject
첫 번째 익스플로잇(exploit.sh
)은 _/tmp_에 바이너리 activate_sudo_token
을 생성합니다. 이를 사용하여 세션에서 sudo 토큰을 활성화할 수 있습니다 (자동으로 루트 셸을 얻지 않으며, sudo su
를 실행해야 합니다):
두 번째 익스플로잇 (exploit_v2.sh
)은 _/tmp_에 setuid가 설정된 root 소유의 sh 셸을 생성합니다.
세 번째 익스플로잇 (exploit_v3.sh
)는 sudoers 파일을 생성하여 sudo 토큰을 영구적으로 만들고 모든 사용자가 sudo를 사용할 수 있도록 합니다.
해당 폴더 또는 폴더 내에 생성된 파일에 쓰기 권한이 있는 경우, 이진 파일 write_sudo_token를 사용하여 사용자 및 PID에 대한 sudo 토큰을 생성할 수 있습니다. 예를 들어, /var/run/sudo/ts/sampleuser 파일을 덮어쓸 수 있고, PID 1234로 해당 사용자로 쉘을 가지고 있다면, 비밀번호를 알 필요 없이 다음을 수행하여 sudo 권한을 얻을 수 있습니다:
파일 /etc/sudoers
와 /etc/sudoers.d
내부의 파일들은 누가 sudo
를 사용할 수 있는지와 그 방법을 설정합니다. 이 파일들은 기본적으로 사용자 root와 그룹 root만 읽을 수 있습니다.
만약 이 파일을 읽을 수 있다면 흥미로운 정보를 얻을 수 있을 것이고, 만약 어떤 파일을 쓸 수 있다면 권한을 상승시킬 수 있습니다.
당신이 쓸 수 있다면 이 권한을 악용할 수 있습니다.
이 권한을 남용하는 또 다른 방법:
sudo
바이너리의 대안으로 OpenBSD의 doas
가 있습니다. /etc/doas.conf
에서 그 설정을 확인하는 것을 잊지 마세요.
만약 사용자가 일반적으로 머신에 연결하고 sudo
를 사용하여 권한을 상승시키는 것을 알고 있고, 해당 사용자 컨텍스트 내에서 쉘을 얻었다면, 새로운 sudo 실행 파일을 생성하여 루트로서 당신의 코드를 실행한 다음 사용자의 명령을 실행할 수 있습니다. 그런 다음, 사용자 컨텍스트의 $PATH를 수정하여 (예: .bash_profile에 새로운 경로 추가) 사용자가 sudo를 실행할 때 당신의 sudo 실행 파일이 실행되도록 합니다.
사용자가 다른 쉘(배시가 아닌)을 사용하는 경우, 새로운 경로를 추가하기 위해 다른 파일을 수정해야 한다는 점에 유의하세요. 예를 들어 sudo-piggyback는 ~/.bashrc
, ~/.zshrc
, ~/.bash_profile
를 수정합니다. bashdoor.py에서 또 다른 예를 찾을 수 있습니다.
또는 다음과 같은 것을 실행할 수 있습니다:
파일 /etc/ld.so.conf
는 로드된 구성 파일이 어디에서 오는지를 나타냅니다. 일반적으로 이 파일은 다음 경로를 포함합니다: include /etc/ld.so.conf.d/*.conf
이는 /etc/ld.so.conf.d/*.conf
의 구성 파일이 읽힐 것임을 의미합니다. 이 구성 파일은 라이브러리가 검색될 다른 폴더를 지정합니다. 예를 들어, /etc/ld.so.conf.d/libc.conf
의 내용은 /usr/local/lib
입니다. 이는 시스템이 /usr/local/lib
내에서 라이브러리를 검색할 것임을 의미합니다.
어떤 이유로 사용자가 쓰기 권한을 가진 경우, 다음 경로 중 하나에서: /etc/ld.so.conf
, /etc/ld.so.conf.d/
, /etc/ld.so.conf.d/
내의 모든 파일 또는 /etc/ld.so.conf.d/*.conf
내의 구성 파일 내의 모든 폴더, 그는 권한 상승을 할 수 있습니다.
다음 페이지에서 이 잘못된 구성을 악용하는 방법을 살펴보세요:
lib
를 /var/tmp/flag15/
에 복사함으로써 RPATH
변수에 지정된 대로 이 위치에서 프로그램에 의해 사용될 것입니다.
그런 다음 /var/tmp
에 gcc -fPIC -shared -static-libgcc -Wl,--version-script=version,-Bstatic exploit.c -o libc.so.6
를 사용하여 악성 라이브러리를 생성합니다.
Linux capabilities는 프로세스에 사용할 수 있는 루트 권한의 하위 집합을 제공합니다. 이는 루트 권한을 더 작고 독특한 단위로 나누는 효과가 있습니다. 이러한 각 단위는 프로세스에 독립적으로 부여될 수 있습니다. 이렇게 하면 전체 권한 세트가 줄어들어 악용 위험이 감소합니다. 다음 페이지를 읽어 권한에 대해 더 배우고 이를 악용하는 방법을 알아보세요:
Linux Capabilities디렉토리에서 "실행" 비트는 영향을 받는 사용자가 "cd"를 통해 폴더로 들어갈 수 있음을 의미합니다. "읽기" 비트는 사용자가 파일을 나열할 수 있음을 의미하고, "쓰기" 비트는 사용자가 파일을 삭제하고 새 파일을 생성할 수 있음을 의미합니다.
Access Control Lists (ACLs)는 전통적인 ugo/rwx 권한을 무시할 수 있는 재량적 권한의 두 번째 계층을 나타냅니다. 이러한 권한은 소유자나 그룹의 일원이 아닌 특정 사용자에게 권한을 부여하거나 거부함으로써 파일 또는 디렉토리 접근에 대한 제어를 강화합니다. 이 수준의 세분화는 보다 정밀한 접근 관리를 보장합니다. 추가 세부정보는 여기에서 확인할 수 있습니다.
kali 사용자에게 파일에 대한 읽기 및 쓰기 권한을 부여합니다:
특정 ACL이 있는 파일을 시스템에서 가져옵니다:
구버전에서는 다른 사용자(root)의 셸 세션을 탈취할 수 있습니다. 최신 버전에서는 자신의 사용자의 화면 세션에만 연결할 수 있습니다. 그러나 세션 내부에서 흥미로운 정보를 찾을 수 있습니다.
화면 세션 목록
세션에 연결하기
이것은 오래된 tmux 버전의 문제였습니다. 비특권 사용자로서 root가 생성한 tmux (v2.1) 세션을 하이재킹할 수 없었습니다.
tmux 세션 목록
세션에 연결하기
Check Valentine box from HTB for an example.
2006년 9월부터 2008년 5월 13일 사이에 Debian 기반 시스템(Ubuntu, Kubuntu 등)에서 생성된 모든 SSL 및 SSH 키는 이 버그의 영향을 받을 수 있습니다. 이 버그는 해당 OS에서 새로운 ssh 키를 생성할 때 발생하며, 32,768가지 변형만 가능했습니다. 이는 모든 가능성을 계산할 수 있음을 의미하며, ssh 공개 키를 가지고 있으면 해당 개인 키를 검색할 수 있습니다. 계산된 가능성은 여기에서 확인할 수 있습니다: https://github.com/g0tmi1k/debian-ssh
PasswordAuthentication: 비밀번호 인증이 허용되는지 여부를 지정합니다. 기본값은 no
입니다.
PubkeyAuthentication: 공개 키 인증이 허용되는지 여부를 지정합니다. 기본값은 yes
입니다.
PermitEmptyPasswords: 비밀번호 인증이 허용될 때, 서버가 빈 비밀번호 문자열로 계정에 로그인하는 것을 허용하는지 여부를 지정합니다. 기본값은 no
입니다.
root가 ssh를 사용하여 로그인할 수 있는지 여부를 지정하며, 기본값은 no
입니다. 가능한 값:
yes
: root는 비밀번호와 개인 키를 사용하여 로그인할 수 있습니다.
without-password
또는 prohibit-password
: root는 개인 키로만 로그인할 수 있습니다.
forced-commands-only
: root는 개인 키를 사용하여 로그인할 수 있으며, 명령 옵션이 지정되어야 합니다.
no
: 불가능합니다.
사용자 인증에 사용할 수 있는 공개 키가 포함된 파일을 지정합니다. %h
와 같은 토큰을 포함할 수 있으며, 이는 홈 디렉토리로 대체됩니다. 절대 경로를 지정할 수 있습니다 ( /
로 시작) 또는 사용자의 홈에서 상대 경로를 지정할 수 있습니다. 예:
그 구성은 사용자가 "testusername"의 private 키로 로그인하려고 할 경우, ssh가 귀하의 키의 공개 키를 /home/testusername/.ssh/authorized_keys
및 /home/testusername/access
에 위치한 키와 비교할 것임을 나타냅니다.
SSH 에이전트 포워딩을 사용하면 서버에 키를 남기지 않고 로컬 SSH 키를 사용할 수 있습니다 (비밀번호 없이!). 따라서 ssh를 통해 호스트로 점프하고, 거기서 다른 호스트로 점프할 수 있으며, 초기 호스트에 위치한 키를 사용할 수 있습니다.
이 옵션을 $HOME/.ssh.config
에 다음과 같이 설정해야 합니다:
Host
가 *
인 경우 사용자가 다른 머신으로 이동할 때마다 해당 호스트가 키에 접근할 수 있으므로(이는 보안 문제입니다).
파일 /etc/ssh_config
는 이 옵션을 재정의하고 이 구성을 허용하거나 거부할 수 있습니다.
파일 /etc/sshd_config
는 AllowAgentForwarding
키워드를 사용하여 ssh-agent 포워딩을 허용하거나 거부할 수 있습니다(기본값은 허용).
Forward Agent가 환경에 구성되어 있는 경우 권한 상승을 악용할 수 있으므로 다음 페이지를 읽어보십시오:
SSH Forward Agent exploitation파일 /etc/profile
및 /etc/profile.d/
아래의 파일들은 사용자가 새로운 셸을 실행할 때 실행되는 스크립트입니다. 따라서, 이들 중 하나를 작성하거나 수정할 수 있다면 권한을 상승시킬 수 있습니다.
이상한 프로필 스크립트가 발견되면 민감한 세부정보를 확인해야 합니다.
운영 체제에 따라 /etc/passwd
및 /etc/shadow
파일이 다른 이름을 사용하거나 백업이 있을 수 있습니다. 따라서 모두 찾고 읽을 수 있는지 확인하여 파일 안에 해시가 있는지 확인하는 것이 좋습니다:
일부 경우에 비밀번호 해시를 /etc/passwd
(또는 동등한) 파일 내에서 찾을 수 있습니다.
먼저, 다음 명령어 중 하나로 비밀번호를 생성합니다.
그런 다음 사용자 hacker
를 추가하고 생성된 비밀번호를 추가합니다.
예: hacker:$1$hacker$TzyKlv0/R/c28R.GAeLw.1:0:0:Hacker:/root:/bin/bash
이제 hacker:hacker
로 su
명령을 사용할 수 있습니다.
또는 다음 줄을 사용하여 비밀번호가 없는 더미 사용자를 추가할 수 있습니다. 경고: 현재 머신의 보안을 저하시킬 수 있습니다.
NOTE: BSD 플랫폼에서는 /etc/passwd
가 /etc/pwd.db
및 /etc/master.passwd
에 위치하며, /etc/shadow
는 /etc/spwd.db
로 이름이 변경됩니다.
민감한 파일에 쓰기가 가능한지 확인해야 합니다. 예를 들어, 일부 서비스 구성 파일에 쓸 수 있습니까?
예를 들어, 머신이 tomcat 서버를 실행 중이고 /etc/systemd/ 내의 Tomcat 서비스 구성 파일을 수정할 수 있다면, 다음과 같은 줄을 수정할 수 있습니다:
Your backdoor will be executed the next time that tomcat is started.
다음 폴더에는 백업 또는 흥미로운 정보가 포함될 수 있습니다: /tmp, /var/tmp, /var/backups, /var/mail, /var/spool/mail, /etc/exports, /root (마지막 폴더는 읽을 수 없을 가능성이 높지만 시도해 보세요)
Read the code of linPEAS, it searches for 여러 가능한 파일이 비밀번호를 포함할 수 있습니다. 또 다른 흥미로운 도구는 LaZagne로, 이는 Windows, Linux 및 Mac에서 로컬 컴퓨터에 저장된 많은 비밀번호를 검색하는 데 사용되는 오픈 소스 애플리케이션입니다.
If you can read logs, you may be able to find 흥미로운/기밀 정보가 그 안에 있을 수 있습니다. 로그가 이상할수록 더 흥미로울 것입니다 (아마도). 또한, 일부 "잘못된" 구성된 (백도어가 있는?) 감사 로그는 이 게시물에서 설명한 대로 감사 로그에 비밀번호를 기록할 수 있게 해줄 수 있습니다: https://www.redsiege.com/blog/2019/05/logging-passwords-on-linux/.
로그를 읽기 위해 adm 그룹이 정말 유용할 것입니다.
파일 이름이나 내용에 "password"라는 단어가 포함된 파일을 확인하고, 로그 내의 IP와 이메일, 또는 해시 정규 표현식도 확인해야 합니다. 이 모든 것을 수행하는 방법을 여기서 나열하지는 않겠지만, 관심이 있다면 linpeas가 수행하는 마지막 체크를 확인할 수 있습니다.
어디서 python 스크립트가 실행될 것인지 알고 있고, 그 폴더 안에 쓰기가 가능하거나 python 라이브러리를 수정할 수 있다면, OS 라이브러리를 수정하고 백도어를 설치할 수 있습니다 (python 스크립트가 실행될 위치에 쓸 수 있다면, os.py 라이브러리를 복사하여 붙여넣기 하세요).
라이브러리를 백도어하려면 os.py 라이브러리의 끝에 다음 줄을 추가하세요 (IP와 PORT를 변경하세요):
logrotate
의 취약점은 로그 파일이나 그 상위 디렉토리에 쓰기 권한이 있는 사용자가 잠재적으로 권한 상승을 얻을 수 있게 합니다. 이는 logrotate
가 종종 root로 실행되기 때문에, _/etc/bash_completion.d/_와 같은 디렉토리에서 임의의 파일을 실행하도록 조작될 수 있기 때문입니다. 로그 회전이 적용되는 모든 디렉토리뿐만 아니라 _/var/log_에서도 권한을 확인하는 것이 중요합니다.
이 취약점은 logrotate
버전 3.18.0
및 이전 버전에 영향을 미칩니다.
취약점에 대한 더 자세한 정보는 이 페이지에서 확인할 수 있습니다: https://tech.feedyourhead.at/content/details-of-a-logrotate-race-condition.
이 취약점은 logrotten으로 악용할 수 있습니다.
이 취약점은 CVE-2016-1247 **(nginx 로그)**와 매우 유사하므로, 로그를 변경할 수 있는 경우 로그를 관리하는 사람이 누구인지 확인하고, 심볼릭 링크로 로그를 대체하여 권한을 상승시킬 수 있는지 확인하십시오.
취약점 참조: https://vulmon.com/exploitdetails?qidtp=maillist_fulldisclosure&qid=e026a0c5f83df4fd532442e1324ffa4f
어떤 이유로든 사용자가 _/etc/sysconfig/network-scripts_에 ifcf-<whatever>
스크립트를 쓰기 할 수 있거나 기존 스크립트를 조정할 수 있다면, 당신의 시스템은 pwned입니다.
네트워크 스크립트, 예를 들어 _ifcg-eth0_는 네트워크 연결에 사용됩니다. 이들은 .INI 파일과 정확히 같습니다. 그러나 이들은 Linux에서 Network Manager( dispatcher.d)에 의해 ~sourced~됩니다.
내 경우, 이러한 네트워크 스크립트에서 NAME=
속성이 올바르게 처리되지 않습니다. 이름에 공백이 있는 경우 시스템은 공백 이후의 부분을 실행하려고 시도합니다. 이는 첫 번째 공백 이후의 모든 것이 root로 실행된다는 것을 의미합니다.
예를 들어: /etc/sysconfig/network-scripts/ifcfg-1337
디렉토리 /etc/init.d
는 **System V init (SysVinit)**을 위한 스크립트의 집합입니다. 이는 고전적인 리눅스 서비스 관리 시스템으로, 서비스의 start
, stop
, restart
, 때때로 reload
를 위한 스크립트를 포함합니다. 이 스크립트는 직접 실행하거나 /etc/rc?.d/
에 있는 심볼릭 링크를 통해 실행할 수 있습니다. Redhat 시스템의 대체 경로는 /etc/rc.d/init.d
입니다.
반면에, /etc/init
는 Upstart와 관련이 있으며, 이는 우분투에서 도입된 최신 서비스 관리 시스템으로, 서비스 관리 작업을 위한 구성 파일을 사용합니다. Upstart로의 전환에도 불구하고, SysVinit 스크립트는 Upstart 구성과 함께 여전히 사용됩니다.
systemd는 현대적인 초기화 및 서비스 관리자이며, 온디맨드 데몬 시작, 자동 마운트 관리, 시스템 상태 스냅샷과 같은 고급 기능을 제공합니다. 이는 배포 패키지를 위한 /usr/lib/systemd/
와 관리자의 수정을 위한 /etc/systemd/system/
에 파일을 정리하여 시스템 관리 프로세스를 간소화합니다.
LinEnum: https://github.com/rebootuser/LinEnum(-t 옵션) Enumy: https://github.com/luke-goddard/enumy Unix Privesc Check: http://pentestmonkey.net/tools/audit/unix-privesc-check Linux Priv Checker: www.securitysift.com/download/linuxprivchecker.py BeeRoot: https://github.com/AlessandroZ/BeRoot/tree/master/Linux Kernelpop: 리눅스 및 MAC에서 커널 취약점 열거 https://github.com/spencerdodd/kernelpop Mestaploit: multi/recon/local_exploit_suggester Linux Exploit Suggester: https://github.com/mzet-/linux-exploit-suggester EvilAbigail (물리적 접근): https://github.com/GDSSecurity/EvilAbigail 더 많은 스크립트 모음: https://github.com/1N3/PrivEsc
AWS 해킹 배우기 및 연습하기:HackTricks Training AWS Red Team Expert (ARTE) GCP 해킹 배우기 및 연습하기: HackTricks Training GCP Red Team Expert (GRTE)