👻
security
  • 计算机技术
  • OWASP TOP 10
  • 名词解释
  • 1
    • 常见端口利用
    • F5 big-ip从环境搭建到漏洞复现
    • 红队资源
  • About
    • APT
      • 海莲花(APT-C-00)
        • 样本分析
      • 毒云藤(APT-C-01)
        • 大规模钓鱼攻击活动披露
        • 2020上半年针对我重要机构定向攻击活动揭秘
      • 响尾蛇(T-APT-04)
        • 利用WebSocket隧道的新型攻击活动披露
      • 蔓灵花(APT-C-08)
        • 移动平台攻击活动揭露
      • 蓝宝菇(APT-C-12)
        • 组织使用云存储技术发起的最新攻击活动披露
      • 双尾蝎组织(APT-C-23)
        • 针对中东地区的最新攻击活动
      • Lazarus(APT-C-26)
        • 暴风行动 -利用MATA框架针对数字货币行业的攻击活动揭秘
      • Fancy Bear(APT-C-28)
        • 携小众压缩包诱饵对北约、中亚目标的定向攻击分析
      • 肚脑虫组织(APT-C-35)
        • 使用升级版数字武器针对周边地区的攻击活动
        • 针对巴基斯坦的攻击活动
      • 拍拍熊(APT-C-37)
      • 军刀狮(APT-C-38)
      • 蓝色魔眼(APT-C-41)
        • 组织首次针对我国重要机构定向攻击活动披露
      • 美人鱼(Infy)
        • 使用最新的Foudre后门进行攻击活动的分析
    • 各类靶场讲解
      • sqli-labs
      • upload-labs
      • xss-labs
    • CISP题库
    • Docker
      • Docker基线
        • docker基线-概述
        • 推荐一
        • 推荐二
        • 推荐三
        • 推荐四
        • 推荐五
        • 推荐六
      • 命令与选项
      • 基于Docker的固件模拟
      • 固件相关
      • Docker 私有仓库搭建
      • 基础命令的背后
      • 渗透思路调研
      • Docker容器环境检测方法【代码】
    • 浏览器
    • markdown
    • 密码学
    • 内网渗透TIPS
    • 网络扫描
    • 正则表达式
  • 操作系统
    • Android
      • APK终端安全分析法
      • 应用审计指南
        • 通用审计方法
    • IOS
      • 应用审计指南
    • Linux
      • 反弹shell
      • 基线检查
      • SHELL编程
      • 实战技能
    • windows
      • BACKDOOR with 权限维持
      • 磁盘取证实验
      • 基线检查
      • 免杀抓取明文
      • payload下载方式
      • powershell
      • 日志分析
        • 分析工具
      • Untitled
  • 数据库
    • db2
    • mysql
      • webshell写入
      • 基础知识
      • 核心技术
      • 高级应用
    • oracle
      • webshell写入
    • SQLserver
      • webshell写入
  • 中间件
    • apache
      • 基线检查
      • 日志审计
    • iis
      • 基线检查
      • 7.5解析绕过漏洞
    • nginx
      • 基线检查
    • tomcat
      • 基线检查
  • 编程语言
    • C
    • Java
      • webshell
        • 查杀Java web filter型内存马
        • Filter/Servlet型内存马的扫描抓捕与查杀
        • 基于内存 Webshell 的无文件攻击技术研究
        • 基于tomcat的内存 Webshell 无文件攻击技术
        • Tomcat 内存马检测
      • 代码审计
      • 代码审计指南
      • 浅析Java命令执行
      • 相关框架简介及漏洞
    • PHP
      • 代码审计
      • 破解DVWA-admin密码
      • webshell
        • 常见php一句话webshell解析
        • PHP Webshell Hidden Learning
        • Webshell免杀研究
        • Webshell那些事-攻击篇
        • 过D盾webshell分享
      • 相关框架简介及漏洞
    • python
      • 安全编码规范-代码审计
      • 编码规范
      • fishc
      • 某教程涉及脚本
      • POC编写相关
      • python秘籍
        • 上半部分
        • 下半部分
      • 安全方面的内容
        • Python Opcode逃逸笔记
        • 虚拟机逃逸
      • with-EXCEL
      • 相关框架简介及漏洞
      • 源码剖析
        • 多线程和GIL锁
        • Set容器
        • 统一内存管理
        • 信号处理机制
        • 循环垃圾回收器
        • 字符串对象PyStringObject
        • 整数对象PyIntObject
        • 字节码和虚拟机
    • 汇编
    • Javascript
      • Tampermonkey Script
  • AIGC
    • howtouse
  • 网络
    • CCNA
  • 漏洞类型及讲解
    • 综合
    • 技术分享
      • 暴力破解与信息泄露
      • 信息泄露漏洞_java
      • sqli-with-java
      • python远程命令执行与SSRF
    • SQL-Injectoin
    • Cross-Site Scripting
      • 跨站的艺术-XSS入门与介绍
      • 跨站的艺术-XSS Fuzzing 的技巧
      • 给开发者的终极XSS防护备忘录
      • AngularJS特性的 XSS
    • 文件操作
      • 文件包含
  • how-to-use
    • Acunetix(AWVS)
      • 安装到使用
      • 编写AWVS脚本探测web services
      • 简单分析-web方面
      • 流量分析特征
    • burpsuite
      • 导出报告方式
      • captcha-killer
      • FAKE-IP
      • JSFind
      • 编写插件绕过WAF
    • Cobalt Strike
      • Cobalt Strike Powershell过360+Defender上线
    • FOFA
    • GDB
    • PowerSh
      • 获得Powershell命令的历史记录
      • 深入分析PowerShell的两面性
      • 内网渗透利器之PowerSploit
      • PoC:滥用PowerShell Core
      • 如何绕过PowerShell访问限制并实现PowerShell代码执行
      • 工具包
      • 无powershell运行powershell方法总结
    • sheji
    • sqlmap
      • Atlas修改SQLMap tampers 绕过WAF/IDS/IPS
      • 内核分析
      • 检测剖析
      • tamper
      • UDF
      • --os-shell
      • sqlmapapi
      • with burp
      • 网络特征
    • Matlab
    • Metasploit
      • 与Powershell
    • NESSUS
      • 流量分析特征
      • Untitled
    • Network MapTools
      • 流量特征修改
      • 识别主机指纹
    • waf
      • ngx-lua-waf
      • modsecurity
由 GitBook 提供支持
在本页
  • 简单表达注入
  • orderBy 滤波器旁路
  • 带表达式的 ng-init
  • 通过 constructor.constructor 污染原型
  • ng-click 注射
  • ng-bind-html 不安全绑定
  • 基于注释的注入(旧版 Angular)
  • $eval 或 $watch 注入
  • i18n/本地化占位符
  • 多部分沙盒逃生
  • 摘要:

这有帮助吗?

  1. 漏洞类型及讲解
  2. Cross-Site Scripting

AngularJS特性的 XSS

简单表达注入

{{alert(1)}}

如果使用 AngularJS 的网站在 Angular 模板中错误地包含用户提供的字符串(例如,通过 ng-bind-html 或直接包含在模板中), {{ ... }} 表达式语法可能会导致代码执行。在旧版 AngularJS 中,如果将 {{alert(1)}} 注入表达式上下文,则会触发。

orderBy 滤波器旁路

[1] | orderBy:'x=alert(1)'

一个典型的 AngularJS 沙盒逃逸(1.6 之前),它错误地使用了 orderBy 过滤器。通过提供 'x=alert(1)' 作为排序参数,AngularJS 会对其进行解释,并最终执行 alert(1) 。

带表达式的 ng-init

<div ng-init="x=alert(1)"></div>

ng-init 通常用于在 Angular 作用域中设置初始数据。如果能在 ng-init 属性中注入任意表达式,就可以执行 JavaScript。例如, ng-init="x=alert(1)" 将在编译指令时立即触发警报。

通过 constructor.constructor 污染原型

{{ ({}).toString.constructor('alert(1)')() }}

在旧版 AngularJS 中,表达式可以部分访问 JavaScript 构造函数。通过遍历原型链并调用 constructor.constructor ,攻击者可以实例化新的 Function 并运行任意代码。

ng-click 注射

<button ng-click="alert(1)">Click Me</button>

如果应用程序将用户输入反映到 ng-click 或其他 ng-* 指令属性中,就可以执行 JavaScript。例如,未转义的参数变成 ng-click="alert(1)" 实际上就是 XSS。

ng-bind-html 不安全绑定

<div ng-bind-html="userInput"></div>
<script>
  // userInput is set to: "<img src='x' onerror='alert(1)'/>"
</script>

ng-bind-html 如果没有 Angular 的 $sce (严格上下文转义)或额外的 sanitization,就会呈现未转义的 HTML,包括 标记或事件处理程序。攻击者可以提供恶意 HTML 来运行 JS。

基于注释的注入(旧版 Angular)

在旧版 AngularJS(1.2 之前)中,您可以将表达式放在 HTML 注释中,Angular 仍会对其进行解析:

<!-- {{alert(1)}} -->

Angular 用于解析注释中的表达式。攻击者可以在 HTML 注释中隐藏恶意代码,从而绕过某些天真的内容过滤器。

$eval 或 $watch 注入

$scope.$eval("alert(1)");

如果 AngularJS 应用程序将 $eval 或 $watch 暴露给用户输入,攻击者就可以传递任意表达式进行评估。如果开发人员使用 $eval(userInput) 而未进行消毒,就可能发生这种情况。

i18n/本地化占位符

// If there's an i18n system that merges placeholders into Angular expressions:
"Hello {{user.name}}"

某些基于 Angular 的 i18n 系统或翻译工具会自动将占位符注入模板。如果用户控制的数据填充了占位符,攻击者就可以在翻译中插入 {{alert(1)}} ,从而导致 XSS。

多部分沙盒逃生

{y:''.constructor.prototype}.y.charAt=[].join; [1] | orderBy:'x=alert(1)'

这种多阶段有效载荷首先会更改全局对象或原型,然后使用过滤器(如 orderBy )来突破 Angular 的沙盒。这是 AngularJS 1.x 中较为复杂的已知旁路之一。

摘要:

  1. 模板表达式: {{ ... }} 注入是最常见的。

  2. 过滤器和指令:如果注入用户数据, orderBy 、 ng-init 、 ng-click 等都可能被滥用。

  3. 原型污染:访问 .constructor.constructor 会创建函数。

  4. 过度许可 ng-bind-html : 如果不执行 $sce 则允许直接注入 HTML/JS。

  5. 较旧的 AngularJS 版本:这些有效载荷中有许多是针对较旧的 AngularJS 1.x 版本的,其中存在已知的沙箱逃脱问题,这些问题已在较新版本或现代 "Angular"(v2+)中得到修复。

上一页给开发者的终极XSS防护备忘录下一页文件操作

最后更新于1个月前

这有帮助吗?