【JS】判断是否安装了某个Chrome插件

前提

manifest.json 清单

下文均以manifest.json v3介绍。

因为Chrome官方文档中明确说明,v2已经弃用了。

ID

由于浏览器的安全策略,以下方法均在「已知扩展程序 ID」 的前提下才可实现。

获取扩展程序ID

进入扩展程序管理页,找到对应插件。
注意:上架后的程序ID唯一,但是开发阶段(文件夹拖入形式),ID是随机变化的(每次拖入ID发生改变)。


方式一:Web端加载扩展程序中的资源

通过web端尝试加载扩展程序中的资源来判断是否下载了插件。

扩展程序

在manifest.json 清单中将图片暴露为 web可访问资源。

注意:一定要加后缀,按照编译器默认提示并不会生效。

Web端

通过扩展程序ID,尝试加载扩展程序中暴露的图片资源

javascript 复制代码
function detectExtension(extensionId) {
    let img
    img = new Image()
    img.src = "chrome-extension://" + extensionId + "/icons/logo-tini.png"
    img.onload = function () {
        console.log("插件已存在")
    };
    img.onerror = function () {
        console.log("未找到插件")
    };
}

方式二:Web与扩展程序通信

扩展程序

在manifest.json 清单中,添加externally_connectable配置项,该配置项用于指定扩展与哪些网站可以进行外部通信,即与网站的内容脚本进行通信。

background.js中监听Web端的消息

javascript 复制代码
// background.js
chrome.runtime.onMessageExternal.addListener(function (
  message,
  sender,
  sendResponse
) {
  if (message && message === "hasExtension") {
    sendResponse({ hasExtension: true })
  } else {
    return true
  }
})

但是content.js中不可以监听Web端的消息,主要因为 「沙盒环境限制」「消息传递机制」

沙盒环境限制

content.js在网页环境中运行,与网页的 DOM 共享同一个沙盒环境,但与扩展程序的其他部分(如 background.js)处于不同的沙盒环境 。因此,content.js 无法直接访问 Chrome 扩展 API,包括 chrome.runtime.onMessage.addListener。

消息传递机制

content.js 与其他部分通信的主要方式是通过消息传递。content.js 可以使用 chrome.runtime.sendMessage 方法向其他部分发送消息,其他部分可以通过监听 chrome.runtime.onMessage.addListener 来接收消息。但 content.js 自身不具备接收消息的能力,因为它运行在沙盒环境中,无法直接监听 Chrome 扩展的事件。

Web端

javascript 复制代码
try {
  chrome.runtime.sendMessage(
    extensionId,
    "hasExtension",
    (res) => {
      console.log("res", res)
      if (res && res.hasExtension) {
        console.log("插件已存在")
      }
    }
  )
} catch (error) {
  console.log(error.message)
  console.log("未找到插件")
}

方式三:扩展程序向Web端插入元素(不需要扩展程序ID,更适用于开发阶段未上架的扩展)

扩展程序

在 content.js 中向页面插入标识,也可以自行操作dom,比如给某个web端已存在的标签添加自定义属性等等。

javascript 复制代码
let div = document.createElement('div');
div.setAttribute('id', 'hasExtension');
// 也可以继续添加多个自定义属性用于提高健壮性
div.setAttribute("isInstalled", "true")
document.getElementsByTagName('body')[0].appendChild(div);

注意:一定要写在 content.js 中,其他不生效。因为只有 content.js 与Web端DOM共享一个沙盒环境。content.js 会在页面加载完成后注入到页面中,但是在页面的 DOM 元素加载完毕之前执行。

Web端

javascript 复制代码
function detectExtension() {
  let div = document.getElementById("hasExtension");
  let flag = div.getAttribute("isInstalled")
  if (div && flag) {
        console.log('插件已存在');
  } else {
      console.log('未找到插件');
  }
}
相关推荐
微风中的麦穗15 小时前
【MATLAB】MATLAB R2025a 详细下载安装图文指南:下一代科学计算与工程仿真平台
开发语言·matlab·开发工具·工程仿真·matlab r2025a·matlab r2025·科学计算与工程仿真
2601_9491465315 小时前
C语言语音通知API示例代码:基于标准C的语音接口开发与底层调用实践
c语言·开发语言
开源技术15 小时前
Python Pillow 优化,打开和保存速度最快提高14倍
开发语言·python·pillow
学嵌入式的小杨同学15 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
mftang17 小时前
Python 字符串拼接成字节详解
开发语言·python
jasligea17 小时前
构建个人智能助手
开发语言·python·自然语言处理
yuezhilangniao17 小时前
AI智能体全栈开发工程化规范 备忘 ~ fastAPI+Next.js
javascript·人工智能·fastapi
kokunka17 小时前
【源码+注释】纯C++小游戏开发之射击小球游戏
开发语言·c++·游戏
云栖梦泽18 小时前
易语言开发从入门到精通:补充篇·网络编程进阶+实用爬虫开发·API集成·代理IP配置·异步请求·防封禁优化
开发语言
java1234_小锋18 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试