9、DVWA——XSS(Stored)

文章目录

  • 一、存储型XSS概述
  • 二、low
    • [2.1 源码分析](#2.1 源码分析)
    • [2.2 通关分析](#2.2 通关分析)
  • 三、medium
    • [3.1 源码分析](#3.1 源码分析)
    • [3.2 通关思路](#3.2 通关思路)
  • 四、high
    • [4.1 源码分析](#4.1 源码分析)
    • [4.2 通关思路](#4.2 通关思路)

一、存储型XSS概述

XSS,全称Cross Site Scripting,即跨站脚本攻击,某种意义上也是一种注入攻击,是指攻击者在页面中注入恶意的脚本代码,当受害者访问该页面时,恶意代码会在其浏览器上执行

需要强调的是,XSS不仅仅限于JavaScript,还包括flash等其它脚本语言。

根据恶意代码是否存储在服务器中,XSS可以分为存储型XSS与反射型XSS。DOM型的XSS由于其特殊性,常常被分为第三种,这是一种基于DOM树的XSS。例如:服务器端经常使用document.boby.innerHtml等函数动态生成html页面,如果这些函数在引用某些变量时没有进行过滤或检查,就会产生DOM型的XSS。DOM型XSS可能是存储型,也有可能是反射型。

二、low

2.1 源码分析

php 复制代码
<?php

if( isset( $_POST[ 'btnSign' ] ) ) {
    // Get input
    $message = trim( $_POST[ 'mtxMessage' ] );
    $name    = trim( $_POST[ 'txtName' ] );

    // Sanitize message input
    $message = stripslashes( $message );
    $message = mysql_real_escape_string( $message );

    // Sanitize name input
    $name = mysql_real_escape_string( $name );

    // Update database
    $query  = "INSERT INTO guestbook ( comment, name ) VALUES ( '$message', '$name' );";
    $result = mysql_query( $query ) or die( '<pre>' . mysql_error() . '</pre>' );

    //mysql_close();
}

?> 

分析:

  • stripslashes()删除字符串中的反斜杠;
  • mysql_real_escape_string()转义SQL语句中使用的字符串中的特殊字符
  • 可见服务端并没有对XSS进行过滤。

2.2 通关分析

既然没有过滤,payload:<script>alert("XSS")</script>


三、medium

3.1 源码分析

php 复制代码
<?php

if( isset( $_POST[ 'btnSign' ] ) ) {
    // Get input
    $message = trim( $_POST[ 'mtxMessage' ] );
    $name    = trim( $_POST[ 'txtName' ] );

    // Sanitize message input
    $message = strip_tags( addslashes( $message ) );
    $message = mysql_real_escape_string( $message );
    $message = htmlspecialchars( $message );

    // Sanitize name input
    $name = str_replace( '<script>', '', $name );
    $name = mysql_real_escape_string( $name );

    // Update database
    $query  = "INSERT INTO guestbook ( comment, name ) VALUES ( '$message', '$name' );";
    $result = mysql_query( $query ) or die( '<pre>' . mysql_error() . '</pre>' );

    //mysql_close();
}

?> 

分析:

  • trim():移除特殊字符,默认移除:"\0"(NULL)"\t"(制表符)"\n"(换行)"\x0B"(垂直制表符)"\r"(回车)" "(空格)
  • addslashes():转义双引号;
  • strip_tags():移除html标签;
  • 可见,服务器对message部分过滤慎严格,但是在name参数部分只是做

3.2 通关思路

payload写在name处,payload:<Script>alert("XSS")</script> 。因为name处有字符限制,故抓包修改参数。

四、high

4.1 源码分析

php 复制代码
<?php

if( isset( $_POST[ 'btnSign' ] ) ) {
    // Get input
    $message = trim( $_POST[ 'mtxMessage' ] );
    $name    = trim( $_POST[ 'txtName' ] );

    // Sanitize message input
    $message = strip_tags( addslashes( $message ) );
    $message = mysql_real_escape_string( $message );
    $message = htmlspecialchars( $message );

    // Sanitize name input
    $name = preg_replace( '/<(.*)s(.*)c(.*)r(.*)i(.*)p(.*)t/i', '', $name );
    $name = mysql_real_escape_string( $name );

    // Update database
    $query  = "INSERT INTO guestbook ( comment, name ) VALUES ( '$message', '$name' );";
    $result = mysql_query( $query ) or die( '<pre>' . mysql_error() . '</pre>' );

    //mysql_close();
}

?> 

分析:name参数处只是过滤了script标签,可以使用img标签进行绕过。

4.2 通关思路

payload:<img src=x onerror=alert("111")>

相关推荐
鹅天帝15 小时前
20260407网安学习日志——序列化漏洞
前端·学习·web安全·网络安全·xss
cTz6FE7gA2 天前
XSS、CSRF、SQL注入、防重放与敏感数据保护的分层策略
sql·xss·csrf
188号安全攻城狮2 天前
【前端安全】Trusted Types 全维度技术指南:CSP 原生 DOM XSS 防御终极方案
前端·安全·网络安全·xss
LlNingyu4 天前
什么是SSRF,它最基本的形式是什么(一)
前端·网络·安全·web安全·xss·csrf
admin and root5 天前
XSS之Flash弹窗钓鱼
前端·网络·安全·web安全·渗透测试·xss·src
Mr. G K5 天前
探测XSS漏洞方法
安全·web安全·xss
陈天伟教授6 天前
人工智能应用- 人工智能风险与伦理:01.数据安全
前端·人工智能·安全·xss·csrf
李白你好7 天前
浏览器插件 | 信息收集、统一指纹识别 、DOM XSS 检测 、漏洞报告生成与管理
前端·xss
未知鱼7 天前
Python安全开发之简易Xss检测工具(详细注释)
python·安全·xss
FreeBuf_10 天前
Claude浏览器扩展漏洞允许通过任意网站实现零点击XSS提示注入
前端·网络·xss