mysql注入

mysql注入

假如你开发了一个用户认证系统,应该用户登录后才能返回相应的结果

python 复制代码
# -*- coding: UTF-8 -*-
"""
@Project :pythonProject 
@File    :sql注入.py
@IDE     :PyCharm 
@Author  :于金龙@阿龙的代码在报错
@Date    :2024/8/27 下午4:01 
"""
import pymysql

conn = pymysql.connect(host='localhost',
                       port=3306,
                       user='root',
                       passwd="20020115",
                       db='user',
                       charset='utf8')
cursor = conn.cursor()


def log_on():
    name = input('输入用户名')
    password = input('输入密码')
    sql = f'select name,password from users where name={name} and password={password}'
    cursor.execute(sql)
    user = cursor.fetchall()
    if user:
        print('登录成功')
    else:
        print('密码或账号不匹配')


if __name__ == '__main__':
    log_on()

但是当我们在输入用户名的时候输入"" or 1=1 --不同输入对用户名和密码也可以登录成功 (如图所示)

MySQL 复制代码
mysql> select * from users;
+----+---------------+----------+
| id | name          | password |
+----+---------------+----------+
|  1 | yujinlong2002 | 20020115 |
|  2 | admin         | admin    |
|  3 | 2             | 2        |
+----+---------------+----------+
3 rows in set (0.00 sec)

可以在我们的数据表中是没有的

原因:

当我们输入的的用户名是和sql的关键字组成的一个完整的sql语句拼接的结果是:

mysql 复制代码
select * from users where name='' or 1=1 -- password=1;

提示:在MySQL中--表示的是注释,注释后的内容MySQL就不会在执行了

所以这段语句的意识就是查询name=' ' 或者 1=1,或者只要有一边正确就为正,所以这段sql就相当于select * from users,

然后就理所当然的登录成功了。

如何尽力避免sql注入的问题

在sql语句中我们尽力不用使用python的字符串格式化,尽力使用pymysql中的exectue的方法

python 复制代码
import pymysql

conn = pymysql.connect(host='localhost',
                       port=3306,
                       user='root',
                       passwd="20020115",
                       db='user',
                       charset='utf8')
cursor = conn.cursor()

def log_on():
    name = input('输入用户名')
    password = input('输入密码')
    cursor.execute('select name,password from users where name=%s and password=%s', (name, password))
    user = cursor.fetchall()
    if user:
        print('登录成功')
    else:
        print('密码或账号不匹配')

ursor.fetchall()

if user:

print('登录成功')

else:

print('密码或账号不匹配')

复制代码
相关推荐
Wave8456 分钟前
非阻塞按键(单击,双击,长按)
数据库
2401_8318249611 分钟前
为你的Python脚本添加图形界面(GUI)
jvm·数据库·python
久违的太阳12 分钟前
记录一次ORACLE RAC安装PSU补丁步骤
数据库·oracle
2401_8796938713 分钟前
用Pygame开发你的第一个小游戏
jvm·数据库·python
xushichao198923 分钟前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
sthnyph35 分钟前
初识MySQL · 库的操作
数据库·mysql
原来是猿36 分钟前
MySQL【视图】
数据库·mysql
2401_873587821 小时前
MySQL——事务管理
数据库·mysql
探索宇宙真理.1 小时前
SiYuan SQL漏洞 | CVE-2026-29073复现&研究
数据库·经验分享·sql·eureka·安全漏洞·siyuan
2501_945423541 小时前
工具、测试与部署
jvm·数据库·python