python sql注入如何防止_Python如何防止sql注入

Python如何防止sql注入。web漏洞之首莫过于sql了,不管使用哪种语言进行web后端开发,只要使用了关系型数据库,可能都会遇到sql注入攻击问题。4667a9c0301d778094283f2354580512.png

那么在Python web开发的过程中sql注入是怎么出现的呢,又是怎么去解决这个问题的?

这里并不想讨论其他语言是如何避免sql注入的,网上关于PHP防注入的各种方法都有,Python的方法其实类似,这里我就举例来说说。

起因

漏洞产生的原因最常见的就是字符串拼接了。

当然,sql注入并不只是拼接一种情况,还有像宽字节注入,特殊字符转义等等很多种,这里就说说最常见的字符串拼接,这也是初级程序员最容易犯的错误。

首先咱们定义一个类来处理mysql的操作:ea08acca61e4677986c818eb15c3b9d6.png

这个类有问题吗?

答案是:有!

这个类是有缺陷的,很容易造成sql注入,下面就说说为何会产生sql注入。

为了验证问题的真实性,这里就写一个方法来调用上面的那个类里面的方法,如果出现错误会直接抛出异常。d56207387f306927e7f1940b8be06ea8.png

这个方法非常简单:

一个最常见的select查询语句,也使用了最简单的字符串拼接组成sql语句,很明显传入的参数 testUrl 可控,要想进行注入测试,只需要在testUrl的值后面加上单引号即可进行sql注入测试。

这个不多说,肯定是存在注入漏洞的,脚本跑一遍,看啥结果:

(1064, "You have an error in your SQL syntax; check the manual that

corresponds to your MariaDB server version for the right syntax to use

near ''t.tips''' at line 1")

回显报错,很眼熟的错误,这里我传入的测试参数是:

t.tips'

下面再说一种导致注入的情况,对上面的方法进行稍微修改:290065e6a3ba69ec6a362da34809bc17.png

这个方法里面没有直接使用字符串拼接,而是使用了 %s 来代替要传入的参数,看起来是不是非常像预编译的sql?

那这种写法能不能防止sql注入呢?测试一下便知道,回显如下:

(1064, "You have an error in your SQL syntax; check the manual that

corresponds to your MariaDB server version for the right syntax to use

near ''t.tips''' at line 1")

和上面的测试结果一样,所以这种方法也是不行的,而且这种方法并不是预编译sql语句,那么怎么做才能防止sql注入呢?

解决

两种方案

1.对传入的参数进行编码转义

2. 使用Python的MySQLdb模块自带的方法

第一种方案其实在很多PHP的防注入方法里面都有,对特殊字符进行转义或者过滤。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值