一、Mysql UTF-8编码
搭建环境
创建一个.php文件
<?php
$mysqli = new mysqli("localhost", "root", "123456", "security");
/* check connection */
if ($mysqli->connect_errno) {
printf("Connect failed: %s\n", $mysqli->connect_error);
exit();
}
$mysqli->query("set names utf8");
username = addslashes(_GET['username']);
if ($username === 'admin') {
die('Permission denied!');
}
/* Select queries return a resultset */
sql = "SELECT \* FROM \`table1\` WHERE username='{username}'";
if ($result = $mysqli->query( $sql )) {
printf("Select returned %d rows.\n", $result->num_rows);
while ($row = $result->fetch_array(MYSQLI_ASSOC))
{
var_dump($row);
}
/* free result set */
$result->close();
} else {
var_dump($mysqli->error);
}
$mysqli->close();
在数据库中创建一张表
data:image/s3,"s3://crabby-images/c79c4/c79c4cc148edd7daca1c1c6ec3fb93da08e7bd71" alt=""
data:image/s3,"s3://crabby-images/1a3f8/1a3f85a4ab00f860f22fd05abbbb56ac9e4e1400" alt=""
表中插入数据
data:image/s3,"s3://crabby-images/97aa7/97aa7e07b3910703dbae4acb9336a0bc83ded252" alt=""
data:image/s3,"s3://crabby-images/396ff/396ff65186b8548c4054cc93e670a8eacbcc8cfc" alt=""
这样环境就搭好了, 然后访问网页
data:image/s3,"s3://crabby-images/96018/96018f57821cee378e68d5191c78463d796a377c" alt=""
当username=admin时就会被拒绝,但是当username≠admin时,又查询不了数据库
data:image/s3,"s3://crabby-images/146f5/146f53c01fea16fbc5f52aabb4415f9d1ca77d5d" alt=""
data:image/s3,"s3://crabby-images/5d6ea/5d6ea2e0d5c20d0f663bbb6dfc3255f38341429e" alt=""
所以要想查询到数据库,就必须让username=admin,但是username=admin又会被拒绝,所以我们需要传递一个admin并带有字符的,让程序认为他不是admin,但是又可以让MySQL把那个字符放弃删除。
data:image/s3,"s3://crabby-images/b1afa/b1afaa47eeeee9a67cc8a9d7e2be0dfe9e48e8aa" alt=""
经过尝试发现%c2可以绕过,但是为什么呢?
这是因为%c2是一个特殊字符,MySQL在转换字符集的过程为,utf-8---->utf-8--->latin 1,但是在这个案例中实际上是utf-8---->utf-8--->utf-8,而latin 1只支持英文,因此在转换的过程中就抛出了错误,导致查出了username=admin的结果。
二、无字母数字webshell
首先在Ubuntu下的/usr/local/nginx/html中,创建一个web.php
data:image/s3,"s3://crabby-images/ed628/ed628ce19e1f0a9fa0a44a9f9f1264bd200617cf" alt=""
访问网页
data:image/s3,"s3://crabby-images/d849d/d849defac9274425c2c432e538cd74148e0a540f" alt=""
然后下一个上传文件的html文件
data:image/s3,"s3://crabby-images/0c602/0c6026262eeb8ee41bd27b75d6a37fe7befd3410" alt=""
data:image/s3,"s3://crabby-images/78c6d/78c6d7a233cbe0e9a64e0a13f041023a62a56a20" alt=""
最后随便创建一个txt文件,编写内容
data:image/s3,"s3://crabby-images/899ae/899ae9090137f2ba9ce6dccc3eac8fea8cd94ac5" alt=""
现在,使用burp suite进行抓包
data:image/s3,"s3://crabby-images/2ccfe/2ccfe54983234697e753ed6b8092462b4278e4b8" alt=""
data:image/s3,"s3://crabby-images/b5d12/b5d128f0cbcece2e66d5f2227dbf964c7e8cbf2b" alt=""
发送到repeater下边
data:image/s3,"s3://crabby-images/1d18f/1d18f02a6057d53e079b06c251a685cafb1e80be" alt=""
data:image/s3,"s3://crabby-images/660b4/660b473c6fcc9c07d4a7d95fe8c9de191a4df037" alt=""
然后将红框内的数据放到web.php下
data:image/s3,"s3://crabby-images/f3a4c/f3a4c4892a5d8f6b7836002f269f857b2bf07d5b" alt=""
data:image/s3,"s3://crabby-images/84329/843298500afe9f283dcb52dfcb04a2f555953de2" alt=""
这里改为POST
data:image/s3,"s3://crabby-images/2bb0d/2bb0d47ef90a5c71ac3438e7c6cc64c0aede9d96" alt=""
然后就可以写get传参
data:image/s3,"s3://crabby-images/7dcfd/7dcfddb75de6b8dc70d89902a14c7ebe6548c4a1" alt=""
但是 由于这里是get传参,要遵循url编码,所以要将空格,问号, @,分号进行转换
data:image/s3,"s3://crabby-images/fc5da/fc5da95971b8a1e6dabdfb1c4f544c0e9858344b" alt=""
提交
data:image/s3,"s3://crabby-images/c30fe/c30fe223de4886ab18733487f4939d7f6acf7238" alt=""
在Linux下的/tmp中可以看到生成了一个临时文件
data:image/s3,"s3://crabby-images/35f72/35f7297fe5673459d5d2ded1d754f657f1b6eecc" alt=""
为进一步验证,可以在web.php下添加sleep,然后再次提交
data:image/s3,"s3://crabby-images/5d0ad/5d0ad43c5be230577813ad5981e88e742448cbb1" alt=""
然后再去查看这个临时文件是否存在
data:image/s3,"s3://crabby-images/d3775/d37756c312ef82fd3da690511c4679d499ecf3ad" alt=""