前端如何实现 [记住密码] 功能

前端如何实现“记住密码”功能

“记住密码”功能在现代 Web 应用中仍然非常常见,但由于浏览器安全策略和用户隐私意识的提升,实现方式已经从早期的“明文存 Cookie”演变为更安全、更符合规范的方案。

下面是目前主流的几种实现方式,从简单到推荐的完整说明:

1. 最常见但已不推荐的方式(仅作了解)

方式:用户名 + 密码同时存入 Cookie 或 localStorage

// 登录成功后 localStorage.setItem('username', username); localStorage.setItem('password', password);// 明文!极度危险// 下次打开页面自动填充 document.getElementById('username').value = localStorage.getItem('username')||''; document.getElementById('password').value = localStorage.getItem('password')||'';

问题

  • 密码明文存储在客户端,极易被窃取(XSS、物理访问、开发者工具等)
  • localStorage 没有过期时间,永久保留
  • 几乎所有安全扫描工具都会标记为高危漏洞

结论2025 年已完全不建议使用这种方式


2. 当前最推荐的合规方案(浏览器原生 + 记住我)

现代浏览器(Chrome、Safari、Edge、Firefox)都提供了密码管理器自动填充功能,前端只需要配合好即可实现“记住密码”。

核心思路

不自己存密码,而是让浏览器记住密码。

前端要做的事:

  1. 使用正确的表单结构,让浏览器识别这是登录表单
  2. 添加 autocomplete="on" 或更具体的属性
  3. 提供“记住我”复选框(但实际不存密码)
  4. 登录成功后,浏览器会弹出“是否保存密码”的提示
推荐的 HTML 结构
<formid="loginForm"method="post"autocomplete="on"><div><labelfor="username">用户名 / 邮箱</label><inputtype="text"id="username"name="username"autocomplete="username"required></div><div><labelfor="password">密码</label><inputtype="password"id="password"name="password"autocomplete="current-password"required></div><divclass="remember-me"><inputtype="checkbox"id="remember"name="remember"checked><labelfor="remember">记住我(下次自动登录)</label></div><buttontype="submit">登录</button></form>
关键属性说明
属性作用推荐值
autocomplete="username"告诉浏览器这是用户名/邮箱字段username / email
autocomplete="current-password"告诉浏览器这是当前登录密码current-password
autocomplete="on"表单整体允许自动填充on
name="password"必须有 name,浏览器才会识别为密码字段password
浏览器行为
  • 用户第一次登录成功后,浏览器通常会弹出“保存密码?”的提示
  • 用户选择“保存”后,下次访问相同域名时:
    • 用户名/邮箱会自动填充
    • 密码字段会显示“使用保存的密码”或直接填充(取决于浏览器设置)
“记住我”复选框的作用

现在“记住我”更多是心理安慰 + 业务逻辑

  • 勾选了 → 后端返回更长的 session/token 有效期(比如 30 天)
  • 没勾选 → session 短(比如 2 小时或浏览器关闭即失效)

前端不需要自己存密码,只需把这个状态传给后端。


3. 更现代的方案:使用 Credential Management API(推荐高级场景)

浏览器提供的 Credential Management API 允许网站主动读取/保存用户凭证。

示例代码(保存凭证)
asyncfunctionsaveCredential(username, password){if(!navigator.credentials)return;try{const cred =newPasswordCredential({id: username,password: password,name: username,// 可选,显示在选择器中iconURL:'/logo.png'// 可选});await navigator.credentials.store(cred); console.log('凭证已保存');}catch(err){ console.error('保存凭证失败', err);}}
自动获取保存的凭证
asyncfunctionautoFillLogin(){if(!navigator.credentials)return;try{const cred =await navigator.credentials.get({password:true,mediation:'optional'// 可选:显示选择器});if(cred && cred.type ==='password'){ document.getElementById('username').value = cred.id; document.getElementById('password').value = cred.password;}}catch(err){ console.log('获取凭证失败', err);}}// 页面加载时尝试自动填充 window.addEventListener('load', autoFillLogin);

支持情况(2026 年):

  • Chrome / Edge:完全支持
  • Safari:部分支持(限制较多)
  • Firefox:不支持或支持有限

4. 总结:2025–2026 年推荐做法对比

方案安全性用户体验实现难度推荐指数备注
明文存 localStorage/Cookie★☆☆☆☆★★★☆☆不推荐高危漏洞
浏览器原生自动保存(推荐)★★★★★★★★★★★★★★★首选
Credential Management API★★★★★★★★★☆★★★★☆高级场景
后端返回长效 token + HttpOnly Cookie★★★★★★★★★☆★★★★☆适合 App 端

一句话结论

现代 Web 应用中,“记住密码”功能最好的实现方式是:配合浏览器的密码管理器,使用规范的表单结构 + autocomplete 属性,让浏览器来负责记住和填充密码,前端只负责“记住我”状态的业务逻辑(长 session / token)。

如果你想在项目中同时支持“记住我” + “一键登录”,可以告诉我你的技术栈(React/Vue/纯 JS?),我可以给你更具体的完整代码示例。

Read more

OpenClaw配置飞书机器人完整指南

OpenClaw配置飞书机器人完整指南 使用openclaw channels add配置飞书机器人需完成插件安装→飞书应用创建→通道配置→事件订阅→发布应用五个核心步骤,以下是可直接执行的详细流程。 文章目录 * OpenClaw配置飞书机器人完整指南 * 一、前置准备 * 二、通道配置(openclaw channels add) * 方法1:交互式向导配置(推荐) * 方法2:非交互式命令配置(适合脚本) * 方法3:手动编辑配置文件 * 三、事件订阅与发布(关键步骤) * 四、测试与验证 * 五、常见问题排查 一、前置准备 1. 飞书开放平台创建应用(获取凭证) 1. 访问飞书开放平台:https://open.feishu.cn/app 2. 创建企业自建应用,填写名称(如"

低代码Web界面开发实战:用Dify Workflow 5分钟构建专业表单

低代码Web界面开发实战:用Dify Workflow 5分钟构建专业表单 【免费下载链接】Awesome-Dify-Workflow分享一些好用的 Dify DSL 工作流程,自用、学习两相宜。 Sharing some Dify workflows. 项目地址: https://gitcode.com/GitHub_Trending/aw/Awesome-Dify-Workflow 还在为复杂的前端代码头疼吗?想快速搭建Web界面却不懂JavaScript?别担心,Dify Workflow可视化工具能帮你解决这些困扰。作为一款强大的低代码开发平台,它让Web界面开发变得像搭积木一样简单有趣。Awesome-Dify-Workflow项目汇集了丰富的DSL工作流模板,让你零基础也能快速上手。 为什么选择低代码开发? 传统Web开发需要掌握HTML、CSS、JavaScript等多种技术,而低代码平台通过可视化组件和预置模板,让你用拖拽的方式就能完成界面构建。 开发方式学习成本开发周期维护难度传统编码开发高 ✅ 需要专业前端知识长 🕐 通常需要数天到数周高 📈 需

Gemma-3-12B-IT WebUI效果呈现:强化学习对齐+RLHF训练流程解析

Gemma-3-12B-IT WebUI效果呈现:强化学习对齐+RLHF训练流程解析 1. 引言:从聊天界面到模型灵魂 当你打开Gemma-3-12B-IT的WebUI界面,输入一个问题,几秒钟后就能得到一个流畅、准确、甚至充满人情味的回答。这个看似简单的交互背后,隐藏着一套复杂而精密的训练体系——强化学习对齐(Reinforcement Learning Alignment)和RLHF(Reinforcement Learning from Human Feedback)训练流程。 你可能已经体验过Gemma-3-12B-IT的强大对话能力:它能理解你的意图,生成高质量的代码,解释复杂概念,甚至进行创意写作。但你是否想过,这个模型是如何学会“好好说话”的?它为什么不会像早期的聊天机器人那样胡言乱语,或者给出有害的建议? 今天,我们就来深入解析Gemma-3-12B-IT背后的训练秘密。这不是一篇枯燥的技术论文,而是一次带你走进大模型“训练营”的旅程。我们会用最直白的方式,解释强化学习对齐和RLHF到底是什么,它们如何让一个“原始”的语言模型变成现在这个聪明、有用、安全的对话

Qwen3-VL-WEBUI游戏AI:视觉决策系统搭建

Qwen3-VL-WEBUI游戏AI:视觉决策系统搭建 1. 引言:为何需要基于Qwen3-VL的视觉决策系统? 在当前AI驱动的游戏自动化、智能NPC设计与玩家行为分析等场景中,传统的纯文本大模型已难以满足复杂交互需求。游戏界面本质上是高度结构化的多模态环境——包含图像、动态UI元素、空间布局和实时反馈机制。为此,阿里开源的 Qwen3-VL-WEBUI 提供了一个强大的解决方案。 该平台内置了 Qwen3-VL-4B-Instruct 模型,作为Qwen系列迄今最强的视觉-语言模型(VLM),具备深度视觉理解、长上下文推理与GUI操作能力。通过将其部署为Web服务,开发者可快速构建一个能“看懂”游戏画面并做出智能决策的AI代理系统。 本文将围绕如何利用 Qwen3-VL-WEBUI 构建一套完整的游戏AI视觉决策系统,涵盖技术原理、部署实践、核心功能调用及工程优化建议,帮助读者实现从“感知”到“行动”的闭环。 2. 技术架构解析:Qwen3-VL的核心能力拆解 2.1 多模态融合机制:视觉与语言的统一表征 Qwen3-VL采用交错MRoPE(Multiresolu