写点什么

HTML 5 通过 sandbox 属性提升 iFrame 的安全性

  • 2010-01-30
  • 本文字数:1422 字

    阅读完需:约 5 分钟

目前 Web Hypertext Application Technology Working Group (WHATWG)正与 W3C 通力合作建立 HTML 5 标准,在过去 3 个月中,该项工作已经进入到了 WHATWG 的“ Last Call ”阶段。在这期间,变化最大的一个特性就是 iframe 元素的 sandbox 属性。sandbox 属性可以防止不信任的 Web 页面执行某些操作。

HTML 5 规范的编辑 Ian Hickson谈到了sandbox 的好处,它可以防止如下操作:

  • 访问父页面的 DOM(从技术角度来说,这是因为相对于父页面 iframe 已经成为不同的源了)
  • 执行脚本
  • 通过脚本嵌入自己的表单或是操纵表单
  • 对 cookie、本地存储或本地 SQL 数据库的读写

HTML 5 的修订历史页面还提到了 sandbox 的其他特性:

  • 禁用插件
  • 禁止其他浏览上下文的导航
  • 禁止弹出窗口和模式对话框

iFrames 因安全问题而臭名昭著,这主要是因为 iFrames 常常被用于嵌入第三方内容,而后者则可能会执行某些恶意操作。sandbox 通过限制被嵌入内容所允许的操作而提升 iFrames 的安全性。这种方式将沙箱内容与父页面进行了分离,因此限制了被嵌入内容的权限。

与 sandbox 一起出来的还有其 MIME 类型:text/html-sandboxed。Hickson 说到:

text/html-sandboxed MIME 类型确保用户不会访问到不可信的内容。它包含两部分内容:首先,如果用户直接访问页面时,浏览器不可以渲染那些具有 text/html-sandboxed MIME 类型的页面。目前所有浏览器都支持这一点,这些浏览器会下载页面的标记但不会渲染页面;其次,支持 sandbox 属性的浏览器需要渲染具有 text/html-sandboxed MIME 类型的 iframes(但会受到 sandbox 属性中所设定的权限限制)目前为止,还没有浏览器实现这一点,Google Chrome 也是如此(它会渲染父页面,但却下载 iframe 内容而非在 iframe 中对其进行渲染)。因此目前还没法使用该项技术,除非 Google 更新 Chrome 以支持这一点(从理论上来说,其他的浏览器厂商在实现了对 sandbox 属性的支持后就会实现该技术,让我们拭目以待吧)。

目前,只有 Google Chrome 4.0 使用了 sandbox,Firefox、IE8 和 Safari 都还没有实现这一点,但相信不久之后这些浏览器都会实现的。围绕着 HTML 5 <video> 元素发生了很多事情,Google 通过 H.264 标准对其进行实现,而其他浏览器则使用了不同的标准或是干脆还没有实现。但这种情况不会发生在这里,因为每个浏览器都可以在内部自由决定如何实现 sandbox。但即便是明天所有的主流浏览器都采用了 sandbox,众多的开发者和内容管理者也不能立刻就使用它,因为还有那么多的遗留浏览器会忽略掉该属性,因此稳妥的办法还是采取常规的安全手段来保护 iFrames。

查看英文原文: The HTML 5 sandbox Attribute Improves iFrame Security

2010-01-30 00:063731
用户头像

发布了 88 篇内容, 共 269.8 次阅读, 收获喜欢 9 次。

关注

评论

发布
暂无评论
发现更多内容

善用Optional,告别NPE

京东科技开发者

重磅发布 | OpenSearch 推出向量检索 GPU 图算法方案并支持 GPU 规格售卖

阿里云大数据AI技术

阿里云 gpu 向量检索 OpenSearch

企业如何建设泛网络业务访问认证能力

芯盾时代

终端安全 iam 统一身份管理平台

车间数字化管理系统(源码+文档+部署+讲解)

深圳亥时科技

光真的变慢了吗?怎么证明?

博文视点Broadview

什么是CANN和Ascend C

zjun

CANN Ascend 人工智能】

首款开发鸿蒙原生应用的AI辅助编程工具正式上线了

最新动态

轻松化解Git合并冲突:实用指南

代码忍者

MySQL存储引擎及索引简介

京东科技开发者

遵义正规等保测评机构有吗?在哪里?

行云管家

网络安全 等保 等保测评 遵义

一文带你了解软件开发行业需要堡垒机的几个情形

行云管家

网络安全 软件开发 信息安全 IT运维

研发数据洞察怎么驱动实际的改进?

思码逸研发效能

DevOps 研发效能 研发度量 研发提效 思码逸

AI英语口语测试APP的开发流程

北京木奇移动技术有限公司

软件外包公司 AI口语测试 AI口语评测

Acunetix v24.12 发布,新增功能概览

sysin

Acunetix

Ascend C的编程模型

zjun

AscendCL cudnn Ascend

2024-12-18:正方形中的最多点数。用go语言,给定一个二维数组 points 和一个字符串 s,其中 points[i] 表示第 i 个点的坐标,s[i] 表示第 i 个点的标签。 如果一个正

福大大架构师每日一题

福大大架构师每日一题

淘宝/天猫商品详情及快递费用API返回值解析

代码忍者

淘宝API接口 淘宝评论API

工厂生产管理的10大痛点!一一解决!

积木链小链

制造业 工厂管理

HTML 5通过sandbox属性提升iFrame的安全性_安全_Abel Avram_InfoQ精选文章