如何跨域访问在线图片实现base64转换?

发布于 2022-09-12 23:41:04 字数 2088 浏览 47 评论 0

油猴脚本获取鼠标处的图片链接data.target.src,可能是微博的图片、百度的图片等,找到在线图片转换base64函数,需要跨域访问

https://www.cnblogs.com/daysm...

油猴子中添加了// @grant GM_xmlhttpRequest

    const copyImage = function(argumentArr, data) {
        var base64URL = ajax(data.target.src,
        function(dataUrl) {
            console.log('结果:', dataUrl)
            return dataUrl;
            }
        )
    }
    //在线图片转换base64
    function toDataURL(src, callback, outputFormat) {
        var img = new Image();
        img.crossOrigin = 'Anonymous';
        img.onload = function() {
            var canvas = document.createElement('CANVAS');
            var ctx = canvas.getContext('2d');
            var dataURL;
            canvas.height = this.naturalHeight;
            canvas.width = this.naturalWidth;
            ctx.drawImage(this, 0, 0);
            dataURL = canvas.toDataURL(outputFormat);
            callback(dataURL);
        };
        img.src = src;
        if (img.complete || img.complete === undefined) {
            img.src = "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///ywAAAAAAQABAAACAUwAOw==";
            img.src = src;
        }
    }
    // ajax 跨域访问公共方法
    function ajax(url, text, element, method, data, headers) {
        if (!!!method)
            method = 'GET';
        // >>>因为Tampermonkey跨域访问(a.com)时会自动携带对应域名(a.com)的对应cookie
        // 不会携带当前域名的cookie
        // 所以,GM_xmlhttpRequest【不存在】cookie跨域访问安全性问题
        // 以下设置默认headers不起作用<<<
        url += text;
        if (!!!headers)
            headers = { 'cookie': '' };
        GM_xmlhttpRequest({
            method: method,
            url: url,
            headers: headers,
            data: data,
            onload: function (res) {
                toDataURL(res.responseText, element);
            },
            onerror: function (res) {
                displaycontainer("连接失败",element);
            }
        });
    }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

晨与橙与城 2022-09-19 23:41:04

跨域时,如果资源服务器不允许的话,前端是不能获取到该资源的,也是为了安全考虑,可以尝试做一层代理,但有些服务器也会做防爬处理。

canvas 中的图片可能来自一些第三方网站。在资源服务器不允许的情况下,使用跨域的图片绘制时会污染画布,这是出于安全考虑。在“被污染”的画布中调用 toBlob() toDataURL() getImageData() 会抛出安全警告。

风蛊 2022-09-19 23:41:04

img.crossOrigin = 'Anonymous';
改为
img.crossOrigin = '*';
如果服务器做了拦截就没办法了

感性 2022-09-19 23:41:04

找到一个特别的解决办法啦,创建一个防止缓存的地址
http://t.zoukankan.com/golovi...

let image = new Image()
image.src = this.networkImg + '?v=' + Math.random()
image.crossOrigin = "*"
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文