uniApp 小程序保存图片到本地实现方案

原文: https://mp.weixin.qq.com/s/hTqlpOdLncDE2m7mQaHVDA

背景

壁纸、头像类型小程序保存需要支持用户可以保存图片到本地。

实现流程

alt

判断授权

uni.getSetting({
    success: function(res) {
        if (res.authSetting['scope.writePhotosAlbum']) {
             // 判断授权成功开始下载
            ...
        } else if (res.authSetting['scope.writePhotosAlbum'] === undefined) {
            // 判断授权成功开始下载
            ...
        } else {
            // 判断授权失败,弹框提示用户授权
            ...
        }
    },
    fail: function(error) {
        // 失败错误信息输出
        console.log(error, 'getSetting')
    }
})

获取授权

uni.showModal({
    title: '提示',
    content: '需要授权保存相册',
    showCancel: true,
    success: function(resShow) {
        if (resShow.confirm) {
            // 弹出用户点击同意
            uni.openSetting({
                scope: 'scope.writePhotosAlbum',
                success: function(resOpen) {
                    // 授权成功开始下载
                },
                fail: function(errorOpen) {
                    // 授权失败输出错误信息
                    console.log(errorOpen, 'openSetting')
                }
            })
        } else {
            // 用户取消授权提示用户
            that.showToast('取消授权无法下载')
        }
    }
})

下载图片

uni.downloadFile({
    url: url,
    filePath: uni.env.USER_DATA_PATH + '/' + new Date().getTime() + '.jpg',
    success(res) {
        if (res.statusCode === 200) {
            // 下载成功开始保存图片
            ...
        }
    },
    fail(error) {
        // 下载失败输出错误信息
        console.log('下载失败', error)
    }
})

保存图片

uni.saveImageToPhotosAlbum({
    filePath: filePath,
    success: function() {
        console.log('保存成功')
    },
    fail: function(error) {
        console.log('保存失败', error)
    }
})

注: 上述流程只是简单描述图片保存到手机相册的流程,生产环境还有记录下载次数、弹出广告等流程。

G|Z|号回复 壁纸 即可获取全部源码,免费开源,可商用

本文由 mdnice 多平台发布

### 如何在 UniApp实现图片保存本地相册的功能 在 UniApp 开发中,可以通过调用 `uni.saveImageToPhotosAlbum` API 来实现图片保存到用户的手机相册中的功能[^1]。此 API 支持多种平台,包括 Android、iOS 和微信小程序等。 #### 1. 调用 saveImageToPhotosAlbum 方法 该方法用于将指定路径下的图片保存至系统的相册中。以下是其基本参数说明: - **filePath**: 需要保存图片文件路径 (String 类型),支持临时路径和永久路径。 下面是一个简单的代码示例来演示如何使用这个 API: ```javascript // 假设已知图片的 filePath const filePath = '/path/to/your/image.jpg'; uni.saveImageToPhotosAlbum({ filePath: filePath, success(res) { console.log('成功保存图片', res); uni.showToast({ title: '图片保存' }); }, fail(err) { console.error('保存失败:', err); // 如果是因为未授权导致失败,则引导用户打开设置页面重新授予权限 if (err.errMsg.includes('auth deny')) { uni.showModal({ content: '需要您授予保存图片相册的权限', confirmText: '设置', success(modalRes) { if (modalRes.confirm) { uni.openSetting(); // 打开应用设置界面 } } }); } else { uni.showToast({ icon: 'none', title: '保存失败,请重试' }); } } }); ``` 上述代码展示了如何处理保存操作的成功与失败情况,并特别注意到了因权限不足而导致的操作失败情形[^2]。 #### 2. 请求并管理权限 为了能够正常执行保存动作,在某些平台上可能还需要额外请求用户的存储或相机权限。这通常通过 `uni.authorize` 或者直接尝试触发保存时由系统弹窗询问完成。如果之前被拒绝过权限,则可以利用 `uni.getSetting` 查看当前状态以及指引用户前往开启相应选项[^3]。 对于微信环境而言,除了基础的读写外部储存许可外,还需确保服务器地址已被加入业务域名白名单之中,否则即使拥有足够的权限也可能无法顺利完成下载任务[^4]。 #### 3. 处理不同端上的差异性 由于目标运行环境的不同(如 H5 vs Native App ),实际开发过程中可能会遇到一些细微差别。比如安卓机种有时会要求先加载再另存新图;而对于 iOS 设备来说则更倾向于直接提供最终版本给它自行决定后续流程等等。因此建议开发者依据官方文档针对各个场景分别测试验证最佳实践方案。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值