首页
/ 深入解析cursor-security-rules项目中的SSRF防护规则

深入解析cursor-security-rules项目中的SSRF防护规则

2025-06-19 10:06:04作者:卓炯娓

什么是SSRF攻击

SSRF(Server-Side Request Forgery,服务器端请求伪造)是一种安全漏洞,攻击者能够诱使服务器向内部系统发起非预期的请求。这种攻击可能导致敏感数据泄露、内部服务探测,甚至内部网络入侵等严重后果。

cursor-security-rules项目的SSRF防护方案

cursor-security-rules项目提供了一套全面的SSRF防护规则,适用于所有执行出站网络请求的代码,无论使用何种编程语言或框架。这些规则旨在帮助开发者在代码层面预防SSRF漏洞。

核心防护规则详解

1. 禁止用户输入直接控制目标URL

规则原理:直接使用未经处理的用户输入构造请求URL是SSRF攻击的主要入口点。

不安全示例

# 危险!用户可控制请求目标
requests.get(request.args["url"])

安全实践

  • 使用白名单机制,只允许访问预定义的、可信的URL
  • 如果必须使用用户输入,应进行严格的验证和过滤

2. 阻止访问私有/内部IP地址范围

规则原理:防止攻击者利用SSRF探测或攻击内部网络资源。

禁止访问的范围包括

  • 本地地址:localhost127.0.0.1
  • 私有地址段:
    • 169.254.0.0/16(链路本地)
    • 192.168.0.0/16
    • 10.0.0.0/8
    • 172.16.0.0/12
  • 其他保留地址段

实现建议

  • 在发起请求前检查目标IP是否属于禁止范围
  • 考虑使用专门的IP地址验证库

3. 解析并验证主机名

规则原理:防止攻击者通过DNS重绑定等技术绕过防护。

安全实践

  1. 首先解析主机名获取IP地址
  2. 验证解析后的IP地址是否允许访问
  3. 确保DNS解析结果不会被篡改

4. 限制允许的协议和端口

规则原理:减少攻击面,防止利用非标准协议进行攻击。

允许的协议

  • HTTP (端口80)
  • HTTPS (端口443)

禁止的协议

  • file://
  • gopher://
  • ftp://
  • 其他自定义协议处理器

实现建议

  • 显式指定协议,不要使用协议相对URL
  • 验证端口号在允许范围内

5. 禁止自动转发授权头信息

规则原理:防止内部认证信息通过SSRF请求泄露。

安全实践

  • 默认不转发任何认证头信息
  • 如需转发,必须经过明确的范围界定和安全审计
  • 特别注意Cookie、Authorization、X-Auth-Token等敏感头

规则实施的最佳实践

  1. 代码生成注意事项

    • 自动生成的代码也必须遵守这些规则
    • 如果规则被违反,必须添加注释说明问题并提供修正建议
  2. 错误处理

    • 当规则被触发时,应提供清晰的错误信息
    • 错误信息应帮助开发者理解问题本质和修复方法
  3. 防御深度

    • 建议在多个层面实施防护(应用层、网络层等)
    • 不要仅依赖单一防护措施

实际开发中的应用

在实际开发中,建议将这些规则集成到:

  • 代码审查流程
  • 静态代码分析工具
  • CI/CD管道中的安全检查步骤

通过多层次的防护,可以显著降低SSRF攻击的风险,保护系统和数据安全。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
176
2.07 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
203
280
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
957
566
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Python
78
72
Git4ResearchGit4Research
Git4Research旨在构建一个开放、包容、协作的研究社区,让更多人能够参与到开放研究中,共同推动知识的进步。
HTML
28
6
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.01 K
397
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
348
1.34 K
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
121
631