golang如何实现SSRF防护策略_golang SSRF防护策略实现方案

SSRF 是服务端请求伪造,Go 因 net/http 默认不限制 URL 而易受攻击;防护需三步:解析 URL、校验协议(仅 http/https)、检查主机(禁用私有 IP 和非白名单域名)。SSRF 是什么,为什么 Go 服务特别容易中招SSRF(Server-Side Request Forgery)不是用户直接攻击你的接口,而是诱使你的 Go 服务自己去"访问不该访问的地方"------比如 http://127.0.0.1:8080/admin 或内网 http://10.0.1.5:3306。Go 的 net/http 默认不做任何 URL 限制,http.Get(req.URL) 一调就发,只要传进来的是合法 URL,它就真去连。而很多业务场景天然需要"代理请求"或"URL 回调校验",比如:富文本图片自动下载、Webhook 地址验证、OAuth 第三方回调重定向地址解析......这些地方一旦对用户输入的 URL 缺乏白名单或协议/域名约束,SSRF 就几乎必然发生。用 net/url + net/http 做基础校验的硬核写法别依赖第三方中间件------SSRF 防护必须在业务逻辑入口做,且要细粒度控制。核心是三步:解析 URL → 检查协议 → 校验主机(含 IP 归属)。下面这段是生产可用的最小防护骨架:func isAllowedURL(rawURL string) error {u, err := url.Parse(rawURL)if err != nil {return fmt.Errorf("invalid URL format")}if u.Scheme != "https" && u.Scheme != "http" {return fmt.Errorf("disallowed scheme: %s", u.Scheme)}// 解析 host,支持域名和 IPv4/IPv6host, port, _ := net.SplitHostPort(u.Host)if host == "" {host = u.Host}ip := net.ParseIP(host)if ip != nil {if ip.IsLoopback() || ip.IsPrivate() || ip.IsUnspecified() {return fmt.Errorf("disallowed private/loopback IP: %s", host)}}// 白名单域名(建议从配置加载,而非硬编码)allowedHosts := mapstringbool{"api.example.com": true, "cdn.example.net": true}if _, ok := allowedHostshost; !ok {return fmt.Errorf("host not in allowlist: %s", host)}return nil}常见错误现象:url.Parse 后只检查 u.Host,却忽略 u.Scheme 被设为 file:// 或 ftp://;或用 strings.HasPrefix(u.Host, "127.") 这种字符串匹配,漏掉 127.0.0.1:8080 或 IPv6 的 ::1。gorilla/handlers.CORS 不能防 SSRF,但 SameSite 和 Referer 可辅助判断CORS 是浏览器行为,跟 SSRF 完全无关------攻击者根本不用浏览器,直接 curl -X POST 构造请求即可绕过所有前端限制。真正有用的辅助手段只有两个:Referer 头校验(需确认你允许的来源可信)和 SameSite=Strict Cookie 设置(防止跨站带认证态发起 SSRF 请求)。但注意:SameSite 对纯 API 场景无效,且不能替代 URL 白名单。立即学习"go语言免费学习笔记(深入)"; RedClaw 百度推出的手机端万能AI Agent助手

相关推荐
曲幽42 分钟前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API
python·fastapi·web·translate·goldendict·libretranslate·stardict·pystardict
渣波1 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
荣码1 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
兵慌码乱11 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵12 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio16 小时前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
用户03321266636717 小时前
使用 Python 从零创建 Word 文档
python
Csvn1 天前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定
后端·python
曲幽1 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
用户556918817531 天前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录
python·自动化运维