首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SQL注入原理及防御

SQL注入尤其是字符串型注入尤为明显且容易,下面以登录校验为例简单介绍其原理和防御策略。

登录接口SQL

根据用户名和密码获取用户数据:

正常情况下的请求体application/json:

所得到的SQL:

SQL注入下的请求体

此时得到的SQL将是:

成功注入的原因:

和原来的结合

后面的sql组成部分变成了注释,失去了原来的and逻辑判断作用

且永远为真

结果:

将会造成用户表所有数据的泄露

SQL注入防御

阻止SQL注入的方法主要是利用现有数据库第三方库完善的防SQL注入的特性,避免重复造轮子

原始SQL情况下

使用%s占位符,利用PyMySQL自带的防注入特性

ORM情况下

SQLAlchemy ORM已经对SQL注入进行了处理,直接使用ORM语法即可,不需要特别处理。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20210324A01A5V00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券