uniapp微信小程序下载base64图片流或https图片

常规https的图片下载是这样的

复制代码
const urlPath = 'https://test/logo.png'
uni.downloadFile({
	url: urlPath,
	success(res){
		// 这时会产生一个临时路径,在应用本次启动期间可以正常使用。
		if (res.statusCode == 200) {
			// 需要将图片保存到相册
			uni.saveImageToPhotosAlbum({
				filePath: res.tempFilePath, // 图片文件路径,可以是临时文件路径也可以是永久文件路径,不支持网络图片路径
				success(res){
					uni.showToast({
						title: '保存成功',
						icon: 'none'
					})
					// 如果保存成功需要打开查看,请使用以下方法,同时也支持打开文件
					uni.openDocument({
						filePath: res.savedFilePath,
						success(res){},
						fail(err){
							uni.showToast({
		                        title: '手机不支持该文件类型,请安装wps或office应用',
		                        icon: 'none'
		                    })
						}
					})
				},
				fail(err){
				uni.showToast({
				  title: '图片保存失败',
				  icon: 'none'
				})
				}
			})
		} else {
			uni.showToast({
			  title: '下载失败,请稍后再试',
			  icon: 'none'
			})
		}
	},
	fail(err) {
		 uni.showToast({
		    title: '下载失败,请稍后再试',
		    icon: 'none'
		 })
     }
})

下面来说一下后端返回base64的文件流,是如何下载的

必须把返回的流去掉这一部分:data:image/png;base64,否则下载不了

如我自己的流:

java 复制代码

java 复制代码
downImg(){
        var byte=this.codeImg.replace("data:image/png;base64,","");
        const fs = uni.getFileSystemManager(); //全局唯一的文件管理器
        var number = Math.random();
        fs.writeFile({
          filePath: wx.env.USER_DATA_PATH + '/code' + number + '.png',
          data: byte,
          encoding: "base64",
          success(res) {
            uni.saveImageToPhotosAlbum({ //保存为png格式到相册
              filePath: wx.env.USER_DATA_PATH + '/code' + number + '.png',
              success: function (res) {
                uni.showToast({ title: "下载成功", icon: "success" });
              },
              fail: function (err) {
                console.log(err)
              }
            })
          }
        })
      },
相关推荐
开发加微信:hedian11613 分钟前
微信推客小程序系统开发技术实践
微信·小程序
Python大数据分析1 小时前
uniapp微信小程序商品列表数据分页+本地缓存+下拉刷新+图片懒加载
缓存·微信小程序·uni-app
机构师1 小时前
<uniapp><指针组件>基于uniapp,编写一个自定义箭头指针组件
javascript·uni-app·vue·html
小白_ysf1 小时前
uniapp和vue3项目中引入echarts 、lime-echart(微信小程序、H5等)
微信小程序·uni-app·echarts·h5·lime-echart
imHere·1 小时前
UniApp 分包异步化配置及组件引用解决方案
微信小程序·uni-app·分包
说私域3 小时前
开源AI智能名片链动2+1模式S2B2C商城小程序在淘宝公域流量运营中的应用研究
人工智能·小程序·开源
2501_916013743 小时前
App 上架全流程指南,iOS App 上架步骤、App Store 应用发布流程、uni-app 打包上传与审核要点详解
android·ios·小程序·https·uni-app·iphone·webview
canglingyue4 小时前
微信小程序加速计开发指南
微信小程序·小程序
0x0004 小时前
Uniapp - 自定义 Tabbar 实现
前端·uni-app
SY_FC4 小时前
uniapp发布成 微信小程序 主包内 main.wxss 体积太大
微信小程序·小程序·uni-app