chrome extension api中有没有可以阻止页面上特定脚本执行的方法?

发布于 2022-09-01 21:13:12 字数 152 浏览 14 评论 0

这几天在做一个chrome拓展,想通过检索页面中的脚本资源,选择想要阻止执行的脚本进行阻止,然后注入新的脚本进行替代。想问一下chrome extension api中有没有这样的方法,只阻止页面上一个或几个脚本执行,而不是使用chrome.debugger调试全部禁用。谢谢各位大牛~

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

单挑你×的.吻 2022-09-08 21:13:12

自己当时的的问题,自己来回答下。在background.js背景文件中是可以配置要阻止的文件请求的:

// 监听发送请求
chrome.webRequest.onBeforeRequest.addListener(
  function(details) {
    return {redirectUrl: chrome.extension.getURL("returnjs.js")};
  },
  {
    urls: [
        "*://*.jquery.top/*",
      "*://*.elongstatic.com/*"
    ],
    types: ["script"]
  },
  ["blocking"]
);

urls中配置要监控的url,可以进行范围匹配,types中对监听的文件类型进行匹配,['blocking']参数表示要进行的操作是拦截,然后:
`
return {redirectUrl: chrome.extension.getURL("returnjs.js")};
`
这句就是将监听到匹配的url请求重定向为请求return.js,return.js中的代码是void 0;即什么都不做,这样就达到了拦截效果。

染火枫林 2022-09-08 21:13:12

这是无解的。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文