前端安全问题?XSS和CSRF?

一、XSS(跨站脚本攻击)

🔥 本质

攻击者把恶意 JS 注入到页面里执行

👉 你的网站,被别人"插代码"


🧨 常见类型

1️⃣ 存储型 XSS(最危险)

恶意代码被存进数据库

流程:

  1. 攻击者提交评论:

    <script>alert('被黑了')</script>
  2. 后端存库

  3. 用户打开页面 → 代码执行


2️⃣ 反射型 XSS

恶意代码在 URL 里

复制代码
https://test.com?q=<script>alert(1)</script>

后端直接返回到页面 ⇒ 执行


3️⃣ DOM 型 XSS

前端自己写出来的漏洞(你最容易踩)

复制代码
document.body.innerHTML = location.search

🛡️ 防御方案(重点!!!)

✅ 1. 转义(最核心)

复制代码
<div>{userInput}</div>  // React 自动转义 ✔

避免:

复制代码
<div dangerouslySetInnerHTML={{ __html: html }} />

✅ 2. 使用白名单过滤

常用库:

  • dompurify

    import DOMPurify from 'dompurify'
    DOMPurify.sanitize(html)


✅ 3. CSP(内容安全策略)

HTTP 头:

复制代码
Content-Security-Policy: script-src 'self'

👉 禁止外部脚本执行


复制代码
Set-Cookie: token=xxx; HttpOnly

👉 JS 拿不到 cookie ⇒ 防止被盗


⚠️ 前端高危点(你要特别注意)

  • innerHTML

  • dangerouslySetInnerHTML

  • URL 参数直接渲染

  • 富文本编辑器(最常见)


二、CSRF(跨站请求伪造)

🔥 本质

攻击者诱导用户在已登录状态下发起请求

👉 利用"你的身份"去干坏事


🧨 攻击流程

  1. 用户登录了银行网站(cookie 已存在)

  2. 打开恶意网站

  3. 自动发请求:

👉 浏览器自动带 cookie

👉 银行以为是你操作的


🛡️ 防御方案(重点!!!)

✅ 1. CSRF Token(最有效)

流程:

  1. 服务端生成 token

  2. 前端请求时带上

    axios.post('/api', data, {
    headers: {
    'X-CSRF-Token': token
    }
    })

👉 攻击者拿不到 token ⇒ 无法伪造


✅ 2. SameSite Cookie(现代推荐)

复制代码
Set-Cookie: session=xxx; SameSite=Strict

作用:

说明
Strict 完全禁止跨站
Lax 部分允许(推荐)

✅ 3. 验证 Referer / Origin

后端校验:

复制代码
Origin: https://yourdomain.com

✅ 4. 避免 GET 修改数据

❌ 错误:

复制代码
GET /deleteUser?id=1

✔ 正确:

复制代码
POST /deleteUser

三、XSS vs CSRF 对比(面试高频)

XSS CSRF
本质 注入 JS 伪造请求
攻击对象 用户浏览器 服务器
是否需要登录 ❌ 不一定 ✅ 必须
是否执行 JS
主要防御 转义 / CSP Token / SameSite

四、结合你实际开发(重点建议 🚀)

你做 React / Vue + axios,可以这样落地:

✅ axios 全局加 CSRF

复制代码
axios.interceptors.request.use(config => {
  config.headers['X-CSRF-Token'] = getToken()
  return config
})

✅ 富文本必须过滤

复制代码
DOMPurify.sanitize(content)

✅ 不信任任何输入

包括:

  • URL 参数

  • 表单输入

  • 后端返回数据(是的,也要防)


五、一句话总结(面试用)

👉 XSS:让页面执行恶意 JS

👉 CSRF:让用户"在不知情下"发请求

相关推荐
kyriewen14 小时前
百度用6%成本碾压硅谷?中国AI把性价比玩明白了
前端·百度·ai编程
kyriewen14 小时前
你还在手动敲命令部署?GitHub Actions 让你 push 即上线,摸鱼时间翻倍
前端·面试·github
xcLeigh15 小时前
KES数据库安全、权限、审计实战
数据库·安全·备份·权限·审计·ssl加密·密码策略
Csvn15 小时前
Pinia 状态管理
前端
不减20斤不改头像16 小时前
手机一句话开发贪吃蛇!TRAE SOLO 移动端 AI 编程实测
前端·后端
xuankuxiaoyao16 小时前
Vue.js实践-组件基础下
前端·javascript·vue.js
一棵白菜16 小时前
Claude Code + Amazon Bedrock 使用指南
前端
大家的林语冰17 小时前
前端周刊:axios 疑遭朝鲜黑客“钓鱼“;CSS 新函数上线;npm 上线深色主题;Oxlint 兼容表;ESLint 支持 Temporal......
前端·javascript·css
哀木18 小时前
一个简单的套壳方案,就能让你的 Agent 少做重复初始化
前端
高翔·权衡之境18 小时前
缓存一致性——多核系统的默契之约
驱动开发·嵌入式硬件·安全·缓存·系统安全·信息与通信