匹配模式

匹配模式是一种具有以下结构的网址,用于指定一组网址:

<scheme>://<host>/<path>

scheme:必须是以下各项之一,并使用双斜线 (//) 与模式的其余部分分隔开来:

  • http
  • https
  • 通配符 *,仅与 httphttps 匹配
  • file

如需了解如何将内容脚本注入不受支持的架构(例如 about:data:),请参阅在相关帧中注入

host:主机名 (www.example.com)。主机名前面的 * 用于匹配子网域 (*.example.com),或者仅使用通配符 *。 - 如果您在主机模式中使用通配符,则通配符必须是第一个字符或唯一字符,并且必须紧跟英文句点 (.) 或正斜线 (/)。

path:网址路径 (/example)。对于主机权限,该路径是必需的,但会被忽略。应遵循惯例使用通配符 (/*)。

扩展程序在各种用例中使用匹配模式,包括:

特殊情况

"<all_urls>"
匹配以允许的 scheme 开头的所有网址,包括有效格式下列出的任何格式。由于此变更会影响所有托管方,因此使用该变更的扩展程序在 Chrome 应用商店中的审核可能需要更长时间
"file:///"
允许您的扩展程序在本地文件上运行。此模式要求用户手动授予访问权限。请注意,这种情况下需要使用三个斜线,而不是两个。
Localhost 网址和 IP 地址
如需在开发期间匹配任何 localhost 端口,请使用 http://localhost/*。对于 IP 地址,请在路径中指定地址和通配符,如 http://127.0.0.1/* 所示。您还可以使用 http://*:*/* 来匹配 localhost、IP 地址和任何端口。
顶级域名匹配模式
Chrome 不支持顶级域名 (TLD) 的匹配模式。在各个顶级域名 (TLD) 中指定匹配模式,如 http://google.es/*http://google.fr/* 中所示。

示例模式

https://*/*https://*/
匹配使用 https 架构的所有网址。
https://*/foo*
匹配任何主机上使用 https 架构且路径以 foo 开头的网址。匹配项的示例包括 https://example.com/foo/bar.htmlhttps://www.google.com/foo
https://*.google.com/foo*bar
匹配使用 https 架构且位于 google.com 主机上的所有网址,其路径以 foo 开头并以 bar 结尾。匹配示例包括 https://www.google.com/foo/baz/barhttps://docs.google.com/foobar
file:///foo*
匹配路径以 foo 开头的任何本地文件。匹配示例包括 file:///foo/bar.htmlfile:///foo
http://127.0.0.1/*http://127.0.0.1/
匹配主机 127.0.0.1 上使用 http 架构的所有网址。匹配项的示例包括 http://127.0.0.1/http://127.0.0.1/foo/bar.html
http://localhost/*
与任何 localhost 端口匹配。
*://mail.google.com/*://mail.google.com/*
匹配以 http://mail.google.comhttps://mail.google.com 开头的所有网址。