Match patterns
Host permissions and content script matching are based on a set of URLs defined by match patterns. A match pattern is essentially a URL that begins with a permitted scheme (http, https, file, or ftp, and that can contain '*' characters. The special pattern <all_urls> matches any URL that starts with a permitted scheme. Each match pattern has 3 parts:
- scheme—for example, - httpor- fileor- *Access to- fileURLs isn't automatic. The user must visit the extensions management page and opt in to- fileaccess for each extension that requests it.
- host—for example, - www.google.comor- *.google.comor- *; if the scheme is- file, there is no host part
- path—for example, - /*,- /foo*, or- /foo/bar. The path must be present in a host permission, but is always treated as- /*.
Here's the basic syntax:
<url-pattern> := <scheme>://<host><path>
<scheme> := '*' | 'http' | 'https' | 'file' | 'ftp' | 'urn'
<host> := '*' | '*.' <any char except '/' and '*'>+
<path> := '/' <any chars>The meaning of '*' depends on whether it's in the scheme, host, or path part. If the scheme is *, then it matches either http or https, and not file, ftp, or urn. If the host is just *, then it matches any host. If the host is *._hostname_, then it matches the specified host or any of its subdomains. In the path section, each '*' matches 0 or more characters. The following table shows some valid patterns.
Note: urn scheme is available since Chrome 91.
| Pattern | What it does | Examples of matching URLs | 
|---|---|---|
| https://*/* | Matches any URL that uses the httpsscheme | https://www.google.com/ https://example.org/foo/bar.html | 
| https://*/foo* | Matches any URL that uses the httpsscheme, on any host, as long as the path starts with/foo | https://example.com/foo/bar.html https://www.google.com/foo | 
| https://*.google.com/foo*bar | Matches any URL that uses the httpsscheme, is on a google.com host (such as www.google.com, docs.google.com, or google.com), as long as the path starts with/fooand ends withbar | https://www.google.com/foo/baz/bar https://docs.google.com/foobar | 
| https://example.org/foo/bar.html | Matches the specified URL | https://example.org/foo/bar.html | 
| file:///foo* | Matches any local file whose path starts with /foo | file:///foo/bar.html file:///foo | 
| http://127.0.0.1/* | Matches any URL that uses the httpscheme and is on the host 127.0.0.1 | http://127.0.0.1/ http://127.0.0.1/foo/bar.html | 
| *://mail.google.com/* | Matches any URL that starts with http://mail.google.comorhttps://mail.google.com. | http://mail.google.com/foo/baz/bar https://mail.google.com/foobar | 
| urn:* | Matches any URL that starts with urn:. | urn:uuid:54723bea-c94e-480e-80c8-a69846c3f582 urn:uuid:cfa40aff-07df-45b2-9f95-e023bcf4a6da | 
| <all_urls> | Matches any URL that uses a permitted scheme. (See the beginning of this section for the list of permitted schemes.) | http://example.org/foo/bar.html file:///bar/baz.html | 
Here are some examples of invalid pattern matches:
| Bad pattern | Why it's bad | 
|---|---|
| https://www.google.com | No path | 
| https://*foo/bar | '*' in the host can be followed only by a '.' or '/' | 
| https://foo.*.bar/baz  | If '*' is in the host, it must be the first character | 
| http:/bar | Missing scheme separator ("/" should be "//") | 
| foo://* | Invalid scheme | 
Some schemes are not supported in all contexts.
Exclude matches and globs
Specified page matching is customizable by including the following fields in a declarative registration.
| Name | Type | Description | 
|---|---|---|
| exclude_matches | array of strings | Optional. Excludes pages that this content script would otherwise be injected into. See Match Patterns for more details on the syntax of these strings. | 
| include_globs | array of strings | Optional. Applied after matchesto include only those URLs that also match this glob. Intended to emulate the@includeGreasemonkey keyword. | 
| exclude_globs | array of string | Optional. Applied after matchesto exclude URLs that match this glob. Intended to emulate the@excludeGreasemonkey keyword. | 
The content script will be injected into a page if both of the following are true:
- Its URL matches any matchespattern and anyinclude_globspattern
- The URL doesn't also match an exclude_matchesorexclude_globspattern. Because thematchesproperty is required,exclude_matches,include_globs, andexclude_globscan only be used to limit which pages will be affected.
The following extension injects the content script into https://www.nytimes.com/ health but not into https://www.nytimes.com/ business .
{
  "name": "My extension",
  ...
  "content_scripts": [
    {
      "matches": ["https://*.nytimes.com/*"],
      "exclude_matches": ["*://*/*business*"],
      "js": ["contentScript.js"]
    }
  ],
  ...
}chrome.scripting.registerContentScripts([{
  id : "test",
  matches : [ "https://*.nytimes.com/*" ],
  excludeMatches : [ "*://*/*business*" ],
  js : [ "contentScript.js" ],
}]);Glob properties follow a different, more flexible syntax than match patterns. Acceptable glob strings are URLs that may contain "wildcard" asterisks and question marks. The asterisk * matches any string of any length, including the empty string, while the question mark ? matches any single character.
For example, the glob https://???.example.com/foo/* matches any of the following:
- https://www.example.com/foo/bar
- https://the.example.com/foo/
However, it does not match the following:
- https://my.example.com/foo/bar
- https://example.com/foo/
- https://www.example.com/foo
This extension injects the content script into https://www.nytimes.com/arts/index.html and https://www.nytimes.com/jobs/index.html, but not into https://www.nytimes.com/sports/index.html:
{
  "name": "My extension",
  ...
  "content_scripts": [
    {
      "matches": ["https://*.nytimes.com/*"],
      "include_globs": ["*nytimes.com/???s/*"],
      "js": ["contentScript.js"]
    }
  ],
  ...
}This extension injects the content script into https://history.nytimes.com and https://.nytimes.com/history, but not into https://science.nytimes.com or https://www.nytimes.com/science:
{
  "name": "My extension",
  ...
  "content_scripts": [
    {
      "matches": ["https://*.nytimes.com/*"],
      "exclude_globs": ["*science*"],
      "js": ["contentScript.js"]
    }
  ],
  ...
}One, all, or some of these can be included to achieve the correct scope.
{
  "name": "My extension",
  ...
  "content_scripts": [
    {
      "matches": ["https://*.nytimes.com/*"],
      "exclude_matches": ["*://*/*business*"],
      "include_globs": ["*nytimes.com/???s/*"],
      "exclude_globs": ["*science*"],
      "js": ["contentScript.js"]
    }
  ],
  ...
}