I’m building a chrome extension to change the favicon of the newly opened tabs to differentiate them (to know that I did not read them yet), it works generally well except when CSP is applied. but a strange thing is happening:
I open for example a site using a strict CSP like: https://developer.mozilla.org/en-US/docs/Learn/HTML
I use this code to load and image in the page and as favicon
let FAVICON_URLl = '';
// test1: load it in page
const imgg1 = document.createElement('img');
imgg1.src = FAVICON_URLl;
imgg1.style.cssText = 'position:absolute;top:0;border:2px solid black;width:80px;height:80px;z-index:99999;';
document.body.appendChild(imgg1);
// test2: load it as a favicon
const linkk = document.createElement('link');
linkk.type = 'image/png';
linkk.rel = 'icon';
linkk.href = FAVICON_URLl;
document.head.appendChild(linkk);
test1 gaves no error and the picture is displayed without any CSP error.
but test2 gaves this CSP error at document.head.appendChild(linkk);
Refused to load the image
‘…..’ because it
violates the following Content Security Policy directive: “img-src
‘self’ *.githubusercontent.com .googleusercontent.com .gravatar.com
mozillausercontent.com firefoxusercontent.com profile.stage.mozaws.net
profile.accounts.firefox.com mdn.dev
interactive-examples.mdn.mozilla.net
interactive-examples.mdn.allizom.net wikipedia.org
upload.wikimedia.org https://.google-analytics.com
https://.googletagmanager.com www.gstatic.com”.
conclusion:
the image can be used and be displayed on the web page visually when we use it as img.src even if CSP block them, but cannot be used in head link rel tag <link rel="icon" href="...."> if CSP does not allow it.
here they say:
By default, browsers enforce the same-origin policy to prevent a web
page from accessing cross-origin resources. For example, when a
cross-origin image is loaded, even though it’s displayed on the web
page visually, the JavaScript on the page doesn’t have access to the
image’s data. The resource provider can relax restrictions and allow
other websites to read the resource by opting-in with CORS.
https://web.dev/articles/security-headers
But what I do not understand is why in <link rel="icon" href= is not allowed, it is not javascript, and I’m not accessing it with javascript, so the browser should not block it because of CSP, it should be treated like img.src! no?
Why is this happening? I had read all what I could find about CSP but could not find anything that mentions this behavior. If this is expected, please do you have any source about this behavior? or an explanation at least?






