三、SQL注入之报错注入

news2024/11/17 10:43:48

文章目录

  • 1、 xpath语法
    • (1)extractvalue
    • (2)updatexml
  • 2、concat+rand()+group by()导致主键重复

  报错注入就是利用了数据库的某些机制,人为地制造错误条件,使得查询结果能够出现在错误信息中。这里主要介绍报错注入中常用的xpath语法错误和 concat+rand()+group by()导致主键重复。

1、 xpath语法

 利用xpath语法错误进行报错注入主要利用以下两个函数:

  • extractvalue
  • updatexml

注意: xpath语法错误使用条件必须满足mysql版本>5.1.5。

(1)extractvalue

  作用:从目标xml中返回包含所查询值的字符串。其语法:
extractvalue(xml_document,xpath_string),即extractvalue('目标xml文件名','在xml中查询的字符串')

第一个参数: xml_document是string格式,为xml文档对象的名称
第二个参数: xpath_string是xpath格式的字符串
注意:第二个参数是要求符合xpath语法的字符串,如果不满足要求,则会报错,并且将查询结果放在报错信息里

payloadselect extractvalue(1,concat('~',database()))

  • Xpath没问题的情况下,在1中查询不到database()的结果,但是也没有语法错误,所以不会报错。
    在这里插入图片描述
  • Xpath有问题的情况,用concat函数拼接一个错误的Xpath让mysql报错得到包含查询值的字符串。
    在这里插入图片描述

  注意:extractvalue()能查询字符串的最大长度为32,如果我们想要的结果趋过32,那要用substring()函数截取或limit分页,一次查看最多32位。

(2)updatexml

  作用:改变文档中符合条件的节点的值,语法:
updatexml(xml_document,xpath_string,new_value)

  • 第一个参数:xml_document是string格式,为xml文档对象的名称;
  • 第二个参数:xpath_string是xpath格式的字符串,第二个参数跟extractvalue函数一样,且利用方式相同;
  • 第三个参数:new_document是string格式,替换查找到的符合条件的数据;

payload select updatexml(1,concat('~ ',(select version()), '~'),1)

  • Xpath没问题的情况下,结果如下:
    在这里插入图片描述

  • Xpath有问题的情况,结果如下。
    在这里插入图片描述

2、concat+rand()+group by()导致主键重复

  这种报错方法的本质是因为floor(rand()*2)的重复性,导致group by语句出错。group by key的原理是循环读取数据的每一行,将结果保存于临时表中。读取每一行的key时,如果key存在于临时表中,则不在临时表中更新临时表的数据;如果key不在临时表中,则在临时表中插入key所在行的数据。

  • floor():对任意正或者负的十进制值向下取整;
  • rand():生成0~1之间的随机数;
  • rand(0)*2:生成0~2之间的随机数;
  • floor(rand()*2):有两条记录就会报错;
  • floor(rand(0)*2):记录需3条以上,且3条以上必报错,返回的值有规律;
  • count():是用来统计结果的,相当于刷新一次结果,简单来说就是计数;
  • group by():在对数据进行分组时会先看看虚拟表里有没有这个值,没有的话就插入,存在的话count()加1

  payloadselect 1 from (select count(*),concat((select语句),floor(rand()*2))x from information_schema.tables group by x)a

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/908554.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SOLIDWORKS基准面介绍

SOLIDWORKS是一款广泛应用于机械设计领域的三维建模软件,其中基准面是在建模过程中必不可少的要素。本文将介绍什么是SOLIDWORKS基准面,以及它在设计中的作用。 SOLIDWORKS基准面是指在设计过程中用来确定草图绘制、特征创建的参考平面。 SOLIDWORKS基…

如何在 Ubuntu 中安装最新的 Python 版本

动动发财的小手,点个赞吧! Python 是增长最快的主要通用编程语言。其原因有很多,例如其可读性和灵活性、易于学习和使用、可靠性和效率。 目前使用的 Python 有两个主要版本 – 2 和 3(Python 的现在和未来)&#xff1…

一篇搞懂TCP、HTTP、Socket、Socket连接池

前言:作为一名开发人员我们经常会听到HTTP协议、TCP/IP协议、UDP协议、Socket、Socket长连接、Socket连接池等字眼,然而它们之间的关系、区别及原理并不是所有人都能理解清楚,这篇文章就从网络协议基础开始到Socket连接池,一步一步…

微服务基础知识

文章目录 微服务基础知识一、系统架构的演变1、单体应用架构2、垂直应用架构3、分布式SOA架构(1)什么是SOA(2)SOA架构 4、微服务架构5、SOA和微服务的关系(1)SOA(2)微服务架构 二、分…

别再排长队了,食堂用餐轻松搞定!

随着科技的不断进步,学校食堂正逐步迎来智能化和数字化的转变。智慧收银系统作为这一转变的重要组成部分,为学校食堂管理带来了全新的可能性和机遇。 在这个数字化时代,智慧收银系统正成为学校食堂迈向未来的关键一步。 客户案例 湖南某大学…

电子器件系列46:气体放电管

C1566785_气体放电管(GDT)_B88069X5010S102_规格书_TDK气体放电管(GDT)规格书 气体放电管指作过电压保护用的避雷管或天线开关管一类,管内有二个或多个电极,充有一定量的惰性气体。气体放电管是一种间隙式的防雷保护元件,它用在通信系统的防雷…

Java详解编译型和解释型语言

在计算机的高级编程语言类型分为两种,分别是编译型和解释型,而Java既有编译型又有解释型 什么是编译型?什么是解释型? 字面上来说编译和解释都有‘翻译’的意思,而她们两个的区别是‘翻译’的时机不同,什…

Flask入门一 ——虚拟环境及Flask安装

Flask入门一 ——虚拟环境及Flask安装 在大多数标准中,Flask都算是小型框架,小到可以称为“微框架”,但是并不意味着他比其他框架功能少。Flask自开发伊始就被设计为可扩展的框架。Flask具有一个包含基本服务的强健核心,其他功能…

leetcode304. 二维区域和检索 - 矩阵不可变(java)

前缀和数组 二维区域和检索 - 矩阵不可变题目描述前缀和代码演示 一维数组前缀和 二维区域和检索 - 矩阵不可变 难度 - 中等 原题链接 - 二维区域和检索 - 矩阵不可变 题目描述 给定一个二维矩阵 matrix,以下类型的多个请求: 计算其子矩形范围内元素的总…

电脑录屏软件哪个好用又免费

在学习工作中或者生活中,经常会遇到需要录屏的情况,那么有哪些好用的录屏软件呢?今天就给大家分享3个好用的电脑录屏软件,有多种录屏模式可选,高清视频随便录制! 1、Win10自带的录屏工具 Win10/Win11系统…

深入理解CountDownLatch

CountDownLatch是一个同步协助类,通常用于一个或多个线程等待,直到其他线程完成某项工作。 CountDownLatch使用一个计数值进行初始化,调用它提供的await()方法的线程会被阻塞直到该计数值减为0。减计数值的方法是countDown(),该方…

OS 多进程图像

schedule()函数为切换进程函数,pCur.state被置为阻塞态,放入磁盘等待队列 pCur和pNew都为对应pcb(为了使参与并发执行的每个程序,包含数据都能独立地运行,在操作系统中必须为之配置一个专门的数据结构,称为…

分布式核心知识

文章目录 前言一、分布式中的远程调用1.1RESTful接口1.2RPC协议1.3区别与联系 二、分布式中的CAP原理 前言 关于分布式核心知识详解 一、分布式中的远程调用 在微服务架构中,通常存在多个服务之间的远程调用的需求。远程调用通常包含两个部分:序列化和通…

【日常记录】win10打印机打印不出来,打印队列里有文档无法删除

Q1:win10打印机打印不出来,打印队列里有文档无法删除 可能原因一:打印机队列有文档卡住了,删除掉就好 打开打印机队列,开始 → 设置 → 设备 → 打印机和扫描仪 → 打开打印机队列 → 暂停并取消队列里所有文档 → 点…

unity开发笔记#230821-手搓一个虚拟摇杆

做unity游戏时,如果是做手机端则需要加一个虚拟摇杆以便玩家控制角色移动(做pc端则直接获取键值即可较方便)。原理就是用Image制作一个大圆圈住一个Image小圆,玩家拖拽小圆控制角色移动。中心思想是,以小圆中心为(0,0)…

C++day1(笔记整理)

一、Xmind整理&#xff1a; 二、上课笔记整理&#xff1a; 1.第一个c程序&#xff1a;hello world #include <iostream> //#:预处理标识符 //<iostream>:输入输出流类所在的头文件 //istream:输入流类 //ostream:输出流类using namespace std; //std&#x…

*args无疑是解决函数重载的一大创新利器--我用可变数量参数解决了函数重载问题

需求分析 最近遇到这样一个需求&#xff1a;根据用户传递的不同参数数量执行不同的功能。我这几天一直在思考这个问题&#xff1a;如何根据参数数量去执行不同的功能&#xff0c;最初的设想是把不需要的参数设置为NONE或者""再或者" "(后两者引号均表示传空…

Go:测试框架GoConvey 简介

快速开始 GoConvey是一个完全兼容官方Go Test的测试框架&#xff0c;一般来说这种第三方库都比官方的功能要强大、更加易于使用、开发效率更高&#xff0c;闲话少说&#xff0c;先看一个example&#xff1a; package utils import (. "github.com/smartystreets/goconvey…

怎么查看小程序中的会员信息

商家通过查看会员信息&#xff0c;可以更好地了解用户&#xff0c;并为他们提供更个性化的服务和推荐。接下来&#xff0c;就将介绍如何查看会员信息。 商家在管理员后台->会员管理处&#xff0c;可以查看到会员列表。支持搜索会员的卡号、手机号和等级。还支持批量删除会员…

Java原子类

是什么 对多线程访问同一个变量&#xff0c;为了保证线程安全需要加锁&#xff0c;而锁是比较消耗性能的。Java从JDK 1.5开始提供了java.util.concurrent.atomic包&#xff0c;这个包中的原子操作类提供了一种用法简单、性能高效、线程安全地更新一个变量的方式。 jdk1.8新增…