【安全】(三)Django之SQL注入防御

1、什么是SQL注入

SQL注入是针对数据的一种攻击手段。黑客通过各种方法恶意篡改你后台中访问数据库的SQL语句,从而达到他的目的。如防御不当,黑客通过SQL注入可获取数据库相关隐私信息、恶意修改数据、恶意删除数据等。

2、Django中如何防御SQL注入

Django自带的ORM查询在进行数据访问时,会根据使用的数据库服务器(例如:MySql)的转换规则,自动转义特殊的SQL参数。注意有一个方法另外extra(),这个方法接受原始的SQL。

3、我的防御方案

第一步:对用户提交的字符串做安全验证。若含有危险字符串,则拒绝访问。

第二步:验证用户提交数据的类型、长度等。

第三步:进行数据的增删改查时尽量使用Django的ORM进行查询。若要使用到SQL语句进行查询可使用以下方案,需要传进数据库的数据进行参数化处理。方法如下;

my_connection = connections['default']
with my_connection.cursor() as cursor:
    sql = '''select * from my_table where id = "%s" '''
    cursor.execute(sql,[pk])
    cursor.execute(sql)
    result = cursor.fetchall()
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迷明小栈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值