javascript使用链接跨域下载图片
网络编程 2021-07-04 15:01www.168986.cn编程入门
这篇文章主要介绍了javascript使用链接跨域下载图片,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
前言
图片是最常见的静态资源文件,可以从本地、外链获取图片,或者使用base64码展示。而canvas的toDataUrl() API可以将图片转base64码,然后模拟点击事件即可下载图片。
外链下载
在本地或者网站下载外链url图片时涉及到跨域,跨域会暴露自己的隐私,浏览器对跨域请求进行了限制,故需要设置crossOrigin为anonymous来允许跨域,浏览器会为这张图片的请求头附带Origin信息,告诉静态资源服务器,请在响应头中附带Aess-Control-Allow-Methods、Aess-Control-Allow-Origin,以便浏览器放行。
代码示例如下
eventEmitter.js
/ 事件触发器 @Author: wujiang @Date: 2018-11-11 22:50:43 @Last Modified by: wujiang @Last Modified time: 2018-11-11 23:39:40 / const EventEmitter = require('events') class MyEmitter extends EventEmitter {} const myEmitter = new MyEmitter() export default myEmitter
backend.js
import eventEmitter from './mon/eventEmitter' // 图片下载对象 let downloadedImg = null // 待下载文件名 let fileName = null // 监听是否获取图片地址 eventEmitter.addListener('getHref', href => { imatateDownloadByA(href, fileName) }) / base64下载图片(可跨域) @param {} img @param {String} filename 文件名 / function downloadImg (imgUrl, filename) { fileName = filename startDownloadImg(imgUrl, getImgDataUrl) } / 开始下载图片之前 @param {String} imgUrl @param {Function} callback / function startDownloadImg (imgUrl, callback) { let imageURL = imgUrl downloadedImg = new Image() downloadedImg.crossOrigin = 'Anonymous' downloadedImg.src = imageURL downloadedImg.addEventListener('load', callback, false) } / 获取图片下载base64字符串 @param {DOMimg} domimg / function getImgDataUrl () { const canvas = document.createElement('canvas') const context = canvas.getContext('2d') const width = downloadedImg.width || downloadedImg.naturalWidth const height = downloadedImg.height || downloadedImg.naturalHeight const imgSrc = downloadedImg.src let type = imgSrc.substring(imgSrc.lastIndexOf('.') + 1) let dtype = type === 'jpg' ? 'jpeg' : 'png' canvas.width = width canvas.height = height context.drawImage(downloadedImg, 0, 0) eventEmitter.emit('getHref', canvas.toDataURL(`image/${dtype}`)) } / 通过a标签模拟下载 @param {String} href @param {String} filename / function imatateDownloadByA (href, filename) { const a = document.createElement('a') a.download = filename a.style.display = 'none' a.href = href document.body.appendChild(a) a.click() a.remove() window.URL.revokeObjectURL(href) } downloadImg('https://img.alicdn./imgextra/i2/54199406/O1CN012JLzreAxzn1xhNP_!!54199406.jpg', '测试')
注意
若有跨域的错误提示出现,则需后台服务器进行跨域设置。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程