CSP: default-src
The HTTP Content-Security-Policy
(CSP) default-src
directive serves as a fallback for the other CSP fetch directives. For each of the following directives that are absent, the user agent looks for the default-src
directive and uses this value for it:
child-src
connect-src
font-src
frame-src
img-src
manifest-src
media-src
object-src
prefetch-src
script-src
script-src-elem
script-src-attr
style-src
style-src-elem
style-src-attr
worker-src
CSP version | 1 |
---|---|
Directive type | Fetch directive |
Syntax
One or more sources can be allowed for the default-src
policy:
Content-Security-Policy: default-src <source>;
Content-Security-Policy: default-src <source> <source>;
Sources
<source>
can be any one of the values listed in CSP Source Values.
Note that this same set of values can be used in all fetch directives (and a number of other directives).
Examples
No inheritance with default-src
If there are other directives specified, default-src
does not influence them. The following header:
Content-Security-Policy: default-src 'self'; script-src https://example.com
is the same as:
Content-Security-Policy: connect-src 'self';
font-src 'self';
frame-src 'self';
img-src 'self';
manifest-src 'self';
media-src 'self';
object-src 'self';
script-src https://example.com;
style-src 'self';
worker-src 'self'
Firefox default-src: none
SVG sprite blocking issue
CSP guidelines often recommend starting with default-src 'none'
to lock down all resource loading and then adding further directives to open up the policy, allowing you to load just the resources you need. For example, to allow same-origin loading of images only:
Content-Security-Policy: default-src 'none'; img-src 'self'
However, there is a problem here. If you are embedding SVG sprites defined in external files via the <use>
element, for example:
<svg>
<use href="/images/icons.svg#icon"/>
</svg>
your SVG images will be blocked in Firefox if you have a default-src 'none'
policy set. Firefox does not treat the SVG as an embedded image like other browsers do, therefore img-src 'self'
will not allow them to be loaded. You need to use default-src 'self'
if you want your external sprites to load in Firefox (see bug 1773976 and this CSP spec issue for more information).
Alternatively, if the default-src 'none'
policy is a hard requirement, you can include the SVG sprites inline in the HTML page:
<body>
<svg style="display: none">
<symbol id="icon" viewBox="0 0 24 24">
<path d="…" />
</symbol>
</svg>
…
<svg>
<use href="#icon" />
</svg>
</body>
Specifications
Specification |
---|
Content Security Policy Level 3 # directive-default-src |
Browser compatibility
BCD tables only load in the browser