XSS的绕过姿势(三)
本章提及的几种姿势将在dvwa靶场进行演示
存储型XSS的绕过姿势
data:image/s3,"s3://crabby-images/bc4d1/bc4d171feaa53c0eb2076b18c93959f8b941b71e" alt="image-20230416153751520"
URL:
1
| http://localhost:8081/dvwa/vulnerabilities/xss_s/
|
安全等级:Medium
猜测与尝试
存储型,注意到有两个文本框,一个是姓名,一个是评论消息。
可能只对评论信息做了过滤,名字通过前端限制了输入字长,但没做过滤。
尝试修改名字的限制长度,然后在名字的文本框发脚本。
data:image/s3,"s3://crabby-images/17841/17841b9446d99c2d7a96afadb9ae95c8f11d9aed" alt="image-20230416154209736"
改成100,然后痛快地写脚本
data:image/s3,"s3://crabby-images/2aa95/2aa9595bb82927dc57ef1cae2ba3ac484afb56ed" alt="image-20230416154341442"
失败:
data:image/s3,"s3://crabby-images/79463/79463d2e0ea9d2188254d3b8cd11a8feebff9664" alt="image-20230416154409127"
推测可能对script标签做了过滤,老套路,换img
data:image/s3,"s3://crabby-images/433bb/433bb164dcc3f776c3b69d385fc95b727dc7b9db" alt="image-20230416154853881"
data:image/s3,"s3://crabby-images/044d6/044d6a141afcd47851869734303164bc38f1ae97" alt="image-20230416154918355"
成功
尝试以下在评论消息框发同样的脚本
data:image/s3,"s3://crabby-images/a35ff/a35ff9d4cf7b4e2c2563ef6187eae55fde40b674" alt="image-20230416155125217"
data:image/s3,"s3://crabby-images/e7088/e7088e71d8dc5bfaed8460ff8e0b6044c8b82a74" alt="image-20230416155137551"
失败
message直接没了……可能是过滤掉了尖括号
查看源码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
| <?php
if( isset( $_POST[ 'btnSign' ] ) ) { $message = trim( $_POST[ 'mtxMessage' ] ); $name = trim( $_POST[ 'txtName' ] );
$message = strip_tags( addslashes( $message ) ); $message = ((isset($GLOBALS["___mysqli_ston"]) && is_object($GLOBALS["___mysqli_ston"])) ? mysqli_real_escape_string($GLOBALS["___mysqli_ston"], $message ) : ((trigger_error("[MySQLConverterToo] Fix the mysql_escape_string() call! This code does not work.", E_USER_ERROR)) ? "" : "")); $message = htmlspecialchars( $message );
$name = str_replace( '<script>', '', $name ); $name = ((isset($GLOBALS["___mysqli_ston"]) && is_object($GLOBALS["___mysqli_ston"])) ? mysqli_real_escape_string($GLOBALS["___mysqli_ston"], $name ) : ((trigger_error("[MySQLConverterToo] Fix the mysql_escape_string() call! This code does not work.", E_USER_ERROR)) ? "" : ""));
$query = "INSERT INTO guestbook ( comment, name ) VALUES ( '$message', '$name' );"; $result = mysqli_query($GLOBALS["___mysqli_ston"], $query ) or die( '<pre>' . ((is_object($GLOBALS["___mysqli_ston"])) ? mysqli_error($GLOBALS["___mysqli_ston"]) : (($___mysqli_res = mysqli_connect_error()) ? $___mysqli_res : false)) . '</pre>' );
}
?>
|
第8行是对评论消息做过滤,非常全面,无懈可击
第14行对名字做过滤,只替换script标签,老毛病了。实战很难遇到这种代码。
安全等级:high
猜测与尝试
故技重施:
data:image/s3,"s3://crabby-images/3cf0f/3cf0ff97396de5c02ba1b139eff9f4ac20f05f48" alt="image-20230416161212287"
data:image/s3,"s3://crabby-images/ef6ba/ef6ba904f95a76cf163bb51b503cb18ea27c69e4" alt="image-20230416161342846"
成功 img标签真好用。
查看源码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
| <?php
if( isset( $_POST[ 'btnSign' ] ) ) { $message = trim( $_POST[ 'mtxMessage' ] ); $name = trim( $_POST[ 'txtName' ] );
$message = strip_tags( addslashes( $message ) ); $message = ((isset($GLOBALS["___mysqli_ston"]) && is_object($GLOBALS["___mysqli_ston"])) ? mysqli_real_escape_string($GLOBALS["___mysqli_ston"], $message ) : ((trigger_error("[MySQLConverterToo] Fix the mysql_escape_string() call! This code does not work.", E_USER_ERROR)) ? "" : "")); $message = htmlspecialchars( $message );
$name = preg_replace( '/<(.*)s(.*)c(.*)r(.*)i(.*)p(.*)t/i', '', $name ); $name = ((isset($GLOBALS["___mysqli_ston"]) && is_object($GLOBALS["___mysqli_ston"])) ? mysqli_real_escape_string($GLOBALS["___mysqli_ston"], $name ) : ((trigger_error("[MySQLConverterToo] Fix the mysql_escape_string() call! This code does not work.", E_USER_ERROR)) ? "" : ""));
$query = "INSERT INTO guestbook ( comment, name ) VALUES ( '$message', '$name' );"; $result = mysqli_query($GLOBALS["___mysqli_ston"], $query ) or die( '<pre>' . ((is_object($GLOBALS["___mysqli_ston"])) ? mysqli_error($GLOBALS["___mysqli_ston"]) : (($___mysqli_res = mysqli_connect_error()) ? $___mysqli_res : false)) . '</pre>' );
}
?>
|
第15行,还是只过滤了script标签,其他标签没过滤
总结
img比script标签 更好用,但是如果做了addslashes、strip_tags、htmlspecialchars三重过滤 这就有点麻烦了