防止web项目中的SQL注入


Posted in MySQL onDecember 06, 2021

一、SQL注入简介

SQL注入是比较常见的网络攻击方式之一,它不是利用操作系统的BUG来实现攻击,而是针对程序员编写时的疏忽,通过SQL语句,实现无账号登录,甚至篡改数据库。

二、SQL注入攻击的总体思路

  • 1.寻找到SQL注入的位置
  • 2.判断服务器类型和后台数据库类型
  • 3.针对不同的服务器和数据库特点进行SQL注入攻击

三、SQL注入攻击实例

比如在一个登录界面,要求输入用户名和密码:

可以这样输入实现免帐号登录:

用户名: ‘or 1 = 1 –

密 码:

点登陆,如若没有做特殊处理,那么这个非法用户就很得意的登陆进去了.(当然现在的有些语言的数据库API已经处理了这些问题)

这是为什么呢? 下面我们分析一下:

从理论上说,后台认证程序中会有如下的SQL语句:

String sql = "select * from user_table where username=
' "+userName+" ' and password=' "+password+" '";

当输入了上面的用户名和密码,上面的SQL语句变成:
SELECT * FROM user_table WHERE username=
''or 1 = 1 -- and password=''

"""
分析SQL语句:
条件后面username=”or 1=1 用户名等于 ” 或1=1 那么这个条件一定会成功;

然后后面加两个-,这意味着注释,它将后面的语句注释,让他们不起作用,这样语句永远都能正确执行,用户轻易骗过系统,获取合法身份。
这还是比较温柔的,如果是执行
SELECT * FROM user_table WHERE
username='' ;DROP DATABASE (DB Name) --' and password=''
其后果可想而知…
"""

四、如何防御SQL注入

注意:但凡有SQL注入漏洞的程序,都是因为程序要接受来自客户端用户输入的变量或URL传递的参数,并且这个变量或参数是组成SQL语句的一部分,

对于用户输入的内容或传递的参数,我们应该要时刻保持警惕,这是安全领域里的「外部数据不可信任」的原则,纵观Web安全领域的各种攻击方式,

大多数都是因为开发者违反了这个原则而导致的,所以自然能想到的,就是从变量的检测、过滤、验证下手,确保变量是开发者所预想的。

1、检查变量数据类型和格式

如果你的SQL语句是类似where id={$id}这种形式,数据库里所有的id都是数字,那么就应该在SQL被执行前,检查确保变量id是int类型;如果是接受邮箱,那就应该检查并严格确保变量一定是邮箱的格式,其他的类型比如日期、时间等也是一个道理。总结起来:只要是有固定格式的变量,在SQL语句执行前,应该严格按照固定格式去检查,确保变量是我们预想的格式,这样很大程度上可以避免SQL注入攻击。

比如,我们前面接受username参数例子中,我们的产品设计应该是在用户注册的一开始,就有一个用户名的规则,比如5-20个字符,只能由大小写字母、数字以及一些安全的符号组成,不包含特殊字符。此时我们应该有一个check_username的函数来进行统一的检查。不过,仍然有很多例外情况并不能应用到这一准则,比如文章发布系统,评论系统等必须要允许用户提交任意字符串的场景,这就需要采用过滤等其他方案了。

2、过滤特殊符号

对于无法确定固定格式的变量,一定要进行特殊符号过滤或转义处理。

3、绑定变量,使用预编译语句

MySQL的mysqli驱动提供了预编译语句的支持,不同的程序语言,都分别有使用预编译语句的方法

实际上,绑定变量使用预编译语句是预防SQL注入的最佳方式,使用预编译的SQL语句语义不会发生改变,在SQL语句中,变量用问号?表示,黑客即使本事再大,也无法改变SQL语句的结构

小结:

  • 1.使用预编译绑定变量的SQL语句
  • 2.严格加密处理用户的机密信息
  • 3.不要随意开启生产环境中Webserver的错误显示
  • 4.使用正则表达式过滤传入的参数
  • 5.字符串过滤
  • 6.检查是否包函非法字符

总的来说,防范一般的SQL注入只要在代码规范上下点功夫就能预防

以上所述是小编给大家介绍的防止web项目中的SQL注入,希望对大家有所帮助。在此也非常感谢大家对三水点靠木网站的支持!

MySQL 相关文章推荐
MySQL中出现乱码问题的终极解决宝典
May 26 MySQL
一文读懂navicat for mysql基础知识
May 31 MySQL
Mysql8.0递归查询的简单用法示例
Aug 04 MySQL
Mysql关于数据库是否应该使用外键约束详解说明
Oct 24 MySQL
关于mysql中时间日期类型和字符串类型的选择
Nov 27 MySQL
MySQL数据库⾼可⽤HA实现小结
Jan 22 MySQL
千万级用户系统SQL调优实战分享
Mar 03 MySQL
SQL注入篇学习之盲注/宽字节注入
Mar 03 MySQL
mysql使用instr达到in(字符串)的效果
Apr 03 MySQL
MySQL外键约束(Foreign Key)案例详解
Jun 28 MySQL
MySQL事务的隔离级别详情
Jul 15 MySQL
mysql sock文件存储了什么信息
Jul 15 MySQL
mysql创建存储过程及函数详解
Dec 04 #MySQL
mysql5.6主从搭建以及不同步问题详解
MySQL图形化管理工具Navicat安装步骤
全面盘点MySQL中的那些重要日志文件
关于mysql中时间日期类型和字符串类型的选择
Nov 27 #MySQL
VS2019连接MySQL数据库的过程及常见问题总结
Linux7.6二进制安装Mysql8.0.27详细操作步骤
You might like
什么是调频(FM)、调幅(AM)、短波(SW)、长波(LW)
2021/03/01 无线电
yii2.0框架场景的简单使用示例
2020/01/25 PHP
JS维吉尼亚密码算法实现代码
2010/11/09 Javascript
javascript实现动态侧边栏代码
2014/02/19 Javascript
jQuery循环动画与获取组件尺寸的方法
2015/02/02 Javascript
JS实现网页滚动条感应鼠标变色的方法
2015/02/26 Javascript
js实现根据身份证号自动生成出生日期
2015/12/15 Javascript
JS简单编号生成器实现方法(附demo源码下载)
2016/04/05 Javascript
jquery表格datatables实例解析 直接加载和延迟加载
2016/08/12 Javascript
D3.js中强制异步文件读取同步的几种方法
2017/02/06 Javascript
JS之if语句对接事件动作逻辑(详解)
2017/06/28 Javascript
JavaScript输出所选择起始与结束日期的方法
2017/07/12 Javascript
详解React Native顶|底部导航使用小技巧
2017/09/14 Javascript
快速搭建React的环境步骤详解
2017/11/06 Javascript
Three.js开发实现3D地图的实践过程总结
2017/11/20 Javascript
通过Kettle自定义jar包供javascript使用
2020/01/29 Javascript
Vue数字输入框组件使用方法详解
2020/02/10 Javascript
[04:27]2014DOTA2国际邀请赛 NAVI战队官方纪录片
2014/07/21 DOTA
python实现的简单窗口倒计时界面实例
2015/05/05 Python
小小聊天室Python代码实现
2016/08/17 Python
Python实现的读取/更改/写入xml文件操作示例
2018/08/30 Python
Python两台电脑实现TCP通信的方法示例
2019/05/06 Python
如何利用Anaconda配置简单的Python环境
2019/06/24 Python
Python 多进程原理及实现
2020/12/21 Python
如何用Python进行时间序列分解和预测
2021/03/01 Python
发现两个有趣的CSS3动画效果
2013/08/14 HTML / CSS
CSS3打造百度贴吧的3D翻牌效果示例
2017/01/04 HTML / CSS
英国著名的美容护肤和护发产品购物网站:Lookfantastic
2020/11/23 全球购物
PHP面试题及答案二
2015/05/23 面试题
中秋寄语大全
2014/04/11 职场文书
本科毕业生应聘自荐信范文
2014/06/26 职场文书
区域销售经理岗位职责
2015/04/02 职场文书
酒店财务总监岗位职责
2015/04/03 职场文书
vue实现无缝轮播效果(跑马灯)
2021/05/14 Vue.js
python opencv将多个图放在一个窗口的实例详解
2022/02/28 Python
游戏《我的世界》澄清Xbox版暂无计划加入光追
2022/04/03 其他游戏