web网络安全:跨站脚本攻击(XSS)
跨站脚本攻击(XSS)概述
跨站脚本攻击(XSS,Cross-Site Scripting) 是一种常见的 Web 安全漏洞,攻击者通过向受信任的网站注入恶意脚本(通常是 JavaScript),诱使其他用户在浏览时执行这些恶意代码。XSS 攻击可能导致窃取用户的敏感信息、冒充用户行为、篡改网页内容,甚至执行恶意操作如传播恶意软件。
XSS 的类型
XSS 攻击通常可以分为以下几种类型:
1. 存储型 XSS(Stored XSS)
存储型 XSS 是最危险的一种类型,攻击者将恶意脚本存储在服务器端,其他用户访问该页面时,恶意脚本会在他们的浏览器中执行。
示例:
-
攻击者在留言板或评论区插入恶意脚本:
<script>alert('Your account is hacked!');</script> -
攻击者提交的恶意脚本被服务器存储在数据库中。
-
当其他用户查看该留言时,恶意脚本从数据库中读取并执行,可能导致用户弹出警告框,或进行其他操作。
危害:
- 恶意脚本长期存储在服务器中,可能影响大量用户,给网站带来严重的安全隐患。
- 攻击者可以在用户不知情的情况下窃取其身份信息或执行敏感操作。
2. 反射型 XSS(Reflected XSS)
反射型 XSS 攻击通过 URL 参数将恶意脚本发送到服务器,服务器返回并在页面中直接反射该脚本,最终在用户浏览器中执行。
示例:
-
攻击者构造恶意链接,包含一个恶意脚本:
https://example.com/search?q=<script>alert('XSS!');</script> -
用户点击链接后,服务器将
q参数的值直接嵌入页面响应中:<h1>Search Results for: <script>alert('XSS!');</script></h1> -
用户浏览器执行该脚本,触发弹窗。
危害:
- 该攻击通常在特定情况下(如用户点击恶意链接时)触发,攻击者可以通过邮件、社交网络等渠道诱使用户点击。
- 恶意脚本执行的后果通常为窃取用户信息或恶意重定向。
3. DOM 型 XSS(DOM-based XSS)
DOM 型 XSS 攻击不依赖于服务器返回的数据,而是直接通过客户端的 JavaScript 操作页面的 DOM(文档对象模型)。攻击者利用前端 JavaScript 代码中未充分处理用户输入的部分来注入恶意脚本。
示例:
-
攻击者构造一个恶意链接,包含恶意脚本:
https://example.com/page#<script>alert('XSS!');</script> -
页面中的 JavaScript 代码直接从 URL 哈希部分读取内容,并将其插入到 DOM 中:
javascript复制编辑 document.body.innerHTML = location.hash.substring(1); -
恶意脚本被注入页面并执行。
危害:
- DOM 型 XSS 攻击依赖客户端 JavaScript 逻辑,如果前端没有对 URL 参数进行适当清理,攻击者可以利用这一点进行攻击。
- 该攻击不依赖服务器,因此有时比反射型 XSS 更难检测和防范。
XSS 的危害
XSS 攻击可能造成以下几方面的危害:
- 窃取用户敏感信息:
- 恶意脚本可以窃取用户的 Cookie、会话令牌、输入的数据等敏感信息。
- 通过执行脚本,攻击者可以获取到用户的身份认证信息,进行账户劫持。
- 冒充用户行为:
- 攻击者可以利用 XSS 执行用户操作,伪造用户行为。例如,发送消息、转账、修改账户信息等,造成经济损失。
- 伪造页面内容:
- 攻击者可以修改页面的内容,显示虚假的信息,例如篡改银行账户余额、伪造订单详情等,欺骗用户进行进一步的操作。
- 传播恶意软件:
- 恶意脚本可以强制用户下载恶意软件,或将用户重定向到钓鱼网站,进一步感染用户设备或窃取个人信息。
防御 XSS 攻击的方法
1. 输入验证和清理
对用户输入的数据进行严格的验证和清理,防止恶意代码的注入。拒绝包含 HTML 元素、JavaScript 代码或特殊字符的非法输入。
示例:
- 使用专门的库进行数据转义(如
DOMPurify、html.escape)。 - 对用户输入的字符如
<,>,&,",'等进行转义。
let safeInput = DOMPurify.sanitize(userInput);
2. 输出转义
在将用户输入的内容输出到页面时,进行适当的转义处理,防止用户输入的代码被执行。确保对 HTML、JavaScript、CSS 和 URL 等输出进行转义。
示例:
-
对 HTML 输出进行转义:
<h1>Search Results for: {{ user_input | escape }}</h1> -
使用模板引擎时,使用自动转义功能,避免直接插入用户输入的内容。
3. 使用内容安全策略(CSP)
内容安全策略(CSP)是一种通过 HTTP 头部限制网页加载资源(如 JavaScript)的机制。通过配置 CSP,可以防止恶意脚本的加载,减少 XSS 攻击的风险。
示例:
-
设置 CSP 头部,限制脚本来源:
Content-Security-Policy: script-src 'self' https://trusted-scripts.example.com; -
限制不受信任的脚本执行,从而避免执行外部的恶意脚本。
4. 避免直接使用用户输入
尽量避免将用户输入直接插入到 HTML、JavaScript、CSS 等代码中。尤其是动态构建页面时,应该使用 DOM 操作来生成内容,而不是直接使用 innerHTML。
示例:
-
使用
textContent或setAttribute()来插入内容,而不是innerHTML:let elem = document.createElement("div"); elem.textContent = userInput; document.body.appendChild(elem);
5. 禁用危险的 HTML 功能
前端代码中避免使用危险的 DOM 操作方式,如 innerHTML、document.write() 等,这些方法允许注入 HTML 或 JavaScript,容易导致 XSS 攻击。
6. Cookie 的安全设置
通过配置 Cookie 的安全属性,防止恶意脚本窃取 Cookie 数据。
-
设置
HttpOnly属性,防止 JavaScript 访问 Cookie:Set-Cookie: sessionid=abc123; HttpOnly; -
设置
SameSite属性,防止跨站请求携带 Cookie:Set-Cookie: sessionid=abc123; SameSite=Strict;
7. 使用 HTTP Only 和 Secure 属性
通过设置 Cookie 的 HttpOnly 和 Secure 属性,确保 Cookie 只能通过服务器访问,防止恶意 JavaScript 获取敏感 Cookie。
Set-Cookie: sessionid=abc123; HttpOnly; Secure;
其他防护建议
- 定期审计和渗透测试:进行定期的安全审计和渗透测试,发现并修复 XSS 漏洞。可以使用自动化工具如
OWASP ZAP来进行安全扫描。 - 教育开发人员和用户:定期培训开发人员,增强其对 XSS 攻击的防范意识。用户也应了解不要随意点击可疑链接,避免遭遇社交工程攻击。
- 使用现代框架和库:许多现代框架(如 React、Angular、Vue 等)默认实现了 XSS 防护机制,开发时应优先选择这些框架,以减少 XSS 攻击的风险。
相关文章:
web网络安全:跨站脚本攻击(XSS)
跨站脚本攻击(XSS)概述 跨站脚本攻击(XSS,Cross-Site Scripting) 是一种常见的 Web 安全漏洞,攻击者通过向受信任的网站注入恶意脚本(通常是 JavaScript),诱使其他用户在…...
【Python爬虫(44)】分布式爬虫:筑牢安全防线,守护数据之旅
【Python爬虫】专栏简介:本专栏是 Python 爬虫领域的集大成之作,共 100 章节。从 Python 基础语法、爬虫入门知识讲起,深入探讨反爬虫、多线程、分布式等进阶技术。以大量实例为支撑,覆盖网页、图片、音频等各类数据爬取ÿ…...
微信小程序:多菜单栏设计效果
一、实现效果 二、代码 wxml 编辑前端界面,步骤 菜单逻辑: 逐步取出数组中的项,首先取出顶部菜单项,然后选中后取出选中的底部数据(左侧菜单+右侧内容),然后点击左侧菜单取出选中的左侧菜单对应的右侧内容 ①这里我的数据是全部封装到一个数组对象的,首先我的循环…...
海康威视摄像头ISUP(原EHOME协议) 摄像头实时预览springboot 版本java实现,并可以在浏览器vue前端播放(附带源码)
1.首先说了一下为什么要用ISUP协议来取流 ISUP主要就是用来解决摄像头没有公网ip的情况,如果摄像头或者所在局域网的路由器有公网ip的话,其实采用rtsp直接取流是最方便也是性能最好的,但是项目的摄像头没有公网IP所以被迫使用ISUP,ISUP是海康…...
蓝桥杯之阶段考核
📖 Day 7:阶段考核 - 蓝桥杯官方模拟赛(限时 4 小时) 📖 一、如何高效完成模拟赛? 模拟赛是一种接近真实竞赛的训练方式。要高效完成模拟赛,需要掌握以下策略: 1. 赛前准备 ✅ 环…...
Python爬虫基础重要数据类型
重要数据类型 列表数据类型 在实际开发中,经常需要将一组(不只一个)数据存储起来,以便后边的代码使用。列表就是这样的一个数据结构。且列表是Python中最基本也是最常用的数据结构之一。什么是数据结构呢?通俗来讲&a…...
乐享数科:供应链金融—三个不同阶段的融资模式
供应链金融是与产业链紧密结合的融资模式,它主要体现在订单采购、存货保管、销售回款这三个不同的业务阶段,并针对这些阶段提供了相应的金融服务。以下是这三个阶段中主要的融资模式及其特点: 供应链金融融资模式主要分为以下几种࿱…...
【AI】openEuler 22.03 LTS SP4安装 docker NVIDIA Container Toolkit
NVIDIA Container Toolkit 打开网址 Unsupported distribution or misconfigured repository settings | NVIDIA Container Toolkit 为方便离线安装,先下载过来 wget https://nvidia.github.io/libnvidia-container/stable/rpm/nvidia-container-toolkit.repo mk…...
【2025全网首发B站教程】YOLOv12训练数据集构建:标签格式转换-划分-YAML 配置 避坑指南 | 小白也能轻松玩转目标检测!
【2025全站首发】YOLOv12训练数据集构建:标签格式转换-划分-YAML 配置 避坑指南 | 小白也能轻松玩转目标检测! 文章目录 1. 数据集准备1.1 标签格式转换1.2 数据集划分1.3 yaml配置文件创建 2. 训练验证 1. 数据集准备 示例数据集下载链接:P…...
设计模式教程:中介者模式(Mediator Pattern)
中介者模式是一种行为型设计模式,它用于减少对象之间的直接依赖关系。通过引入一个中介者对象,所有对象的交互都通过中介者进行,而不是直接相互通信。这种模式的主要目的是减少对象之间的耦合,提升系统的灵活性和可维护性。 1. 定…...
编写dockercompose脚本,管理redis,activemq,mysql5.7
编写dockercompose脚本,管理redis,activemq,mysql5.7,mysql的root密码设置Duke2007,redis密码设置duke0591 Docker Compose 多服务编排脚本(安全增强版) yaml 复制 services: # # MySQL 5.7 服务配置 #…...
【编程语言】委托与函数指针
委托与函数指针的相似之处: 指向方法:C# 的委托和 C 的函数指针都可以用来指向一个方法或函数。调用方法:它们都可以通过引用(委托或函数指针)来调用指向的方法。 委托与函数指针的主要区别: 类型安全&am…...
基于vue和微信小程序的校园自助打印系统(springboot论文源码调试讲解)
第3章 系统设计 3.1系统功能结构设计 本系统的结构分为管理员和用户、店长。本系统的功能结构图如下图3.1所示: 图3.1系统功能结构图 3.2数据库设计 本系统为小程序类的预约平台,所以对信息的安全和稳定要求非常高。为了解决本问题,采用前端…...
数字后端实现之Innovus中open net原因解析及解决方案
数字IC后端设计实现Innovus中我们经常会碰到如下的WARNING警告信息。这个log是在route或ECO Route阶段报的。这个WARNING必须要看,因为这里是报告当前设计存在open的net,即某些pin只有逻辑连接,而没有实际的物理连接。 这里正常工具应该报ERR…...
MATLAB基础学习相关知识
MATLAB安装参考:抖音-记录美好生活 MATLAB基础知识学习参考:【1小时Matlab速成教程-哔哩哔哩】 https://b23.tv/CnvHtO3 第1部分:变量定义和基本运算 生成矩阵: % 生成矩阵% 直接法% ,表示行 ;表示列 a [1,2,3;4,5,6;7,8,9];%…...
Mac系统下使用Docker快速部署MaxKB:打造本地知识库问答系统
随着大语言模型的广泛应用,知识库问答系统逐渐成为提升工作效率和个人学习的有力工具。MaxKB是一款基于LLM(Large Language Model)大语言模型的知识库问答系统,支持多模型对接、文档上传和自动爬取等功能。本文将详细介绍如何在Ma…...
RT-Thread+STM32L475VET6——icm20608传感器
文章目录 前言一、板载资源二、具体步骤1.打开CubeMX进行配置1.1 使用外部高速时钟,并修改时钟树1.2 打开I2C3,参数默认即可(I2C根据自己需求调整)1.3 打开串口1.4 生成工程 2. 添加icm20608软件包3. 使能传感器,打开动态链接库4.…...
【信息系统项目管理师-案例真题】2022下半年案例分析答案和详解
更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 试题一(24分)【问题1】(6分)【问题2】(10分)【问题3】(8分)试题二(26分)【问题1】(8分)【问题2】(8分)【问题3】(4分)【问题4】(6分)试题三(25分)【问题1】(12分)【问题2】(7分)【问题…...
3D机器视觉工业3D图像格式常见的格式
工业3D图像格式主要用于存储和交换三维模型数据,常见的格式包括: STL (Stereolithography) 用途: 3D打印和快速成型。 特点: 存储三角面片信息,文件较小,但不包含颜色和材质数据。STEP (Standard for the Exchange of Product Data) 用途: CAD数据交换。 特点: 支持几何、拓…...
SkyWalking集成Kafka实现日志异步采集经验总结
SkyWalking日志异步采集架构 【重点知识】 1、【Agent】kafka-reporter-plugin-x.x.x.jar包放plugins目录后必走kafka(kafka没有正确配置就会报错) 2、【Agent】异步如不开启数据压缩,日志数据较大,pod多、业务大时容易造成网络…...
给TOY计算机加点‘料’:用Python为教学CPU设计新指令(比如乘法、跳转)
给TOY计算机加点‘料’:用Python为教学CPU设计新指令 在计算机科学教育中,TOY计算机是一个经典的教学模型,它简化了真实CPU的复杂性,让学生能够更容易理解计算机体系结构的基本原理。但正是这种简化,也让许多学习者感到…...
技术日报|金融终端FinceptTerminal夺冠,WiFi信号实时人体姿态估计工具RuView亮相榜单
🌟 TrendForge 每日精选 - 发现最具潜力的开源项目 📊 今日共收录 10 个热门项目🌐 智能中文翻译版 - 项目描述已自动翻译,便于理解🏆 今日最热项目 Top 10 🥇 Fincept-Corporation/FinceptTerminal 项目简…...
Python基础-[面试]-救急知识速背
基础语法(15题)【基础语法】 问题:Python代码块是通过什么方式划分的? 答案:通过缩进(通常4个空格)划分代码块。【基础语法】 问题:Python中单行注释使用什么符号? 答案&…...
涨薪技术|Prometheus监控之核心组件简介
各位伙伴,大家好! Prometheus监控对于开发运维工程师来说并不陌生,但是对于测试工程师来说可能还是比较陌生吧!最近也很多小伙伴私信我问prometheus相关问题,所以接下来我会通过连载的方式分享一些关于prometheus如何使用的实践教程。 今天分享:Prometheus的六大核心组件…...
BEV:典型BEV算法总结
核心差异: 1. 视角转换 1)显示视角转换:FastBEV(IPM),BEVDepth(LSS); 2)隐式视角转换:DETR3D(query-based单参考点采样)&a…...
海思3516a OSD水印进阶:动态更新、多区域叠加与性能优化心得
海思3516a OSD水印进阶:动态更新、多区域叠加与性能优化实战 在嵌入式视频处理领域,OSD(On-Screen Display)水印功能早已超越简单的静态文字叠加,成为智能设备中不可或缺的信息交互层。当我们面对安防摄像头需要实时更…...
从‘换脸’到‘换物’:手把手用Attention-GAN实现图片局部精准转换(避坑指南)
从‘换脸’到‘换物’:手把手用Attention-GAN实现图片局部精准转换(避坑指南) 在数字图像处理领域,生成对抗网络(GAN)技术已经从早期的整体风格迁移发展到如今的局部精准编辑。想象这样一个场景:…...
kubectl-debug性能优化:如何配置资源限制和启动参数
kubectl-debug性能优化:如何配置资源限制和启动参数 【免费下载链接】kubectl-debug This repository is no longer maintained, please checkout https://github.com/JamesTGrant/kubectl-debug. 项目地址: https://gitcode.com/gh_mirrors/ku/kubectl-debug …...
SketchUp选择工具全解析:从点选到反选,6种技巧提升建模效率
SketchUp选择工具全解析:从点选到反选,6种技巧提升建模效率 在三维建模的世界里,精确选择是高效创作的基石。就像雕塑家需要精准控制每一处凿刻的力度和位置,SketchUp用户也必须掌握选择工具的精髓。许多中级用户虽然能完成基础建…...
STM32项目实战:用FATFS文件系统给SD卡存点‘小秘密’(附完整代码)
STM32项目实战:用FATFS文件系统给SD卡存点‘小秘密’(附完整代码) 记得第一次用STM32读写SD卡时,那种把传感器数据永久保存下来的成就感,简直比发现新大陆还兴奋。今天我们就来做个有趣的小项目——用FATFS文件系统在S…...
