0

0

使用Golang进行安全性测试_检测潜在的SQL注入点

P粉602998670

P粉602998670

发布时间:2026-02-15 13:38:03

|

247人浏览过

|

来源于php中文网

原创

go中sql注入高危操作是拼接sql字符串,必须用参数化查询(如?或$1占位符),严格校验输入,禁用orm全局操作,并在测试中覆盖恶意输入场景。

使用golang进行安全性测试_检测潜在的sql注入点

Go 里用 database/sql 拼接 SQL 字符串就是高危操作

只要看到 fmt.Sprintf+ 拼接 SQL 查询,基本等于在入口处敞开了 SQL 注入大门。Go 的 database/sql 原生支持参数化查询,但不强制——你不用,它就真不拦。

  • 常见错误现象:sql.ErrNoRows 看似正常,但实际请求中带 ' OR 1=1 -- 却返回了全部用户数据
  • 使用场景:登录验证、搜索接口、ID 查询(如 SELECT * FROM users WHERE id = %s
  • 正确做法:一律用 ? 占位符 + db.Query/db.Exec 的变参传入,例如 db.Query("SELECT * FROM users WHERE name = ?", username)
  • 注意:PostgreSQL 驱动(lib/pq)用 $1,MySQL(go-sql-driver/mysql)用 ?,别混用;SQLite 也认 ?

自定义 HTTP handler 中未校验输入就透传到 SQL 就是漏洞温床

很多 Go Web 服务直接把 r.URL.Query().Get("id")json.Unmarshal 后的字段塞进 SQL,中间零过滤、零类型断言、零长度限制。

  • 常见错误现象:请求 /api/user?id=1%20UNION%20SELECT%20password%20FROM%20users 返回密码字段
  • 使用场景:REST API 的 GET 查询参数、POST JSON body、URL 路径变量(如 /user/:id
  • 实操建议:
    – 对数字 ID 强制转 strconv.Atoi,失败即拒;
    – 对字符串字段做白名单校验(如用户名只允许 [a-zA-Z0-9_])或长度截断(string[:50]);
    – 别信 html.EscapeString,它对 SQL 注入完全无效

ORM 如 GORM 默认开启 AllowGlobalUpdate 会放大风险

GORM v2 默认允许全局更新/删除,配合构造的 map 输入,一条 db.Where(input).Delete(&User{}) 可能删光整表。

  • 常见错误现象:curl -X POST /admin/delete -d '{"status": "active"}' 导致所有 active 用户被删
  • 参数差异:db.Session(&gorm.Session{AllowGlobalUpdate: false}) 才是安全基线;v2.2+ 还需显式关掉 Config.SkipDefaultTransaction = true 避免隐式事务绕过检查
  • 性能影响:禁用全局操作几乎无开销;但若业务真需要批量操作,请改用明确主键列表 + IN 查询,而非开放 where 条件
  • 兼容性注意:GORM v1 的 Unscoped() 和 v2 的 Session 行为不一致,升级时务必重审所有 Delete/Update 调用点

写单元测试时只 mock DB 层会漏掉注入逻辑

mock sqlmockgomock 很容易只验证「SQL 字符串是否匹配预期」,却忽略「这个字符串是怎么拼出来的」。真正的注入路径藏在参数组装逻辑里。

立即学习go语言免费学习笔记(深入)”;

  • 实操建议:
    – 测试用例必须覆盖恶意输入:传 "admin' --""1 OR 1=1""test%; DROP TABLE users;"
    – 不要只断言 error 是否为 nil,要检查最终执行的 SQL 是否含未转义单引号或注释符;
    – 在集成测试中启用 sqlmock.ExpectQuery 并开启 ExpectationsWereMet,确保没漏掉任何非参数化调用
  • 容易踩的坑:用 reflect.DeepEqual 比较 struct 输入时,忽略嵌套 map 或 interface{} 字段可能被恶意污染;这类字段应单独做 schema 校验

最麻烦的不是不会写参数化查询,而是有些老代码里 SQL 构造分散在 3 个 helper 函数 + 1 个模板里,还混着 fmt.Sprintfstrings.ReplaceAll。这种地方没法靠 lint 工具扫出来,得一行行看执行流——尤其注意那些“只是读配置”的函数,它们很可能悄悄拼了 SQL。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

235

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

346

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

212

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

403

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

343

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

197

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

866

2025.06.17

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

76

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 5.1万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号