为什么Firefox和Chrome对于tabs.Tab.favIconUrl返回不同的结果?而我该如何解决呢? 问题为什么这是个问题我该如何解决?

问题描述

问题

我正在编写一个使用该标签的图标的WebExtension。我以这种方式检索当前标签页图标的URL:

var API = chrome || browser;
API.tabs.query({ active: true,currentwindow: true },function (tabs) {
    if (tabs[0] && tabs[0].favIconUrl) {
        console.log(tabs[0].favIconUrl);
    }
});

在Firefox中,控制台记录了表示图像数据的image/x-icon数据URI,但是在Chrome中,控制台记录了指向图标位置的纯URL。例如,如果我在Firefox的stackoverflow.com中运行此命令,则会得到:



但是在Chrome浏览器中,我得到了:

https://cdn.sstatic.net/Sites/stackoverflow/Img/favicon.ico?v=ec617d715196

为什么这是个问题

我需要数据URI,因为我想在自己的画布上绘制收藏夹图标:

var canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
const img = new Image();
img.crossOrigin = 'anonymous';
img.src = tabs[0].favIconUrl;
img.decode()
    .then(() => {
        ctx.drawImage(img,size,size);
        // do other stuff on ctx ...
    })
    .catch(err => console.log(err));

这在Chrome中不起作用,因为网站图标URL指向其他域,因此我遇到了此错误Access to image at 'https://cdn.sstatic.net/Sites/stackoverflow/Img/favicon.ico?v=ec617d715196' from origin 'https://stackoverflow.com' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

以及图像DOMException: The source image cannot be decoded.的解码错误

我该如何解决

MozillaGoogle都为Tab.favIconUrl列出了相同的描述,并且没有提及行为here的这种差异。我还可以如何以跨浏览器兼容的方式检索活动标签的网站图标数据URI?

解决方法

在 Chrome 中,您可以使用网站图标缓存 url chrome://favicon/https://google.com 而不是依赖 Tabs API。请参阅此示例:

Reliably getting favicons in Chrome extensions,chrome://favicon?

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...