码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • xss跨站脚本(cross-site scripting)


    本质上是用户输入 js , html 代码,提交至服务器(可不经过),前端和后端均未对用户的输入和输出进
    行合理的过滤和限制,导致恶意 js 代码以及 html 代码被注入到网页中
    危害:钓鱼欺骗、获取会话、会话劫持、网页蠕虫病毒等;
    即前端代码注入,代码注入类
    代码注入的本质:把用户的输入当作代码执行;
    基本流程
    如何引用 js
    1 、 script 标签
    < script > console . log () < /script>
    2 、 script 标签中的 src 属性
    < script src = "http://a.com/j.js" >< /script>
    3 、事件( on ),(鼠标键盘窗口)
    < input onclick = console . log () >
    < img src = x onerror = console . log () >
    4 、 a 标签 href 属性构造伪协议
    < a href = javascript : console . log () > baidu < /a>
    常见构造标签:
    src = x onerror = alert(1)>
    onload = alert(1)>
    onmouseover = "console.log(5)" >
    href = "javascript:alert(1)" >
    type = text onclick = alert(1)>
    等等
    xss 分类
    1 、反射型
    xss 恶意代码经过服务器但不存储于服务器,一次性
    2 、存储型
    xss 恶意代码经过服务器且存储于服务器(文件,数据库)
    3 、 dom 型(也算反射型的一种)
    xss 恶意代码不经过服务器,无需和服务器交互,发生在客户端处理数据时
    xss 语句及过滤
    1 、无尖括号,可选择用事件触发 js 代码
    2 、无法使用 script 标签及 js 事件的情况下,可选择用 a 标签引入伪协议,例:
    href = "javascript:alert(1)" > random
    3 、某些属性被替换,可选择大小写绕过限制
    例:
    "> hREf = "javascript:alert(1)" > asdf
    用大小写穿插的方式替换 href
    4 、存在过滤属性名、标签名的情况,如果过滤不严谨可尝试双写;
    "> hrhrefef = "javascrscriptipt:alert(1)" > asdf
    5 、可尝试使用实体编码替换 xss 语句中值的部分,
    例:
    href = "javascript:alert(1)" > 友情链接
    可替换 href 后的部分,参数无法替换
    6 、观察页面,有些输入框是隐藏属性
    7 、除了正常的 GET 、 POST 请求外, http 请求头,有时也可以构造 xss
    8 、 ng-include, ①需要指定的是同域名下的图片或文件②搭配事件或其他 js 触发方式
    9 、空格被替换,可选择类似 sql 注入中的替换方法, %0a 、 %0d 、 %09 、 / 等
    10 、反单引号替换括号、中括号
    11 、 img 、 input 等自闭和标签无需闭合,结尾尖括号也可省略,属性后记得加空格
    12 、引入恶意 js 时,可选用邮箱格式,用户名 @ 网址,例: baidu.com@qq.com , 等价于baidu.co 作为用户名去访问qq
    13 、正则不严谨时可使用空格绕过正则
    14 、 svg 标签中可解析实体编码
    15 、标签内增加空白符,不影响标签原有意义
  • 相关阅读:
    微信小程序自定义头部
    MySQL与ES数据同步的四种方案及实践演示
    【 java 面向对象】static关键字的使用
    LeetCode50天刷题计划(Day 10—— 三数之和(20.50-22.40)
    vscode软件的code alignment插件使用
    JVM性能调优的6大步骤,及关键调优参数详解
    quarkus实战之八:profile
    【数据结构】二叉树的顺序存储结构 —— 堆
    【c语言】字符函数和字符串函数(下)
    行为型模式-策略模式
  • 原文地址:https://blog.csdn.net/hakksjss/article/details/137955762
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号