?常规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,否则下载不了
如我自己的流:

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)
}
})
}
})
},