• sqlilabs less-32


    less-32

    前期判断

    在这里插入图片描述
    我给id赋值然后啥都没了。在这里插入图片描述
    在源码看到一条代码,注释后就能显示,但是这玩意应该不能注释,后续实验需要使用.

    在这里插入图片描述

    虽然环境出了点大问题不过看到那行代码就想到宽字节注入。

    宽字节注入

    虽然不能做实验但是还是能虚幻实验一下,先来说说原理吧。
    因为GBK需要两个字节编码,而ascii只需要一个字节,所以叫GBK这类叫宽字节。如果两个ascii字节连着一堆,就会被误认为是一个宽字节字符。

    这个实验
    因为代码mysql_query("SET NAMES gbk");,会导致MYSQL部分编码更改为gbk
    在这里插入图片描述
    在这里插入图片描述
    再看看php编码是什么,是UTF-8(在UTF-8中汉字占3到4个字节)。
    在这里插入图片描述
    php会通过这个编码生成sql语句发给MYSQL,MYSQL收到请求时候会将请求内容从character_set_client转换为character_set_connection

    在这里插入图片描述
    然后再把character_set_connection转化为内部操作字符集,使用character_set的值把内部操作字符集转化character_set_results,然后按character_set_results编码输出。

    在这里插入图片描述
    注入点在哪里呢,在character_set_client,因为MYSQL收到php的编码sql后使用了character_set_client又进行一次编码。

    举个例子来理解理解,因为为了避免用户输入一些不必要的数据,对特俗的字符加上反斜杠“\“进行转义,比如当输入英文单引号" ’ "就会被转义为 " \ ’ "。
    假设我们输入英文单引号,然后被过滤转义为反斜杠加英文单引号,就会导致注入失败。如果我们输入大于127的ascii字符加上一个字符,列如%df’.

    • %df‘ %df‘ ’会被转义为\',\ ascii码是 %5c

    • %df%5c’ 因为两个字节中第一个字节的ascii码大于127就会和后面一个字节一起看成汉字。
      -在这里插入图片描述

    • 運’ 经过MYSQL的GBK编码后就变成了这样
      转义的符号“\”被“%df”带着变成了“運”,就绕过了转义。

    所以这次实验应该是-1%df%27union%20select%201,user(),3--+
    在这里插入图片描述

    less-33

    我的less-33标题却是less-32,不出意外还是和less-32的一样,没有反馈。
    在这里插入图片描述
    在这里插入图片描述
    看源码能找到addslashes

    在这里插入图片描述
    在这里插入图片描述
    和less-32同理,用宽字节注入。

    less-34

    这几个都有相同问题,估计还是通过宽字节注入。
    在这里插入图片描述
    在这里插入图片描述

    less-35

    在这里插入图片描述
    看了下源码发现是数字型,转义也就成摆设了。
    在这里插入图片描述

  • 相关阅读:
    学习HashMap源码
    课件演示用什么软件?万兴录演:多种录屏方式任你选
    Docker从认识到实践再到底层原理(五)|Docker镜像
    Unity DropDown 组件 详解
    ruoyi-vue前端数据字典值引用与回显(列表中回显,多选框回显)
    NextJS开发:解决React Hook useEffect has a missing dependency
    @Valid 注解详解 Java Bean Validation的前世今生
    java面试题
    Pigsty:开箱即用的数据库发行版
    LaTeX中文学习教程(耿楠教授15集全)学习笔记
  • 原文地址:https://blog.csdn.net/qq_37370714/article/details/126013267