(2)从零开发 Chrome 插件:实现 API 登录与本地存储功能

从零开发 Chrome 插件:实现 API 登录与本地存储功能

Chrome 插件作为浏览器功能的重要扩展,能极大提升用户的工作效率。本文将以一个「登录功能插件」为例,带你从零构建一个可调用 API 验证身份、并将用户信息存储在本地的 Chrome 插件。

基础信息请看
Chrome插件开发入门:从零构建你的第一个插件

为什么需要这样的插件?

在日常开发中,我们经常需要访问各种需要登录自有系统或 API,记录操作以及后续的业务操作需要携带token,访问其他业务系统,是很多工具类插件的基础功能。

本文将实现的核心功能包括:

  • 一个简洁的登录界面(输入用户名、密码)
  • 调用后端登录 API 验证身份
  • 将登录状态(如 Token、用户名)安全存储到本地
  • 处理登录过程中的各种异常(如网络错误、账号密码错误)

在这里插入图片描述

从零构建登录插件

第一步:搭建目录结构

一个基础的登录插件目录非常简洁,包含 4 个核心文件:

login-extension/
├─ manifest.json       // 插件配置(必选)
├─ popup.html          // 登录界面(点击插件图标显示)
├─ popup.js            // 登录逻辑(API调用、本地存储)
└─ style.css           // 美化界面(可选但推荐)

第二步:配置 manifest.json

manifest.json 是插件的「身份证」,用于告诉 Chrome 插件的名称、版本、权限等信息。以下是适配 Manifest V3 的配置:

{"manifest_version": 3,"name": "简易登录助手","version": "1.0.0","description": "通过 API 登录并安全保存用户信息","permissions": ["storage"],  // 允许使用本地存储"action": {"default_popup": "popup.html",  // 点击插件图标显示的页面"default_icon": "icon.png"      // 插件图标(可自定义)},"host_permissions": ["https://api.yourdomain.com/*"]  // 允许请求的 API 域名
}

关键配置说明

  • permissions: ["storage"]:声明使用 Chrome 的本地存储 API(chrome.storage)。
  • host_permissions:指定插件可以访问的 API 域名,避免跨域问题(开发时可先用 *://*/* 测试,但上线前需改为具体域名)。

第三步:设计登录界面(popup.html)

登录界面需要包含用户名输入框、密码输入框、登录按钮和状态提示区。以下是一个简洁的实现:

<!DOCTYPE html>
<html>
<head><meta charset="UTF-8"><title>用户登录</title><link rel="stylesheet" href="style.css">
</head>
<body><div class="login-box"><h2>系统登录</h2><div class="input-group"><label for="username">用户名</label><input type="text" id="username" placeholder="请输入用户名"></div><div class="input-group"><label for="password">密码</label><input type="password" id="password" placeholder="请输入密码"></div><button id="loginBtn">登录</button><p id="status"></p>  <!-- 显示登录状态(成功/失败) --></div><script src="popup.js"></script>
</body>
</html>

样式优化后,界面会更贴近现代 Web 应用的设计风格,输入框聚焦时的蓝色边框也能给用户明确的反馈。

第四步:实现登录逻辑(popup.js)

这是插件的核心,负责读取用户输入、调用 API、处理返回结果并保存数据到本地存储。

// 等待页面加载完成
document.addEventListener('DOMContentLoaded', () => {// 获取页面元素const usernameInput = document.getElementById('username');const passwordInput = document.getElementById('password');const loginBtn = document.getElementById('loginBtn');const status = document.getElementById('status');// 登录按钮点击事件loginBtn.addEventListener('click', async () => {// 获取并验证输入const username = usernameInput.value.trim();const password = passwordInput.value.trim();if (!username || !password) {showStatus('请输入用户名和密码', 'error');return;}try {// 调用登录 API(替换为你的实际接口)const response = await fetch('https://api.yourdomain.com/login', {method: 'POST',headers: {'Content-Type': 'application/json',// 如需额外 headers(如 API 密钥),可在此添加// 'X-API-Key': 'your-api-key'},body: JSON.stringify({ username, password })});const result = await response.json();// 处理 API 返回结果if (response.ok && result.success) {// 登录成功:保存用户信息到本地存储await saveUserInfo(username, result.token);showStatus('登录成功!', 'success');// 清空输入框usernameInput.value = '';passwordInput.value = '';} else {// 登录失败(如账号密码错误)showStatus(result.message || '登录失败,请检查账号密码', 'error');}} catch (error) {// 捕获网络错误showStatus('网络错误,请稍后重试', 'error');console.error('登录请求失败:', error);}});// 显示状态信息的工具函数function showStatus(text, type) {status.textContent = text;status.className = type;}// 保存用户信息到本地存储function saveUserInfo(username, token) {return new Promise((resolve) => {chrome.storage.local.set({userInfo: {username: username,token: token,  // 假设 API 返回 TokenloginTime: new Date().toISOString()  // 记录登录时间}}, () => {resolve();});});}
});
代码关键点解析:
  1. API 调用:使用 fetch 发送 POST 请求,将用户名和密码以 JSON 格式传递给后端。实际开发中,需根据后端要求调整请求参数(如是否需要验证码、额外的请求头)。

  2. 本地存储:通过 Chrome 提供的 chrome.storage.local API 保存用户信息。与普通 localStorage 相比,它的优势在于:

    • 不受页面域名限制(插件内全局可用)
    • 支持异步操作,适合存储较大数据
    • 配合 storage 权限,安全性更高
  3. 错误处理:覆盖了三种常见场景:输入为空、API 返回失败(如密码错误)、网络异常,确保用户能明确知道问题所在。

测试插件功能

插件开发完成后,需要在 Chrome 中测试是否能正常工作:

  1. 打开 Chrome 浏览器,访问 chrome://extensions/
  2. 开启右上角的「开发者模式」
  3. 点击「加载已解压的扩展程序」,选择插件所在的 login-extension 文件夹
  4. 点击浏览器工具栏中的插件图标,即可看到登录界面

测试流程建议:

  • 输入正确的账号密码 → 应提示「登录成功」,并在 chrome://extensions/ 的「检查视图」中通过控制台验证本地存储是否有数据(通过 chrome.storage.local.get('userInfo', (data) => console.log(data)) 查看)

总结

通过本文的示例,掌握了 Chrome 插件调用 API 实现登录并存储用户信息的核心流程。这个基础框架可以扩展出更多功能,例如:自动携带 Token 调用其他 API、定期检查登录状态、多账号管理等。

Chrome 插件开发的核心是理解其配置规则和 API 特性,结合前端基础知识,就能快速实现各种实用工具。希望本文能帮助你迈出插件开发的第一步!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/88821.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/88821.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flink时间窗口详解

一、引言在大数据流处理的领域中&#xff0c;Flink 的时间窗口是一项极为关键的技术&#xff0c;想象一下&#xff0c;你要统计一个电商网站每小时的订单数量。由于订单数据是持续不断产生的&#xff0c;这就形成了一个无界数据流。如果没有时间窗口的概念&#xff0c;你就需要…

宽带接入,网线插入电脑的经验

现在一般家里安装移动宽带&#xff0c;都会提供四个千兆接口的光猫路由器&#xff0c;但是要注意了 首先网线的两端看起来一样&#xff0c;实际上并不是&#xff0c;如果发现连接不成功&#xff0c;那么就要换一头重新尝试&#xff0c; 一般像说什么自动DHCP啊&#xff0c;因为…

crmeb多门店对接拉卡拉支付小程序聚合收银台集成全流程详解

一、商户注册与配置​​注册支付平台账号​​&#xff1a;在拉卡拉开放平台注册商户账号&#xff08;私信联系注册&#xff09;​​创建应用​​&#xff1a;获取小程序应用ID(AppID)​​配置支付参数​​&#xff1a;商户号(MID)终端号(TID)API密钥支付回调地址二、配置拉卡拉…

C#将树图节点展示到NetronLight图表中

之前写过NetronLight开源框架 C#使用开源框架NetronLight绘制流程图-CSDN博客 我们这里将TreeView树图的节点内容展示到NetronLight图表中&#xff0c;按照树的层次【深度Level】展示 新建窗体应用程序ShowTreeNodeToDiagram&#xff0c;将默认的Form1重命名为FormShowNode&…

精密模具大深径比微孔尺寸检测方案 —— 激光频率梳 3D 轮廓检测

引言精密模具中大深径比微孔&#xff08;深径比&#xff1e;20:1&#xff0c;孔径&#xff1c;1mm&#xff09;的尺寸精度直接影响注塑件、电子元件等产品的成型质量。此类微孔具有孔径小、深度大、表面质量要求高&#xff08;Ra≤0.1μm&#xff09;等特点&#xff0c;传统检测…

defer学习指南

一、源头&#xff1a;早期管理资源&#xff08;如数据库连接、锁、文件句柄、网络连接&#xff09;和状态清理异常麻烦。 必须在每个可能的返回点&#xff08;return、err、panic&#xff09;手动重复清理代码&#xff0c;极易遗漏且打断主要逻辑思路&#xff01;像Java语言虽然…

NLP_知识图谱_大模型——个人学习记录

1. 自然语言处理、知识图谱、对话系统三大技术研究与应用 https://github.com/lihanghang/NLP-Knowledge-Graph 深度学习-自然语言处理(NLP)-知识图谱&#xff1a;知识图谱构建流程【本体构建、知识抽取&#xff08;实体抽取、 关系抽取、属性抽取&#xff09;、知识表示、知…

linux:进程详解(1)

目录 ​编辑 1.进程基本概念与基本操作 1.1 概念 1.2 描述进程-PCB 1.2.1PCB的基本概念 1.2.2 task_ struct 1.2.3 查看进程 2.进程状态 2.1 Linux内核源码展示 2.2 进程状态查看 ​编辑 2.3 Z(zombie)-僵⼫进程 2.4 僵尸进程的危害 2.5 孤儿进程 3.进程优先级 …

碳中和目标下的全球产业链重构:深度解析与未来路径

引言&#xff1a;气候临界点与产业链的系统性风险2023年&#xff0c;全球平均气温较工业化前上升1.2℃&#xff0c;南极冰盖年消融量达1500亿吨&#xff0c;极端天气事件导致的经济损失占全球GDP的2.3%。这一系列数据背后&#xff0c;暴露出传统产业链的致命缺陷——其设计逻辑…

FPGA实现SDI转LVDS视频发送,基于GTX+OSERDES2原语架构,提供2套工程源码和技术支持

目录 1、前言工程概述免责声明 2、相关方案推荐我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目本博已有的 SDI 编解码方案FPGA实现LVDS视频收发方案 3、工程详细设计方案工程设计原理框图SDI 输入设备Gv8601a 均衡器GTX 解串SMPTE SD/HD/3G SDI IP核BT1120转RGB奇…

新手向:使用Python构建高效的日志处理系统

本文将详细讲解如何使用Python开发一个专业的日志分析工具&#xff0c;能够自动化处理、分析和可视化各类日志文件&#xff0c;大幅提升运维效率。环境准备开发本工具需要以下环境配置&#xff1a;Python环境&#xff1a;建议Python 3.8或更高版本必要库&#xff1a;pandas&…

大模型-量化技术

简介 模型量化是一种重要的模型压缩技术。其核心目标是在可控精度损失下&#xff0c;将大模型中浮点型权重&#xff08;通常为 float32 等高精度格式&#xff09;近似转换为低精度离散值表示&#xff08;通常为 int8&#xff09;。 具体而言&#xff0c;该技术通过将模型的权重…

【C语言网络编程】HTTP 客户端请求(域名解析过程)

在做 C 语言网络编程或模拟 HTTP 客户端时&#xff0c;第一步就离不开“把域名解析为 IP 地址”这一步。很多人可能直接复制粘贴一段 gethostbyname 的代码&#xff0c;但未必真正理解它的原理。 本篇博客将围绕一个经典函数&#xff1a; char *host_to_ip(const char *hostna…

Node.js特训专栏-实战进阶:16. RBAC权限模型设计

🔥 欢迎来到 Node.js 实战专栏!在这里,每一行代码都是解锁高性能应用的钥匙,让我们一起开启 Node.js 的奇妙开发之旅! Node.js 特训专栏主页 专栏内容规划详情 我将从RBAC权限模型的基础概念、核心组件讲起,详细阐述其设计原则、数据库模型设计,还会结合代码示例展示在…

mac上BRPC的CMakeLists.txt优化:解决Protobuf路径问题

问题背景与挑战 在构建高性能RPC框架BRPC时&#xff0c;​Protobuf依赖路径的配置往往是开发者面临的主要挑战之一。原始CMake配置在寻找Protobuf库时存在以下痛点&#xff1a; ​路径搜索不精确​&#xff1a;默认find_library无法定位自定义安装路径下的Protobuf​版本兼容…

Go 性能分析利器:pprof 工具实战指南

在 Go 语言开发中&#xff0c;性能问题往往是项目上线后最棘手的挑战之一。无论是 CPU 占用过高、内存泄漏&#xff0c;还是 goroutine 失控&#xff0c;都可能导致服务响应缓慢甚至崩溃。而pprof作为 Go 官方提供的性能分析工具&#xff0c;就像一把精准的手术刀&#xff0c;能…

fio测试SSD直接I/O(Direct IO)性能仅有100MB/s的问题解决

针对您使用fio测试SSD直接I/O&#xff08;Direct IO&#xff09;性能仅有100MB/s的问题&#xff0c;结合SSD特性和fio测试原理 fio测试SSD直接I/O&#xff08;Direct IO&#xff09;性能仅有100MB/s的问题 - LinuxGuideLinuxGuide 以下是可能的原因及优化方案&#xff1a; &a…

EVO-0:具有隐空间理解的视觉-语言-动作模型

25年6月来自上海交大、EvoMind Tech 和上海算法创新研究院&#xff08;IAAR-Shanghai&#xff09;的论文“EVO-0: Vision-Language-Action Model with Implicit Spatial Understanding”。 视觉-语言-动作 (VLA) 模型已成为一种有前途的框架&#xff0c;可使通用机器人能够在现…

文心大模型4.5开源测评:轻量化部署实践与多维度能力验证

前言&#xff1a;开源浪潮下的轻量化革命 2025年百度文心大模型4.5系列的开源&#xff0c;标志着国产大模型从“参数竞赛”转向“实用落地”的关键转折。当行业仍在追逐千亿参数模型时&#xff0c;文心4.5以0.3B轻量级模型撕开一条新赛道——单卡部署、低成本运维、中文场景高…

LeetCode 2401.最长优雅子数组

给你一个由 正 整数组成的数组 nums 。 如果 nums 的子数组中位于 不同 位置的每对元素按位 与&#xff08;AND&#xff09;运算的结果等于 0 &#xff0c;则称该子数组为 优雅 子数组。 返回 最长 的优雅子数组的长度。 子数组 是数组中的一个 连续 部分。 注意&#xff1a;长…