80,【4】BUUCTF WEB [SUCTF 2018]MultiSQL

53,【3】BUUCTF WEB october 2019 Twice SQLinjection-CSDN博客

上面这个链接是我第一次接触二次注入

这道题也涉及了

对二次注入不熟悉的可以看看

BUUCTF出了点问题,打不开,以下面这两篇wp作为学习对象

[SUCTF 2018]MultiSQL-CSDN博客

[SUCTF 2018]MultiSQL MYSQL 预处理写-CSDN博客

第一篇前面的1到3步做过了,从第4步开始学习

作者所说的越权访问准确来说属于越权访问中的水平越权

所给的条件表达上涉及以下知识

user() 函数

user() 是 SQL 中的一个系统函数,不同数据库系统中该函数的作用可能略有不同,但通常用于返回当前连接数据库的用户名。例如在 MySQL 中,user() 会返回当前登录用户的名称。

mid(str, pos) 函数

mid() 函数用于从字符串中提取子字符串。mid((user()), 1) 表示从 user() 返回的用户名中提取从第 1 个字符开始的子字符串,这里实际上就是取用户名的第一个字符。

ascii() 函数

ascii() 函数用于返回字符串最左边字符的 ASCII 码值。所以 ascii(mid((user()), 1)) 就是获取当前数据库用户名字符串第一个字符的 ASCII 码值。

if(condition, value_if_true, value_if_false) 函数

if() 是一个条件判断函数。if(ascii(mid((user()),1))>0,1,0) 会判断当前数据库用户名字符串第一个字符的 ASCII 码值是否大于 0,如果大于 0 则返回 1,否则返回 0。由于字符的 ASCII 码值通常都是大于 0 的,所以这个表达式一般会返回 1。

注意:布尔盲注常常使用此种表达式

load_file()函数

是 MySQL 数据库中的一个函数,其主要作用是读取服务器文件系统上的文件内容,并将其作为一个字符串返回。该函数通常用于在 SQL 查询中直接获取文件的文本信息。

预处理(预编译语句)

是一种在数据库操作中广泛使用的技术,用于提高数据库操作的安全性和性能。它将 SQL 语句的编译和执行过程分离,先对 SQL 语句进行预编译,然后再将用户输入的数据绑定到预编译的语句中执行。通过预处理可以绕过转义单引号

剩下的代码与payload去博主的博客里看吧,比较简单

第二篇博主用了堆叠注入,确实,像select等关键字被过滤后的第一想法就应该是堆叠

并且采用了char拼接绕过,char也很常用

(本来想粘一篇我做过的堆叠注入的题,但实在写的差劲,自行搜索学习吧)

最后也可成功执行,绕过

笔记

很像学习SQL时那块知识的复习,不过也有新知识

相关推荐
碎叶城李白42 分钟前
若依学习笔记1-validated
java·笔记·学习·validated
im_AMBER1 小时前
学习日志05 python
python·学习
真的想上岸啊2 小时前
学习C++、QT---18(C++ 记事本项目的stylesheet)
开发语言·c++·学习
HuashuiMu花水木3 小时前
PyTorch笔记1----------Tensor(张量):基本概念、创建、属性、算数运算
人工智能·pytorch·笔记
rui锐rui3 小时前
大数据学习2:HIve
大数据·hive·学习
凛铄linshuo4 小时前
爬虫简单实操2——以贴吧为例爬取“某吧”前10页的网页代码
爬虫·python·学习
大春儿的试验田4 小时前
高并发收藏功能设计:Redis异步同步与定时补偿机制详解
java·数据库·redis·学习·缓存
笑衬人心。5 小时前
Ubuntu 22.04 修改默认 Python 版本为 Python3 笔记
笔记·python·ubuntu
金色光环5 小时前
【Modbus学习笔记】stm32实现Modbus
笔记·stm32·学习
THMOM916 小时前
TinyWebserver学习(9)-HTTP
网络协议·学习·http