• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > sql注入实例以及如何防sql注入

sql注入实例以及如何防sql注入

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了sql注入,实例等相关知识,希望本文的分享对您有所帮助

概述

??sql注入就是利用某些数据库的外接接口将用户数据插入到实际的数据库操作语言当中,从而达到入侵数据库乃至操作系统的目的。在安全领域,我们永远不要信任用户的输入,我们必须认定用户输入的数据都是不安全的,我们都需要对用户输入的数据进行过滤处理。没有(运行时)编译,就没有注入。所以从根本上防止上述类型攻击的手段,还是避免数据变成代码被执行,时刻分清代码和数据的界限。而具体到SQL注入来说,被执行的恶意代码是通过数据库的SQL解释引擎编译得到的,所以只要避免用户输入的数据被数据库系统编译就可以了。
??与其他数据库不同,MySQL可以运行在不同的SQL Mode(SQL服务器模式)下,并且可以为不同客户端应用不同模式。这样每个应用程序可以根据自己的需求来定制服务器的操作模式。模式定义MySQL应支持哪些SQL语法,以及应执行哪种数据验证检查。这有点类似于apache配置不同级别的错误日志,报告哪些错误,又不报告哪些错误。

SQL注入

1.注入实例

//php代码
$unsafe_variable = $_POST['user_input'];   
mysql_query("INSERT INTO `table` (`column`) VALUES ('{$unsafe_variable}')");

当post中代码如下时候:

value'); DROP TABLE table;--

查询代码变成

INSERT INTO `table` (`column`) VALUES('value'); DROP TABLE table;--')

这样会直接删除table表,你的数据被破坏了。

2.防止sql注入

方法一
prepareStatement+Bind-Variable:SQL语句和查询的参数分别发送给数据库服务器进行解析。
对于php来说有两种实现方式。

//使用PDO(PHP data object)
$stmt = $pdo->prepare('SELECT * FROM employees WHERE name = :name');  
$stmt->execute(array('name' => $name));  
foreach ($stmt as $row) {  
    // do something with $row  
}

//使用mysql扩展-mysqli
$stmt = $dbConnection->prepare('SELECT * FROM employees WHERE name = ?');
$stmt->bind_param('s', $name);
$stmt->execute();
$result = $stmt->get_result();
while ($row = $result->fetch_assoc()) {
    // do something with $row
}

方式二
对查询语句进行转义(最常见的方式):使用应用程序提供的转换函数。
|应用|函数|

|--------|
|MySQL C 
API
|
mysql_real_escape_string
()|
|MySQL++|escape和quote修饰符|
|PHP|使用mysql_real_escape_string()(适用于PHP4.3.0以前),之后可以使用mysqli或pdo|
|
Perl
 DBI|placeholder或quote()|
|Ruby DBI|placeholder或quote()|

方式三
使用自己定义函数进行校验:其本质上还是对输入非法数据进行转义和过滤。
输入验证可以分为:1.整理数据使之有效;2.拒绝已知的非法输入;3.只接收已知的合法输入。

方式四
使用存储过程。
存储过程参见: (9)mysql中的存储过程和自定义函数

sql服务器模式

1.sql模式语法

#查看当前sql模式
select @@sql_mode;
#查看当前sql模式
SELECT @@session.sql_mode;
#修改当前sql模式
SET [SESSION][GLOBAL] sql_mode='modes';
  • 其中session选项表示只在本次连接生效;而global表示在本次连接不生效,下次连接生效。

  • 也可以使用“--sql-mode='modes'”,在MySQL启动时候设置sql_mode。

  • 可以在配置文件中设置。

    2.sql_mode常用值

    ONLY_FULL_GROUP_BY:
    对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中。

NO_AUTO_VALUE_ON_ZERO:
该值影响自增长列的插入。默认设置下,插入0或NULL代表生成下一个自增长值。如果用户 希望插入的值为0,而该列又是自增长的,那么这个选项就有用了。

STRICT_TRANS_TABLES:
在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制。

NO_ZERO_IN_DATE:
在严格模式下,不允许日期和月份为零。

NO_ZERO_DATE:
设置该值,mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告。

ERROR_FOR_pISION_BY_ZERO:
在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。如 果未给出该模式,那么数据被零除时MySQL返回NULL。

NO_AUTO_CREATE_USER:
禁止GRANT创建密码为空的用户。

NO_ENGINE_SUBSTITUTION:
如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常。

PIPES_AS_CONCAT:
将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似。

ANSI_QUOTES:
启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符。

说明

ORACLE的sql_mode设置等同:PIPES_AS_CONCAT, ANSI_QUOTES, IGNORE_SPACE, NO_KEY_OPTIONS, NO_TABLE_OPTIONS, NO_FIELD_OPTIONS, NO_AUTO_CREATE_USER。

【相关推荐】

1. 免费mysql在线视频教程

2. MySQL最新手册教程

3. 布尔教育燕十八mysql入门视频教程

以上就是sql注入实例以及如何防sql注入的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅谈开启magic_quote_gpc后的sql注入攻击与防范
  • 利用SQL注入漏洞拖库的方法
  • 利用SQL注入漏洞登录后台的实现方法
  • sql格式化工具集合
  • 什么是SQL注入?带你从零开始认识SQL注入
  • 如何使用PDO查询mysql避免SQL注入的方法
  • 如何防止sql注入?介绍5种防止sql注入的方法
  • sql注入实例以及如何防sql注入
  • PDO防止sql注入的机制
  • mysql进阶(二十四)防御SQL注入的方法总结

相关文章

  • 2018-12-05 mongodb sharding 原理学习与试用(五)之添加与移除shard
  • 2018-12-05关于SQL中CTE(公用表表达式)(Common Table Expression)的总
  • 2018-12-05SQL SERVER 与ACCESS、EXCEL的数据转换方法分享
  • 2018-12-05MySQL中curdate()函数的代码案例
  • 2018-12-05MySql5.6使用validate password 插件加强密码强度的安装及使用方法_MySQL
  • 2018-12-05sqlserver 2008手工修改表结构,表不能保存的问题与解决方法
  • 2018-12-05给你的数据库文件减肥
  • 2018-12-05sql2005 日志清理 SQL2005压缩清除日志的方法
  • 2018-12-05详细介绍Linux系统MySQL忘记密码,重置密码,忽略表名、列名大小写的方法
  • 2018-12-05Mysql中创建用户帐户的方法

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • tpcc-mysql安装测试与使用的实例教程
    • mysql5.5与mysq 5.6中禁用innodb引擎的方法
    • mysql 导出select语句结果到excel文件遇到问题及解决方法_MySQL
    • MySQL 用户权限详细汇总
    • MySql官方手册学习笔记1 MySql简单上手
    • Mysql学习总结(17)MySQL数据库表设计优化_MySQL
    • 使用准则进行条件查询--1.3.运行查询前输入参数
    • 64位Win10系统安装Mysql5.7.11的方法(案例详解)_MySQL
    • 有关mysql优化的一些东东整理
    • MySQL索引优化的实际案例分析

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有