为什么谷歌浏览器插件中不能使用xmlhttprequest(axios)

按照Chrome Extension官方说明,在MV3中,由于Service Workers的机制,background pages中不支持XMLHttpRequest,建议使用原生fetch()。由于axios使用的是XMLHttpRequest,因此,不能使用axios进行API请求。

在V3 (MV3) 版本中,Google 引入了Service Workers来替代传统的background pages作为扩展的后台进程。这一变更主要是出于安全性和性能的考虑。

Service Workers的设计初衷是处理网络请求、缓存以及提供离线支持,它们运行在一个沙盒化的环境中,拥有自己的执行上下文,与网页或其他Worker隔离。Service Workers不具有窗口上下文,因此不能直接使用一些与DOM(文档对象模型)相关的API,如XMLHttpRequest。

XMLHttpRequest(XHR)是一个与浏览器窗口上下文紧密绑定的API,它主要用于在浏览器环境中执行异步HTTP请求。

由于Service Worker没有直接访问DOM或浏览器窗口的权限,使用XHR会与Service Worker的设计原则冲突,可能导致安全漏洞或行为不可预测性。

因此,在Chrome Extension的MV3规范中,如果你需要在后台处理网络请求,应该使用fetch()方法而非XMLHttpRequest。对原有的background脚本进行相应的调整以兼容Service Worker的限制和特性。

相关推荐
我是伪码农6 分钟前
JS考核复写
前端·javascript·css
Hello eveybody7 分钟前
二叉树简述+考试要点(Python)
开发语言·python
JianZhen✓8 分钟前
前端开发AI工具全攻略:Cursor省Token+模型选择+免VPN工具+万能提示词
前端·人工智能
第二只羽毛11 分钟前
C++高性能内存池6(面试题)
大数据·开发语言·c++
故事和你9115 分钟前
洛谷-算法1-1-模拟与高精度4
开发语言·数据结构·c++·算法·蓝桥杯·动态规划
I love studying!!!17 分钟前
Python项目:使用API
开发语言·python
祁鱼鱼鱼鱼鱼22 分钟前
Location 字符匹配详解
linux·服务器·前端
祁鱼鱼鱼鱼鱼25 分钟前
Nginx反向代理及反向代理负载均衡
linux·服务器·前端
We་ct27 分钟前
JS核心难点解析:变量提升、作用域、Promise、this与类型转换
开发语言·前端·javascript·面试·作用域·类型转化·变量提升
雪的季节27 分钟前
deleteLater跨线程安全触发时机解析
开发语言·qt·安全