《Web应用漏洞侦测与防御:揭秘鲜为人知的攻击手段和防御技术》——第 2 章 HTML 注入及跨站脚本攻击

简介:

本节书摘来自华章计算机《Web应用漏洞侦测与防御:揭秘鲜为人知的攻击手段和防御技术》一书中的第2章,作者:(美) 希马(Shema, M.)著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。

第 2 章 HTML 注入及跨站脚本攻击

大多数网络攻击都是采用跨站脚本(XSS)攻击。这种攻击在站点之间频繁发生,攻击者只需要了解HTML标签和一些肤浅的JavaScript知识,就能彻底击垮站点。跨站脚本攻击的历史和浏览器的历史一样久远,具体时间可以追溯到JavaScript仍被称为LiveScript之时,当时黑客攻击还被简单地描述为“恶意HTML”。本章中,我们将会探索为什么这种攻击仍然如此难以预防,还会介绍现代浏览器和HTML5规范怎样影响攻击者和防御者之间的较量。
还记得邀请苍蝇到它的客厅做客的蜘蛛吗?还记得帮助蝎子渡河的乌龟吗?这些故事都包含了猎手的天真和猎物的肮脏。Internet充斥着陷阱、阴暗的角落、恶意行为,使得随意地浏览网站成为了一种危险的行为。有些网站即便不存在明显的危险,至少也值得高度怀疑,因为它们对浏览器有潜在的敌意。提供盗版软件、免费色情视频、盗版音乐等内容的网站往往遍布病毒或恶意软件,等待着不安全浏览器对它进行访问。这些站点捕食不知情的访问者不足为怪。
恶意内容并不局限于这些边缘站点,也不会让人一眼就能看出来。它会出现在我们认为安全的网站,人们使用这些网站发送电子邮件、处理个人财务、阅读新闻、参与社交网络等。跨站脚本攻击这种典型的网络攻击是广泛且持续存在的顽疾。多亏反病毒信息和操作系统安全设置,使得大多数人对下载和运行不了解的程序非常警惕,而且在人们的电脑上也有足够的警告及保护来阻止带有病毒的可执行程序。
浏览器一直以JavaScript的形式执行代码,你并不清楚这些代码的具体内容,代码的执行也不需要经过你的同意,而且是发生在防病毒软件或其他电脑防御措施的作用范围之外。来自网站的HTML和JavaScript在其信任的沙盒中执行各类操作。浏览器可以显示你收件箱的下一条消息或者显示你银行账户的当前余额,浏览器甚至可以提取你的密码并发送到位于其他国家的服务器上,或者在后台执行转账。从浏览器的角度,所有这些动作都是正常的业务。
2005年10月,一名用户登录到MySpace并读取了某人的个人资料。浏览器执行了那个页面中的JavaScript代码,自动更新了用户自己的个人资料并声明Samy是他们的英雄。然后一个朋友查看了该用户的个人资料,并且在他自己的个人资料上确认Samy确实是“我的英雄”。然后另一个朋友,虽然他既没有听说过也没有见过Samy,访问了MySpace并添加了相同的声明。这种模式持续进行,并呈现爆炸性增长,时间长达24小时,Samy有了超过一百万的朋友,MySpace因流量问题而崩溃。Samy精心制作了一个跨站脚本(XSS),使用了约4000个字符的文本,引发了针对有数千台服务器的公司的拒绝服务攻击,该公司当时的估值大约5亿美元。这次攻击还使得Samy成为了跨站脚本攻击产生的巨大影响的象征(http: //blogoscoped. com/archive/2005-10-14-n81. html为Samy创建者的访谈录)。
你经常被提示向网站重新认证吗?你使用基于Web的电子邮件吗?你曾经在线查看银行账户吗?发送Twitter吗?加某人为好友吗?这些网站中的每一类操作都有XSS漏洞的实例。
HTML注入攻击的威力并不仅仅是惹恼用户(攻破网站对于网站运营商而言就不光是滋扰了),它还可以用于下载键盘记录程序,该程序可用来获取银行和在线游戏的证书。可用HTML注入来获取浏览器的cookie,从而可以在不知道被攻击者用户名和密码的情况下访问他的账户。HTML注入攻击是针对Web浏览器用户的简单但非常危险的攻击的基础。

相关文章
|
2月前
|
存储 监控 安全
如何在Python Web开发中确保应用的安全性?
如何在Python Web开发中确保应用的安全性?
|
2月前
|
前端开发 JavaScript
探索现代Web应用的微前端架构
【10月更文挑战第40天】在数字时代的浪潮中,Web应用的发展日益复杂多变。微前端架构作为一种新兴的设计理念,正逐步改变着传统的单一前端开发模式。本文将深入探讨微前端的核心概念、实现原理及其在实际项目中的应用,同时通过一个简单的代码示例,揭示如何将一个庞大的前端工程拆分成小而美的模块,进而提升项目的可维护性、可扩展性和开发效率。
|
21天前
|
弹性计算 Java 关系型数据库
Web应用上云经典架构实践教学
Web应用上云经典架构实践教学
Web应用上云经典架构实践教学
|
29天前
|
Kubernetes 安全 Devops
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
63 10
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
|
21天前
|
弹性计算 Java 数据库
Web应用上云经典架构实战
本课程详细介绍了Web应用上云的经典架构实战,涵盖前期准备、配置ALB、创建服务器组和监听、验证ECS公网能力、环境配置(JDK、Maven、Node、Git)、下载并运行若依框架、操作第二台ECS以及验证高可用性。通过具体步骤和命令,帮助学员快速掌握云上部署的全流程。
|
2月前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
50 6
|
2月前
|
前端开发 JavaScript UED
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势,包括样式表优化、DOM操作减少、图像优化等技术,并分析了电商网站的具体案例,强调了技术演进对Web性能的深远影响。
44 5
|
2月前
|
机器学习/深度学习 人工智能 JavaScript
JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景
本文探讨了JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景。JavaScript将注重性能优化、跨平台开发、AI融合及WebAssembly整合;TypeScript则强调与框架整合、强类型检查、前端工程化及WebAssembly的深度结合。两者结合发展,特别是在Vue 3.0中完全采用TypeScript编写,预示着未来的Web开发将更加高效、可靠。
54 4
|
2月前
|
缓存 安全 网络安全
HTTP/2与HTTPS在Web加速中的应用
HTTP/2与HTTPS在Web加速中的应用
|
21天前
|
弹性计算 负载均衡 安全
云端问道-Web应用上云经典架构方案教学
本文介绍了企业业务上云的经典架构设计,涵盖用户业务现状及挑战、阿里云业务托管架构设计、方案选型配置及业务初期低门槛使用等内容。通过详细分析现有架构的问题,提出了高可用、安全、可扩展的解决方案,并提供了按量付费的低成本选项,帮助企业在业务初期顺利上云。
下一篇
开通oss服务