首发】JS将图片转化为base64编码,并实现点击下载,js实现图片下载的实操博客

网友投稿 931 2022-05-30

背景需求

在前端的工作中,经常碰到点击下载图片的需求,但是有一种情况大家经常碰到,就是点击-之后,在浏览器窗口默认打开了,并没有调用浏览器进行下载

如果你正在完善这个需求,一直解决不了,恭喜你看到了这篇文章。

在正式开始前,先说一下整体的逻辑

JS实现下载图片非常简单,网上有很多的分享

将图片转换为base64

为了防止大图下载失败,将base64转换为 blob;

下载图片。

编码时间

整体逻辑代码如下所示

图片点击下载

答题时间

很多教程到此就结束了,但是并没有说明以下几个问题

'crossOrigin', 'Anonymous':canvas 跨域问题

如果没有该内容将会出现错误内容:canvas无法执行toDataURL方法,即污染的画布无法输出,但是这里其实还存在一个问题,就是如果你使用的是 cdn 加速的静态图片,那还是无法跨域,解决的亮点在于配置 CDN HTTP头配置跨域资源共享(CORS),从而解决该问题,如果你没有运维权限,可以联系运维工程师,在CDN后台参考下述配置。

一定让 CDN 的响应头包含如下配置 Access-Control-Allow-Origin:*,当然仅开启某些域名跨域访问也是可以的,看需求。

如果你使用的不是CDN,而是其它服务器,但服务和资源不在一个域名下

以下内容使用 Nginx 进行介绍。

【首发】JS将图片转化为base64编码,并实现点击下载,js实现图片下载的实操博客

在静态资源服务器配置如下内容。

location ^~ /静态资源文件夹/ { alias /www/wwwroot/静态资源文件夹/; # 开启允许跨域访问 add_header 'Access-Control-Allow-Origin' '*'; }

我想,到这里你已经能完成 js 实现图片下载 这一操作了

这里还会衍生出一个面试问题,你知道 canvas 污染么?

记录时间

2022年度 Flag,写作的

563

/ 1024 篇。

可以

关注

我,

我、

评论

我、

我啦。

CDN

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:学妹一反常态主动联系我,我要不要答应帮她?
下一篇:X牙直播数据采集,为数据分析做储备,Python爬虫120例之第24例
相关文章