常见sql注入原理详解!

作者: 思梦PHP | 来源:发表于2017-11-16 21:23 被阅读42次

1、首先我们创建一个mysqli的链接

/**数据库配置*/

$config = ['hostname'=>"localhost", 'port'=>"3306", 'username'=>"root",'password'=>'','db'=>'sql'];

/**接收参数*/

$id = $_GET['id']?$_GET['id']:"";

if(empty($id)){

echo "article is not def"

}

/**链接数据库*/

$mysqli = new \mysqli($config['hostname'],$config['username'],$config['password'],$config['db']);

/**设置编码*/

$mysqli->set_charset("utf8");

url数字注入结果测试

我们访问url:http://localhost/mysql/index.php?id=1

结果展示:

array(size=2)'article_id'=>string'1'(length=1)'title'=>string'思梦php编写:PHP操作Redis详解案例'(length=44)

(1)/当我们在在url上稍作修改时:

http://localhost/mysql/index.php?id=1‘   //加一个单引号

这样你的sql语句就会报错

(2)我们再次修改url的时候

http://localhost/mysql/index.php?id=-1 or 1=1//后面参数修改成这样

结果展示了所有的文章列表

D:\wamp\www\mysql\index.php:11:array(size=2)'article_id'=>string'1'(length=1)'title'=>string'思梦php编写:PHP操作Redis详解案例'(length=44)

D:\wamp\www\mysql\index.php:11:array(size=2)'article_id'=>string'2'(length=1)'title'=>string'Mysql存储过程从0开始(上)'(length=36)

D:\wamp\www\mysql\index.php:11:array(size=2)'article_id'=>string'3'(length=1)'title'=>string'思梦php编写:PHP排序的几种方法'(length=42).............

2、表单注入,主要利用sql语句的注释

$username = $_POST['username']?$_POST['username']:"";

$password = $_POST['password']?$_POST['password']:"";

$sql = "select * from tb_member where account='$username'AND password='$pass'";

$res = $mysqli->query($sql);

$row = $res->fetch_assoc();

if($row){

echo "登录成功!";

}else{

echo "账号密码错误!";

}

正常输入

打印:登录成功!

我们简单修改一下

打印:登录成功!

原理:首先使用单引号结束sql语句,然后加#注释后面的sql语句

同理另一种方式为

打印:登录成功!

原理:首先使用单引号结束sql语句,然后加(-- )注释后面的sql语句

相关文章

  • 常见sql注入原理详解!

    1、首先我们创建一个mysqli的链接 /**数据库配置*/ $config = ['hostname'=>"lo...

  • SQL注入

    SQL注入 概念 危害 原理 实例 防御 基础 - ### SQL语句所用符号不同数据库的sql注入与提权常见S...

  • OWASP TOP 10 总结

    一、注入(常见sql注入)原理:违背了“数据与代码分离”原则。通过拼接sql语句获取敏感数据条件:数据没有经过程序...

  • java框架之MybatisSQL注入漏洞

    一、SQL注入漏洞基本原理 在常见的web漏洞中,SQL注入漏洞较为常见,危害也较大。攻击者一旦利用系统中存在的S...

  • Mybatis SQL注入防护与like查询中的通配符

    一、Mybatis SQL注入防护原理 sql注入大家都不陌生,是一种常见的攻击方式,攻击者在界面的表单信息或ur...

  • web安全测试(2)

    本章主要介绍常见web安全漏洞。 一、SQL注入 SQL注入(SQL Injection),是最常见影响非常广泛的...

  • web 安全

    常见web安全及防护原理 sql注入原理就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,...

  • BUUCTF-Web-随便注(三种解题思路)

    知识点:SQL注入-堆叠注入,sql预处理语句,巧用contact()函数绕过 堆叠注入原理: 在SQL中,分号(...

  • 2020-07-29

    安全渗透测试-sql注入 总目标: 1、sql注入介绍 2、web安全渗透测试分类 3、sql注入原理 4、sql...

  • sql注入风险

    SQL注入攻防入门详解 如何从根本上防止 SQL 注入 教您使用参数化SQL语句 参数化查询为什么能够防止SQL注...

网友评论

    本文标题:常见sql注入原理详解!

    本文链接:https://www.haomeiwen.com/subject/ajbrvxtx.html