mysql - sql报错原因?
问题描述
发现一个正在维护的老系统的基于orderBy的sql注入漏洞,准备验证一下,
我先执行这个sql注入,是可以的
SELECT sysitem_item.item_id FROM sysitem_item `sysitem_item` ORDER BY (selectcasewhen(1=1)then1else(select depositfrom sysuser_user_deposit)end)=1 ASC LIMIT 20 OFFSET 0
但是当我执行这个带update语句的sql时报错了:
SELECT sysitem_item.item_id FROM sysitem_item `sysitem_item` ORDER BY (selectcasewhen(1=1)then1else(updatesysuser_user_depositsetdeposit=11)end)=1 ASC LIMIT 20 OFFSET 0
报错
<code>#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ’update<br>sysuser_user_deposit<br>set<br>deposit=11)end)=1 ASC LIMIT 20 OFFSET 0’ at line 9</code>
我应该如何让他执行update?
问题解答
回答1:主体是select的时候,里面是不能update的,否则执行不了的,mybatis这种注入我试过,<select>里执行update直接报错,注入不了
相关文章:
1. MYSQL 根据两个字段值查询 但两个值的位置可能是互换的,这个怎么查?2. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?3. mysql replace 死锁4. mysql - C#连接数据库时一直这一句出问题int i = cmd.ExecuteNonQuery();5. javascript - 微信网页开发从菜单进入页面后,按返回键没有关闭浏览器而是刷新当前页面,求解决?6. extra没有加载出来7. android - 安卓做前端,PHP做后台服务器 有什么需要注意的?8. python - 数据与循环次数对应不上9. php传对应的id值为什么传不了啊有木有大神会的看我下方截图10. mysql - ubuntu开启3306端口失败,有什么办法可以解决?
