文章详情页
mysql - 看这条sql有可能被注入吗
浏览:239日期:2022-06-20 14:00:12
问题描述
SELECT * FROM table1 where condition1=1 ORDER BY $sortField$ $sortOrder$ limit 0,20
$sortField$和$sortOrder$可以写任意sql
这条sql有被注入的风险吗
问题解答
回答1:只要你直接用变量来生成sql语句,都有被注入的风险
SELECT * FROM table1 where condition1=1 ORDER BY $sortField$ $sortOrder$ limit 0,20
sortField='id'sortOrder='; drop table users; --'
你的sql就会变成
SELECT * FROM table1 where condition1=1 ORDER BY id; drop table users; -- limit 0,20回答2:
你考虑问题的方向不正确。
防注入的正确做法是使用官方驱动的参数模式,因为只有官方自己的东西,才知道应该怎样避免被注入。
如果你自己写SQL,就算现在不被注入,说不定这条链路中所涉及的组件,在以后其中某个组件发生变化,那就会有被注入的风险。
回答3:你直接可以拿sqlmap测试一下,它的引擎还是很强大的
相关文章:
1. golang - 用IDE看docker源码时的小问题2. debian - docker依赖的aufs-tools源码哪里可以找到啊?3. docker start -a dockername 老是卡住,什么情况?4. macos - mac下docker如何设置代理5. docker images显示的镜像过多,狗眼被亮瞎了,怎么办?6. docker镜像push报错7. docker-machine添加一个已有的docker主机问题8. dockerfile - 为什么docker容器启动不了?9. 关于docker下的nginx压力测试10. docker内创建jenkins访问另一个容器下的服务器问题
排行榜

网公网安备