- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Chrome 扩展程序,可以(如果您允许访问文件 URL)获取您在 chrome 中打开的本地 pdf 文件并将其发送到我们的 API 进行处理。这是通过使用 XMLHttpRequest
获取 pdf 来完成的。至file:///Users/user/whatever/testfile.pdf
从后台脚本。
当为 Chrome 扩展迁移到 manifest v3 时,后台脚本将成为服务 worker 。仅在服务人员中 fetch
可用,而不是 XMLHttpRequest
.问题是,fetch 只支持 http 和 https,不支持 file://url。那么我怎样才能使 Chrome 扩展获取/获取本地文件的功能相同呢?
编辑:我也尝试过的事情:
net:ERR_UNKNOWN_URL_SCHEME
提出请求时Access to XMLHttpRequest at 'file:///.../testfile1.docx.pdf' from origin 'null' has been blocked by CORS policy: Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, chrome-untrusted, https.
file://
的大量研究访问的了解通常被阻止,Chrome 扩展后台脚本曾经是一个异常(exception)。在我看来,内容脚本或 Action 弹出窗口从未允许这样做。
{
"manifest_version": 3,
"name": "..",
"version": "0.1",
"icons": {
"16": "assets/icon-16x16.png",
"48": "assets/icon-48x48.png",
"128": "assets/icon-128x128.png"
},
"action": {
"default_title": ".."
},
"background": {
"service_worker": "background.js"
},
"permissions": [
"webRequest",
"activeTab",
"scripting",
"storage",
"unlimitedStorage",
"identity",
"pageCapture"
],
"host_permissions": [
"<all_urls>"
],
"web_accessible_resources": [{
"resources": ["iframe.html"],
"matches": [],
"extension_ids": []
}]
}
内容脚本以编程方式注入(inject)(使用
webextension-polyfill
支持 promise )
browser.action.onClicked.addListener(async (tab: Tab) => {
await browser.scripting.executeScript({files: [ "inject.js" ], target: {tabId: tab.id}});
});
最佳答案
由于您提到的原因,Chrome 98 及更早版本无法在后台服务人员中执行此操作。
还有一个bug这阻止了在正常可见的 chrome-extension://
中执行此操作页面或 iframe。它已在 Chrome 91 中修复。
解决方案
使用fetch
在 Chrome 99 and newer .
在旧版本中,使用以下解决方法。
解决方法 1:文件系统 API,Chrome 86+
ManifestV3 扩展可以使用新的 File System API读取文件的内容,例如在通过 web_accessible_resources 暴露的 iframe 中.
解决方法 2. 扩展框架,Chrome 91+
使用在该 pdf 选项卡中运行的内容脚本:
matches
manifest.json 中应包含 <all_urls>
或 file://*/*
并且文件访问应该由用户启用activeTab
许可和 programmatic injection当用户iframe.html
的不可见 iframe web_accessible_resources 中公开的文件iframe.html
加载 iframe.js
它像往常一样使用 XMLHttpRequest 。由于 iframe 有 chrome-extension://
URL 其环境action
这样的扩展名弹出或选项页面或任何其他
file://
通过 XMLHttpRequest 的 URL 与以前相同。
chrome://extensions
中启用此扩展程序的页面。 关于google-chrome-extension - Chrome 扩展 - 如何访问本地文件 ://with manifest v3,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66245298/
我有一个问题,我想通过其他程序打开 chrome://extensions/页面,例如 cmd.exe 或其他程序。 我们知道,如果我们用chrome.exe打开一个网站,我们可以在cmd.exe中执
当您编写manifest.json 文件时,您必须为内容脚本指定匹配。 http 和 https 工作正常,但如果我尝试包含 chrome://*/* 或其任何变体,我会得到一个我尝试对我的匹配使用无
我真的很困惑我想制作一个可以扩展用户的Google日历的Chrome扩展程序,我应该在Google API下注册哪种程序? 它是Web App吗?但是我不打算让服务器托管任何东西,因为Chrome扩展
我想在带有chrome-extension://URL的iframe上运行内容脚本。我在我的manifest.json文件中添加了一行代码,该行是从http://code.google.com/chr
目前,我正在使用记事本和 chrome 控制台的组合对我的 google-chrome-extensions 进行编码。我 100% 确信有更好的方法来对这些扩展进行编程。人们使用什么环境? 最佳答案
在编写 manifest.json 文件时,必须指定 matches用于您的内容脚本。 http和 https工作正常,但如果我尝试包含 chrome://*/*或它的任何变体,我收到一个错误,提示我
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 7 年前。 Improve
在发布更新后,我正在尝试为我的 Chrome 扩展程序的用户创造流畅的体验。 我在更新应用程序时重新注入(inject)了我的内容脚本,即使用户继续在扩展更新后未刷新的页面上使用我的扩展,我的功能仍然
将扩展程序从 Chrome 移植到 FF 遵循本教程(在 Chrome 中运行良好):http://www.codingscripts.com/check-whether-user-has-a-chr
我正在将 google-chrome 扩展改编成 firefox。 这个扩展相当简单,它只是重新加载当前浏览器窗口并在其中放置一个特定的字符串(它用于在 Odoo 上激活调试状态)。 但是,当我在 m
我正在尝试在普通 HTML 页面(非扩展)中链接到 chrome://extensions。但是单击链接不会执行任何操作: chrome://extensions 右键单击并在新选项卡中打开只会打开
为 String 编写扩展名很容易,但问题是它总是显示为 "MyString".ExtensionMethod() 如果这样写: public static class Extensions{
如题。我正在运行 Joomla 2.5。 “扩展”下拉菜单中唯一可见的项目是: 模块经理 插件管理器 模板管理器 语言经理 编辑:我这样做是为了安装模板,按照此页面上的说明:http://docs.j
基本上我希望文件名以扩展名列表中的扩展名结尾。这是我在 python 中的代码。我已经将一些示例文件名作为列表,如下所示: extensions = ['.mp3','.m4a','.wma'] fi
在 background.html : chrome.tabs.query({active:true, currentWindow:true},function(tabs){ chrome.tab
我有一个可能被用户禁用的 chrome 扩展。在这种情况下,我想创建一个指向 chrome://extensions 菜单的链接。它会是这样的 Chrome extensions 这是不允许的:不允许
我查看了 Google 文档,但不知道如何更改其类型。 这是我加载时遇到的错误。 尝试安装此扩展时出现警告:“browser_action”仅允许用于扩展程序,这是一个旧版打包应用程序。 这是我的ma
我有一个正在构建的 chrome 扩展,它使用 OAuth 访问许多 API。我没有将我的消费者 secret 存储在扩展程序中,而是重定向到获取 token 的服务器,然后重定向回我的扩展程序中的页
我有一个正在构建的 chrome 扩展,它使用 OAuth 访问许多 API。我没有将我的消费者 secret 存储在扩展程序中,而是重定向到获取 token 的服务器,然后重定向回我的扩展程序中的页
这个问题已经有答案了: Why would a developer place a forward slash at the start of each relative path? (4 个回答)
我是一名优秀的程序员,十分优秀!