sql注入
1 解决办法
1.1 中间件
1.2 占位符
1.3 用ORM时其会自动处理
2 详细
2-1 SQL注入问题 * 利用MySQL的注释语法,钻空子实现常规操作才能操作的功能 案例: 结合MySQL实现用户的登陆 import pymysql # 链接数据库 conn = pymysql.connect( host='127.0.0.1', port=3306, user='root', passwd='1', charset='utf8', database='db6' ) # 产生一个游标对象 cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) username = input('请输入用户名>>>:').strip() password = input('请输入密码>>>:').strip() sql = "select * from user where name='%s' and password='%s'" % (username, password) print(sql) res_sql = cursor.execute(sql) # 若输入正确 if res_sql: print('登陆成功') # 获取数据 print(cursor.fetchall()) else: print('登陆失败') 现象1: 无需用户名即可登陆 现象2: 无需密码可登陆 2-2 解决 import pymysql # 链接数据库 conn = pymysql.connect( host='127.0.0.1', port=3306, user='root', passwd='1', charset='utf8', database='db6' ) # 产生一个游标对象 cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) username = input('请输入用户名>>>:').strip() password = input('请输入密码>>>:').strip() sql = "select * from user where name=%s and password=%s" """ 办法: 不手动拼接敏感数据,先用%s占位,之后将需要拼接的数据交给execute方法 """ print(sql) """ 将要拼接的数据用元组的形式组合起来,execute 会自动识别%s,过滤特殊符号,并用元组里的数据替换%s """ res_sql = cursor.execute(sql, (username,password)) # 若输入正确 if res_sql: print('登陆成功') # 获取数据 print(cursor.fetchall()) else: print('登陆失败')
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!