sqlilabs less-32

sqlilabs less-32

  • less-32
    • 前期判断
    • 宽字节注入

less-32

前期判断

sqlilabs less-32_第1张图片
我给id赋值然后啥都没了。sqlilabs less-32_第2张图片
在源码看到一条代码,注释后就能显示,但是这玩意应该不能注释,后续实验需要使用.

sqlilabs less-32_第3张图片

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

宽字节注入

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

这个实验
因为代码mysql_query("SET NAMES gbk");,会导致MYSQL部分编码更改为gbk
sqlilabs less-32_第4张图片
sqlilabs less-32_第5张图片
再看看php编码是什么,是UTF-8(在UTF-8中汉字占3到4个字节)。
sqlilabs less-32_第6张图片
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就会和后面一个字节一起看成汉字。
    -sqlilabs less-32_第7张图片

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

所以这次实验应该是-1%df%27union%20select%201,user(),3--+
sqlilabs less-32_第8张图片

你可能感兴趣的:(sqli-labs,mysql,php,数据库)