Best Practices to Defend Against Server-Side Request Forgery (SSRF) Attacks
Server-Side Request Forgery (SSRF) is a critical security vulnerability that has become increasingly prevalent in modern web applications. It allows attackers to manipulate server-side applications into sending unauthorized requests to internal or external systems. SSRF is particularly dangerous because it can bypass traditional security controls, such as firewalls, and exploit trusted relationships within an organization’s infrastructure. This vulnerability has been recognized as one of the most severe threats in web application security, earning its place in the OWASP Top 10 list of critical vulnerabilities.
In an SSRF attack, malicious actors exploit the server’s ability to make HTTP requests on behalf of the application. By crafting carefully manipulated inputs, attackers can access sensitive internal resources, such as private IP addresses, cloud metadata endpoints, or privileged files. This can lead to severe consequences, including data breaches, unauthorized access to internal systems, and even privilege escalation.
The rise of cloud computing and microservices architectures has further amplified the risks associated with SSRF. Many cloud environments rely on metadata services to manage resources, making them a prime target for SSRF exploitation. For instance, attackers can use SSRF to access cloud metadata endpoints like http://169.254.169.254 in AWS or GCP, potentially exposing sensitive credentials and configuration data. As organizations increasingly adopt cloud-native technologies, the need for robust SSRF defenses has never been more urgent.
This blog post aims to provide a comprehensive guide to defending against SSRF attacks. By implementing best practices such as input validation, network segmentation, and proactive monitoring, organizations can significantly reduce their attack surface and protect their critical assets. Additionally, we will explore advanced mitigation techniques, including the use of allowlists, secure coding practices, and cloud-specific defenses, to ensure a robust security posture.
For a deeper understanding of SSRF and its implications, we will also reference insights from leading security resources, including Bugv Blog, BrightSec, and OWASP. These resources highlight the evolving nature of SSRF attacks and emphasize the importance of staying ahead of emerging threats.
As we delve into the best practices for mitigating SSRF, it is crucial to adopt a proactive and layered security approach. By doing so, organizations can not only defend against SSRF but also enhance their overall application security framework.
Table of Contents
- Understanding SSRF and Its Risks
- The Anatomy of SSRF Exploits
- Key Characteristics of SSRF
- Common SSRF Attack Scenarios
- Advanced SSRF Techniques
- DNS Rebinding
- Blind SSRF
- Protocol Smuggling
- Real-World SSRF Incidents
- The Rackspace SSRF Exploit
- Capital One Data Breach
- Emerging SSRF Risks in Modern Architectures
- SSRF in Cloud-Native Environments
- SSRF in Microservices
- SSRF in APIs
- Mitigation Strategies Beyond Basics
- Egress Filtering
- Metadata API Protection
- Monitoring and Logging
- Secure Code Practices
- Web Application Firewalls (WAFs)
- The Role of AI and Automation in SSRF Defense
- AI-Powered Threat Detection
- Automated Security Testing
- Continuous Monitoring
- Effective Techniques to Mitigate SSRF Attacks
- Implementing Outbound Request Controls
- Restricting Outbound Connections
- Using Allowlists for Outbound Requests
- Enforcing Protocol Restrictions
- Advanced URL Validation Techniques
- Parsing and Normalizing URLs
- Blocking Redirects
- Validating DNS Resolution
- Leveraging Network Security Best Practices
- Network Segmentation
- Implementing Egress Filtering
- Using Proxy Servers
- Real-Time Monitoring and Anomaly Detection
- Setting Up Alerts for Anomalous Behavior
- Leveraging AI for Threat Detection
- Monitoring DNS Queries
- Secure Development Practices for SSRF Prevention
- Using Predefined API Clients
- Avoiding Dynamic URL Construction
- Implementing Strict Error Handling
- Regular Security Audits
- Continuous Education and Training
- Utilizing Specialized Security Tools
- Web Application Firewalls (WAFs) with SSRF Rules
- API Gateways with Built-In Security Features
- SSRF Detection Tools
- Best Practices for Monitoring and Securing Applications Against SSRF
- Leveraging Comprehensive Logging Frameworks
- Implementing Behavioral Analytics for SSRF Detection
- Enhancing Security Through Protocol-Specific Monitoring
- Leveraging Runtime Application Self-Protection (RASP)
- Utilizing Threat Intelligence for SSRF Defense
- Strengthening Cloud-Specific SSRF Protections
Understanding SSRF and Its Risks
The Anatomy of SSRF Exploits
Server-Side Request Forgery (SSRF) attacks exploit a server’s ability to make HTTP requests on behalf of a user. Attackers manipulate this functionality to send unauthorized requests to internal or external systems, bypassing security controls like firewalls or access control lists. Unlike other vulnerabilities, SSRF directly targets the server’s privileged access to internal resources, making it particularly dangerous.
Key Characteristics of SSRF
- Exploitation of Trust: SSRF attacks exploit the trust between internal systems. For example, a server might be allowed to access sensitive metadata endpoints (e.g., AWS metadata at 169.254.169.254) or internal APIs.
- Lack of Input Validation: Many SSRF vulnerabilities arise from improper validation of user-supplied URLs or URIs. Attackers can manipulate these inputs to redirect requests to malicious or sensitive destinations.
- Privileged Network Position: Servers often have access to internal networks or sensitive systems that are inaccessible to external users. SSRF exploits this privileged position to gain unauthorized access.
Common SSRF Attack Scenarios
- Cloud Metadata Access: Attackers target cloud environments by accessing metadata endpoints that expose sensitive information like access tokens or credentials. For example, AWS metadata can be accessed via http://169.254.169.254/latest/meta-data/.
- Internal Service Discovery: SSRF can be used to enumerate internal services by sending requests to internal IP ranges (e.g., 10.x.x.x or 192.168.x.x) and observing the responses.
- Pivoting to Other Vulnerabilities: SSRF often serves as a gateway to exploit other vulnerabilities, such as Remote Code Execution (RCE) or privilege escalation.
Advanced SSRF Techniques
While basic SSRF attacks rely on simple URL manipulation, advanced techniques leverage more sophisticated methods to bypass security mechanisms.
DNS Rebinding
Attackers use DNS rebinding to bypass IP-based allowlists. In this scenario, the attacker registers a domain that resolves to an external IP during initial validation but later resolves to an internal IP when the server makes the request. This technique allows attackers to access internal resources that would otherwise be blocked.
Blind SSRF
In blind SSRF attacks, the attacker cannot directly observe the server’s response to their malicious request. Instead, they rely on side effects, such as DNS resolution logs or timing discrepancies, to infer the success of the attack. For example, attackers might use a DNS logging service to track whether the server resolves a specific domain.
Protocol Smuggling
Some SSRF attacks exploit non-HTTP protocols, such as FTP, SMTP, or gopher, to interact with internal services. For instance, an attacker might use SSRF to send malicious payloads to an internal email server via SMTP.
Real-World SSRF Incidents
The Rackspace SSRF Exploit
In 2023, a group known as “Play Ransomware” exploited an SSRF-based zero-day vulnerability in Microsoft Exchange to compromise Rackspace. The attackers used SSRF to access sensitive internal systems, resulting in a complete shutdown of email services. The financial impact was estimated at over $10 million (source).
Capital One Data Breach
The infamous Capital One breach in 2019 involved an SSRF vulnerability in AWS. The attacker exploited the server’s access to AWS metadata to obtain credentials, which were then used to access sensitive customer data (source).
Emerging SSRF Risks in Modern Architectures
SSRF in Cloud-Native Environments
The adoption of cloud-native architectures has significantly increased the attack surface for SSRF. Cloud environments often rely on metadata APIs to manage instances, making them prime targets for SSRF attacks. For example:
- AWS metadata endpoints (169.254.169.254) expose sensitive instance data, including IAM roles and tokens.
- Google Cloud Platform (GCP) and Azure have similar metadata services that can be exploited if not properly secured.
SSRF in Microservices
Microservices architectures often involve extensive internal communication between services. SSRF vulnerabilities in one service can be used to pivot to other services, potentially compromising the entire system. For instance:
- An SSRF vulnerability in a public-facing API could be used to access internal APIs or databases.
- Attackers can exploit SSRF to bypass service mesh security controls, such as Istio or Linkerd.
SSRF in APIs
APIs that process user-supplied URLs, such as webhooks or file download endpoints, are particularly vulnerable to SSRF. For example:
- A webhook API might fetch data from a user-supplied URL, allowing attackers to redirect the request to an internal service.
- File download APIs that accept URLs as input can be manipulated to download sensitive internal files.
Mitigation Strategies Beyond Basics
While input validation and allowlisting are essential, advanced mitigation strategies are necessary to address sophisticated SSRF attacks.
Egress Filtering
Implement strict egress filtering to control outbound traffic from the server. For example:
- Block access to private IP ranges (10.x.x.x, 192.168.x.x, etc.) unless explicitly required.
- Restrict outbound traffic to known, trusted destinations.
Metadata API Protection
Cloud providers like AWS and GCP offer enhanced metadata API security. For instance:
- AWS Metadata v2 requires session tokens for access, mitigating unauthorized requests (source).
- Disable metadata APIs if they are not required for the application.
Monitoring and Logging
Proactively monitor and log all outbound requests from the server. Key practices include:
- Logging DNS queries to detect unusual domain resolutions.
- Monitoring HTTP request logs for suspicious patterns, such as requests to internal IP ranges.
Secure Code Practices
Adopt secure coding practices to minimize SSRF risks:
- Avoid direct fetching of user-supplied URLs. Instead, use intermediate services to validate and sanitize the input.
- Require authentication and authorization for all internal services, even when accessed from within the network.
Web Application Firewalls (WAFs)
Deploy WAFs with SSRF-specific rules to detect and block malicious requests. Modern WAFs can analyze request patterns and identify anomalies indicative of SSRF attempts.
The Role of AI and Automation in SSRF Defense
AI-Powered Threat Detection
Artificial Intelligence (AI) can enhance SSRF detection by analyzing traffic patterns and identifying anomalies. For example:
- Machine learning models can detect unusual outbound requests that deviate from normal behavior.
- AI can correlate multiple indicators, such as DNS logs and HTTP requests, to identify potential SSRF attacks.
Automated Security Testing
Incorporate automated security testing into the development lifecycle to identify SSRF vulnerabilities early. Tools like Burp Suite and OWASP ZAP can simulate SSRF attacks and highlight potential weaknesses.
Continuous Monitoring
Use automated monitoring tools to continuously scan for SSRF vulnerabilities in production environments. For example:
- Tools like Aqua Security or Prisma Cloud can identify misconfigurations in cloud environments that could lead to SSRF.
- Automated scanners can detect outdated libraries or dependencies that are vulnerable to SSRF.
By adopting these advanced strategies, organizations can significantly reduce the risk of SSRF attacks and protect their critical assets.
Effective Techniques to Mitigate SSRF Attacks
Implementing Outbound Request Controls
One of the most effective ways to mitigate Server-Side Request Forgery (SSRF) attacks is by controlling outbound requests from the server. Unlike basic input validation, which focuses on sanitizing user inputs, outbound request controls restrict the server’s ability to communicate with unauthorized destinations.
Restricting Outbound Connections
Servers should be configured to limit outbound connections to only the necessary and trusted endpoints. This can be achieved by implementing strict firewall rules that block unauthorized traffic. For example, organizations can configure firewalls to deny requests to internal IP ranges (e.g., 127.0.0.1, 10.0.0.0/8, 169.254.169.254) and private network addresses.
Using Allowlists for Outbound Requests
Instead of relying on blocklists, which can be bypassed with creative URL manipulation, allowlists provide a more robust approach. By defining a list of permitted domains or IP addresses that the server can communicate with, organizations can ensure that only trusted destinations are accessed. For example, a web application might restrict outbound requests to its own API endpoints or specific third-party services.
Enforcing Protocol Restrictions
Attackers often exploit SSRF vulnerabilities by using non-HTTP protocols such as file://, gopher://, or ftp://. To mitigate this risk, servers should enforce protocol restrictions, allowing only HTTP and HTTPS requests. This can be implemented by validating the scheme of the requested URL before processing it.
Advanced URL Validation Techniques
While input validation is a common mitigation strategy, SSRF attacks often bypass basic validation mechanisms. Advanced URL validation techniques can provide an additional layer of security.
Parsing and Normalizing URLs
Attackers may use techniques like URL encoding or obfuscation to bypass validation checks. For instance, a URL like http://127.0.0.1%2F%2E%2E could be interpreted as an internal address. Parsing and normalizing URLs before validation ensures that such manipulations are detected and blocked.
Blocking Redirects
SSRF attacks often exploit open redirects to reach unauthorized destinations. For example, a malicious user might craft a URL that redirects to an internal service. To prevent this, servers should block or strictly validate redirects. A common approach is to disallow redirects to private IP ranges or domains outside the allowlist.
Validating DNS Resolution
Attackers may use DNS rebinding to bypass IP-based restrictions. In this technique, a domain resolves to a public IP during validation but later resolves to an internal IP. To mitigate this, servers should resolve the DNS of the requested URL and verify that it matches the allowlist before making the request.
Leveraging Network Security Best Practices
Network security plays a critical role in mitigating SSRF attacks by isolating sensitive resources and limiting access to internal systems.
Network Segmentation
Dividing the network into smaller, isolated segments can reduce the impact of SSRF attacks. For example, internal databases and APIs should be placed in a separate segment that is inaccessible from the public-facing application servers. This ensures that even if an SSRF attack succeeds, the attacker cannot access sensitive resources.
Implementing Egress Filtering
Egress filtering involves monitoring and controlling outbound traffic from the server. For instance, organizations can use tools like AWS Security Groups or Azure Network Security Groups to restrict outbound traffic to specific IP addresses and ports.
Using Proxy Servers
Proxy servers can act as intermediaries for outbound requests, providing an additional layer of security. By routing all outbound traffic through a proxy, organizations can enforce strict access controls and monitor request patterns for suspicious activity.
Real-Time Monitoring and Anomaly Detection
While the existing content discusses continuous monitoring, this section focuses on real-time detection of SSRF attempts. Real-time monitoring involves analyzing server requests as they occur to identify and block malicious activity.
Setting Up Alerts for Anomalous Behavior
Organizations can configure monitoring tools to trigger alerts when unusual patterns are detected. For example, an alert could be triggered if the server attempts to access internal IP ranges or unexpected domains.
Leveraging AI for Threat Detection
AI-powered tools can analyze large volumes of server logs to identify patterns indicative of SSRF attacks. For instance, tools like Splunk or Elastic Security can detect anomalies such as repeated requests to sensitive endpoints or unusual DNS resolutions.
Monitoring DNS Queries
Monitoring DNS queries made by the server can help detect SSRF attempts that use DNS rebinding or external domains. For example, if the server resolves a domain that is not on the allowlist, it could indicate a potential SSRF attack.
Secure Development Practices for SSRF Prevention
While the existing content covers secure coding practices, this section delves deeper into specific techniques developers can adopt to prevent SSRF vulnerabilities.
Using Predefined API Clients
Instead of allowing the server to fetch user-specified URLs, developers can use predefined API clients with hardcoded endpoints. For example, if an application needs to fetch weather data, it should use a client library for the weather API rather than accepting user-supplied URLs.
Avoiding Dynamic URL Construction
Dynamic URL construction based on user input increases the risk of SSRF vulnerabilities. Developers should avoid concatenating user inputs to form URLs. Instead, they should use parameterized queries or predefined templates.
Implementing Strict Error Handling
Improper error handling can expose sensitive information that aids attackers in crafting SSRF exploits. For instance, a server error revealing the internal network structure can be used to target specific services. Developers should ensure that error messages are generic and do not disclose sensitive details.
Regular Security Audits
Conducting regular security audits of the codebase can help identify SSRF vulnerabilities early. Tools like SonarQube or Checkmarx can analyze the source code for insecure patterns and suggest remediations.
Continuous Education and Training
Developers should be trained on secure coding practices and the latest SSRF attack techniques. Organizations can use platforms like OWASP to provide training resources and guidelines.
Utilizing Specialized Security Tools
Beyond general-purpose firewalls and monitoring systems, specialized tools can provide targeted protection against SSRF attacks.
Web Application Firewalls (WAFs) with SSRF Rules
Modern WAFs, such as Cloudflare WAF or AWS WAF, offer SSRF-specific rules that can detect and block malicious requests. For example, they can analyze request headers and payloads for patterns indicative of SSRF attempts.
API Gateways with Built-In Security Features
API gateways like Kong or Apigee can enforce strict validation of API requests, including URL validation and protocol restrictions. By acting as a gatekeeper, the API gateway can prevent unauthorized requests from reaching the server.
SSRF Detection Tools
Tools like Burp Suite or OWASP ZAP can simulate SSRF attacks during penetration testing. These tools help identify vulnerabilities in the application before they can be exploited by attackers.
By combining these advanced techniques with existing mitigation strategies, organizations can build a robust defense against SSRF attacks. Each layer of protection, from input validation to network segmentation, contributes to reducing the attack surface and minimizing the impact of potential exploits.
Best Practices for Monitoring and Securing Applications Against SSRF
Leveraging Comprehensive Logging Frameworks
Effective logging is a cornerstone for monitoring and securing applications against SSRF attacks. While existing content emphasizes real-time monitoring and anomaly detection, this section focuses on the importance of comprehensive logging frameworks that capture detailed information about server-side requests.
- Detailed Outbound Request Logs: Maintain logs of all outbound requests initiated by the server, including the request method, headers, and destination URLs. This helps identify suspicious patterns, such as requests to unauthorized or internal IP ranges. (CloudSecurityWeb)
- Correlation with User Actions: Correlate server-side requests with user actions to trace potential SSRF attempts back to their origin. For instance, if a user input triggers an unexpected outbound request, it may indicate an SSRF exploit.
- Centralized Log Management: Use centralized logging tools like ELK Stack or Splunk to aggregate logs from multiple servers and analyze them for anomalies. This ensures visibility across distributed systems.
Implementing Behavioral Analytics for SSRF Detection
While the existing content mentions AI-powered threat detection, this section delves into the use of behavioral analytics to identify SSRF attempts based on deviations from normal server behavior.
- Baseline Behavior Profiling: Establish a baseline of normal server behavior, including typical outbound request patterns, frequency, and destinations. Behavioral analytics tools like Dynatrace or Datadog can help detect anomalies that deviate from this baseline.
- Anomaly Detection Algorithms: Implement machine learning algorithms to identify unusual request patterns indicative of SSRF, such as repeated attempts to access internal IP ranges or cloud metadata endpoints (e.g., 169.254.169.254 for AWS). (Bugv Blog)
- Dynamic Risk Scoring: Assign dynamic risk scores to requests based on factors like destination, request frequency, and user behavior. High-risk requests can be flagged for further investigation or blocked automatically.
Enhancing Security Through Protocol-Specific Monitoring
While protocol restrictions have been discussed in existing reports, this section focuses on monitoring and securing specific protocols to prevent SSRF exploits.
- HTTP and HTTPS Monitoring: Monitor HTTP and HTTPS traffic for unusual patterns, such as requests containing encoded payloads or redirects to internal resources. Tools like Fiddler or Wireshark can be used for deep packet inspection.
- Non-HTTP Protocols: SSRF attacks often exploit non-HTTP protocols like FTP, SMTP, or gopher. Restrict and monitor these protocols to ensure they are not being misused. For example, block unused protocols at the firewall level and log any attempts to use them. (BrightSec)
- DNS Query Analysis: Monitor DNS queries to detect SSRF attempts that resolve internal or unauthorized domains. Anomalous DNS queries can indicate attempts to access internal services or exfiltrate data.
Leveraging Runtime Application Self-Protection (RASP)
Runtime Application Self-Protection (RASP) is a relatively new approach to securing applications against SSRF attacks. Unlike traditional monitoring tools, RASP operates within the application runtime environment to provide real-time protection.
- Request Interception: RASP solutions intercept and analyze requests at runtime to identify and block SSRF payloads. For example, they can detect and prevent requests to internal IP ranges or unauthorized domains.
- Context-Aware Protection: By operating within the application, RASP can leverage contextual information, such as user roles and permissions, to make more informed decisions about whether to allow or block a request. (Evolve Security)
- Integration with CI/CD Pipelines: Integrate RASP tools into CI/CD pipelines to identify SSRF vulnerabilities during the development and testing phases. This ensures that vulnerabilities are addressed before deployment.
Utilizing Threat Intelligence for SSRF Defense
Threat intelligence can play a critical role in enhancing SSRF defenses by providing actionable insights into emerging attack vectors and techniques.
- Threat Feed Integration: Integrate threat intelligence feeds into monitoring systems to stay updated on the latest SSRF payloads, malicious IPs, and domains. For example, services like AlienVault or Recorded Future can provide real-time threat data.
- Attack Surface Mapping: Use threat intelligence to map your application’s attack surface and identify potential SSRF entry points. This includes analyzing third-party integrations and APIs for vulnerabilities. (Masaudsec)
- Proactive Defense Measures: Leverage threat intelligence to implement proactive defense measures, such as updating Web Application Firewall (WAF) rules to block known SSRF payloads or IPs associated with malicious activity.
Strengthening Cloud-Specific SSRF Protections
While existing content addresses SSRF in cloud environments, this section focuses on advanced monitoring and security measures tailored specifically for cloud-native applications.
- Cloud Metadata Protection: Monitor and restrict access to cloud metadata endpoints to prevent SSRF exploits targeting sensitive information like AWS IAM credentials. For example, use IAM policies to deny access to the 169.254.169.254 IP range. (Bugv Blog)
- Cloud-Native Security Tools: Use cloud-native security tools like AWS GuardDuty or Azure Security Center to detect and respond to SSRF attempts. These tools can identify unusual outbound traffic patterns and alert security teams in real-time.
- Container Security: Monitor containerized environments for SSRF vulnerabilities. Tools like Aqua Security or Prisma Cloud can scan container images for misconfigurations and vulnerabilities that could be exploited in SSRF attacks.
By implementing these advanced monitoring and security practices, organizations can significantly enhance their defenses against SSRF attacks. Each layer of protection, from logging frameworks to cloud-specific measures, contributes to a robust security posture that minimizes the risk of exploitation.
Conclusion
Server-Side Request Forgery (SSRF) attacks represent a significant and evolving threat to modern applications, particularly in cloud-native and microservices architectures. By exploiting a server’s ability to make HTTP requests, attackers can bypass traditional security controls, access sensitive internal resources, and pivot to other vulnerabilities like Remote Code Execution (RCE). The research highlights key SSRF attack vectors, including cloud metadata exploitation, DNS rebinding, and protocol smuggling, as well as real-world incidents such as the Capital One data breach and the Rackspace SSRF exploit. These examples underscore the critical need for robust defenses against SSRF attacks.
To mitigate SSRF risks, organizations must adopt a multi-layered security approach. Essential strategies include implementing strict egress filtering, enforcing allowlists for outbound requests, and leveraging advanced URL validation techniques to block malicious payloads. Network security measures such as segmentation, egress traffic monitoring, and proxy servers further reduce the attack surface. Additionally, cloud-specific protections, like enabling AWS Metadata v2 and using tools like AWS GuardDuty or Azure Security Center, are critical for securing cloud environments. Advanced solutions, including AI-powered anomaly detection, Runtime Application Self-Protection (RASP), and automated security testing tools like Burp Suite, provide proactive and real-time defenses against sophisticated SSRF techniques.
The implications of this research are clear: as SSRF attacks grow in complexity, organizations must prioritize continuous monitoring, secure coding practices, and regular security audits to stay ahead of evolving threats. By combining foundational defenses with advanced technologies and threat intelligence, businesses can significantly reduce their exposure to SSRF vulnerabilities and safeguard critical assets. Moving forward, security teams should integrate SSRF-specific protections into their development pipelines and adopt a proactive, defense-in-depth strategy to address this pervasive risk.
References
- https://brightsec.com/blog/7-ssrf-mitigation-techniques-you-must-know/
- https://codesucks.substack.com/p/how-to-detect-and-fix-ssrf-in-java
- https://masaudsec.com/advanced-techniques-in-server-side-request-forgery-ssrf/
- https://www.cybersecurityhq.com/blog/server-side-request-forgery-ssrf-common-attacks-risks
- https://blog.bugv.io/understanding-ssrf-a-deep-dive-into-server-side-request-forgery/
- https://aptori.dev/blog/understanding-ssrf-server-side-request-forgery-and-its-impact-on-api-security
- https://medium.com/@techdefenderhub/understanding-server-side-request-forgery-ssrf-9094a38e117a
- https://dotcommagazine.com/2024/03/ssrf-top-ten-things-you-need-to-know/
- https://cloudsecurityweb.com/articles/2023/11/29/detecting-and-preventing-server-side-request-forgery-a-deep-dive-into-api-security/
- https://www.lacework.com/blog/cloudy-with-a-chance-of-threats-advice-for-mitigating-the-top-cyber-threats-of-2024
- https://securitycipher.com/docs/security/vulnerability-explain/server-side-request-forgery/
- https://armur.ai/armur-top-10/8/8/ssrf-prevention-techniques/
- https://medium.com/@ashhadali2019/understanding-and-preventing-server-side-request-forgery-ssrf-15d939dc9529
- https://www.evolvesecurity.com/blog-posts/how-to-prevent-server-side-request-forgery
- https://www.sitelock.com/blog/what-is-ssrf/