news 2026/6/15 13:15:25

Web前端 认证token的安全存储策略

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Web前端 认证token的安全存储策略

目录

方案概述

核心思路:

架构设计:

三层存储策略:

风险接受说明:

接受的风险:

防御的风险:

一句话部署:

🛡️ Next.js XSS 防御终极方案

一、必须做的3件事(核心防御)

1. 永远不用或净化 dangerouslySetInnerHTML

2. API Routes 必须验证输入

3. 配置CSP安全头

二、4个绝对禁止

❌ 永远不要用这些:

三、3个必须验证

用户控制的跳转/加载必须验证:

四、开发习惯2条

1. 数据只通过React传递

2. 第三方库配置安全选项

五、检查清单(部署前)

一句话总结:


前言:最安全的方案不一定用户体验最优,需根据合适的场景选择安全策略。

这里,我主要针对大多数常规业务场景下的实施方案进行分析。这些方案通常不适用于银行、金融、支付等高安全性场景,因为这类场景通常需要进行二次生物验证或其他安全性较强但可能影响用户体验的验证措施。

方案概述

核心思路:

用短期内存token保证安全,用长期refresh_token保证体验,用XSS防御保证token不通过代码窃取。

架构设计:

三层存储策略:

🔐 第一层:access_token → sessionStorage(15分钟)
- 页面关闭自动清除
- XSS难窃取(短暂窗口)

🔐 第二层:refresh_token → localStorage(30天)
- 接受扩展窃取风险
- 用户可手动清除

🔐 第三层:关键操作 → 二次验证
- 支付、改密等需要额外验证

双重刷新机制:

🔄 主动刷新:每14分钟自动刷新access_token
🔄 被动刷新:401时自动用refresh_token换新token
🔄 无缝体验:用户无感知,保持30天免登录

XSS全面防御:

✅ Next.js自动转义所有JSX
✅ CSP阻止外部脚本加载
✅ 禁止dangerouslySetInnerHTML(或必须净化)
✅ API层输入验证
✅ 绝不使用eval/innerHTML

风险接受说明:

接受的风险:

  1. 浏览器扩展可能读取localStorage(用户已同意安装)

  2. 用户电脑木马可能窃取token(超出Web防护范围)

  3. 物理接触电脑可能获取token(用户责任)

防御的风险:

  1. 网站XSS攻击(通过严格CSP和Next.js防护)

  2. CSRF攻击(SameSite Cookie + 后端验证)

  3. Token长期泄露(access_token仅15分钟有效)

  4. 重放攻击(JWT jti + 短期有效期)

一句话部署:

sessionStorage存15分钟access_token,localStorage存30天refresh_token,配置严格CSP,定期npm audit。

🛡️Next.js XSS 防御终极方案

一、必须做的3件事(核心防御)

1. 永远不用或净化dangerouslySetInnerHTML

2. API Routes 必须验证输入

// pages/api/xxx.js 或 app/api/xxx/route.js export default function handler(req, res) { const { content } = req.body; // 必须验证 if (!content || typeof content !== 'string') { return res.status(400).json({ error: 'Invalid input' }); } // 存储前转义 const safeContent = escapeHtml(content); // ...保存到数据库 }

3. 配置CSP安全头

// next.config.js(一次性配置) module.exports = { async headers() { return [{ source: '/(.*)', headers: [ { key: 'Content-Security-Policy', value: "default-src 'self'; script-src 'self';" } ] }]; } };

二、4个绝对禁止

❌ 永远不要用这些:

1. element.innerHTML = ... 2. document.write(...) 3. eval(userCode) 4. new Function(userCode)

三、3个必须验证

用户控制的跳转/加载必须验证:

// 1. URL跳转 if (url.startsWith('/') || url.startsWith('https://yourdomain.com')) { window.location.href = url; } // 2. iframe/src属性 const allowedDomains = ['https://youtube.com']; const isSafe = allowedDomains.some(d => url.startsWith(d)); // 3. 动态脚本 // 不要创建和执行用户提供的脚本

四、开发习惯2条

1. 数据只通过React传递

// ✅ 好习惯 const [data, setData] = useState(''); useEffect(() => { const raw = localStorage.getItem('data'); setData(raw); // React自动转义 }, []); // ❌ 坏习惯 useEffect(() => { const raw = localStorage.getItem('data'); document.getElementById('output').innerHTML = raw; // 绕过React }, []);

2. 第三方库配置安全选项

// 如markdown解析器 new MarkdownIt({ html: false, // 禁止HTML标签 xhtmlOut: true });

五、检查清单(部署前)

✅ CSP安全头已配置
✅ 没有使用未净化的 dangerouslySetInnerHTML
✅ API Routes 都有输入验证
✅ 没有使用 innerHTML/document.write/eval
✅ 用户跳转链接都验证了域名
✅ 运行 npm audit 无高危漏洞
✅ 所有依赖都是最新版本
✅ HTTPS已启用

一句话总结:

在Next.js中,只要:

  1. 不用(或净化)dangerouslySetInnerHTML

  2. API Routes验证所有输入

  3. 配置CSP安全头

  4. 绝不使用 innerHTML/eval

其他时候React自动保护你,XSS风险极低。

总之,在配置和代码中进行预防,安全意识少不了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 8:21:52

【Linux基础】操作系统下的进程与虚拟内存的关系

本系列主要旨在帮助初学者学习和巩固Linux系统。也是笔者自己学习Linux的心得体会。 个人主页: 爱装代码的小瓶子 文章系列: Linux 2. C 文章目录 Linux的魔法世界:进程、内存与操作系统的三重奏第一章:进程——操作系统里的&…

作者头像 李华
网站建设 2026/6/12 13:08:53

RexUniNLU镜像免配置:Dockerfile预置modelscope缓存+torch-cu118依赖

RexUniNLU镜像免配置:Dockerfile预置modelscope缓存torch-cu118依赖 1. 框架概述 RexUniNLU是一款基于Siamese-UIE架构的轻量级自然语言理解框架,其核心优势在于零样本学习能力。这意味着开发者无需准备任何标注数据,只需定义简单的标签&am…

作者头像 李华
网站建设 2026/6/14 14:54:21

maven依赖爆红处理

步骤 1:关闭 IDEA先把当前打开的 IDEA 窗口完全关闭(点击右上角 “”),确保 IDEA 没有在后台运行(可以在任务管理器里检查 “IntelliJ IDEA” 进程,若有则结束)。步骤 2:找到并删除.…

作者头像 李华
网站建设 2026/6/15 12:50:12

Z-Image Turbo快速部署:开箱即用的本地AI画板安装指南

Z-Image Turbo快速部署:开箱即用的本地AI画板安装指南 1. 为什么你需要一个“开箱即用”的本地画板? 你是不是也遇到过这些情况: 下载了某个AI绘图项目,结果卡在环境配置上一整天——CUDA版本对不上、torch和diffusers版本冲突…

作者头像 李华
网站建设 2026/6/15 11:17:16

用YOLOv10做PCB缺陷检测,小目标识别更准

用YOLOv10做PCB缺陷检测,小目标识别更准 在电子制造工厂的自动光学检测(AOI)工位上,一块标准PCB板密布着数百个焊点、走线和元件。其中最微小的虚焊缺陷可能只有0.15毫米宽——相当于一根头发丝的三分之一。传统检测算法常把这类缺…

作者头像 李华