开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 13721|回复: 9
收起左侧

[技术分享] 小程序前端如何优雅得上传图片 之 【阿里云OSS篇】

[复制链接]
结帖率:100% (3/3)
发表于 2021-11-25 17:20:22 | 显示全部楼层 |阅读模式   河南省安阳市
一说到OSS 可能大家都是想到从后端来操作得OSS  今天我给大家带来一篇 前端上传文件到阿里云OSS

话不多说 搞活  先看看阿里云得

https://help.aliyun.com/document_detail/92883.html?spm=5176.8465980.help.dexternal.4e701450ieeqxk

根据api文档我们可以进行封装下面得方法:

[JavaScript] 纯文本查看 复制代码
const uploadFile = function(filePath, path, successc, failc) {
  if (!filePath || filePath.length < 9) {
    wx.showModal({
      title: '图片错误',
      content: '请重试',
      showCancel: false,
    })
    return;
  }
  //存放图片命名格式:自定义时间戳给图片名字(可以自己改)
  const aliyunFileKey = path + new Date().getTime() + Math.floor(Math.random() * 150) + '.png';

  const aliyunServerURL = env.uploadImageUrl; //OSS地址,https
  const accessid = env.OSSAccessKeyId;
  const policyBase64 = getPolicyBase64();
  const signature = getSignature(policyBase64);

  wx.uploadFile({
    url: aliyunServerURL, //开发者服务器 url
    filePath: filePath, //要上传文件资源的路径
    name: 'file', //必须填file
    formData: {
      'key': aliyunFileKey,
      'policy': policyBase64,
      'OSSAccessKeyId': accessid,
      'signature': signature,
      'success_action_status': '200',
    },
    success: function(res) {
      if (res.statusCode != 200) {
        failc(new Error('上传错误:' + JSON.stringify(res)))
        return;
      }
      successc(aliyunServerURL + aliyunFileKey);
    },
    fail: function(err) {
      err.wxaddinfo = aliyunServerURL;
      failc(err);
    },
  })
}

const getPolicyBase64 = function() {
  let date = new Date();
  date.setHours(date.getHours() + env.timeout);
  let srcT = date.toISOString();
  const policyText = {
    "expiration": srcT, //设置该Policy的失效时间,超过这个失效时间之后,就没有办法通过这个policy上传文件了 
    "conditions": [
      ["content-length-range", 0, 5 * 1024 * 1024] // 设置上传文件的大小限制,5mb
    ]
  };

  const policyBase64 = base64.encode(JSON.stringify(policyText));
  return policyBase64;
}

const getSignature = function(policyBase64) {
  const accesskey = env.AccessKeySecret; 
  const bytes = Crypto.HMAC(Crypto.SHA1, policyBase64, accesskey, {
    asBytes: true
  });
  const signature = Crypto.util.bytesToBase64(bytes);
  return signature;
}


最主要得是你 OSS上传地址、AccessKeyId、AccessKeySecret  

然后就可以调用方法进行上传了

[JavaScript] 纯文本查看 复制代码
//上传图片
          //图片路径可自行修改【(这二个参数就是你oss地址目录的下一个路径目录,比如:)】
          uploadImage(res.tempFilePaths, 'images/',
            function (result) {
              console.log("======上传成功图片地址为:", result);
              self.setData({
                online_img:result
              })
              
              //这个result就是返给你上传到oss上的地址链接
              wx.hideLoading();
            }, function (result) {
              console.log("======上传失败======", result);
              
              wx.hideLoading()
            }
          )


最后给大家附上一份 Gitee 源码地址:
https://gitee.com/Ldormant/ali-oss



技术交流+q 1164526353

有老板下单得也可以联系我

评分

参与人数 1好评 +1 精币 +3 收起 理由
冰点 + 1 + 3 感谢分享,很给力!~

查看全部评分

发表于 2024-11-2 15:59:20 高大上手机用户 | 显示全部楼层   湖南省永州市
看看
回复 支持 反对

使用道具 举报

发表于 2021-12-25 21:12:57 | 显示全部楼层   四川省宜宾市
666666666666666666666666666666
回复 支持 反对

使用道具 举报

结帖率:89% (17/19)

签到天数: 9 天

发表于 2021-12-13 09:41:17 | 显示全部楼层   广东省东莞市
好东西必须下载。。
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 7 天

发表于 2021-12-3 05:18:15 | 显示全部楼层   广西壮族自治区南宁市
好东西必须下载。。。。
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 7 天

发表于 2021-12-3 03:14:02 | 显示全部楼层   广西壮族自治区南宁市
感谢大佬分享
回复 支持 反对

使用道具 举报

结帖率:60% (6/10)
发表于 2021-11-27 21:47:46 | 显示全部楼层   江苏省南京市

感谢大佬分享
回复 支持 反对

使用道具 举报

签到天数: 4 天

发表于 2021-11-27 15:29:59 | 显示全部楼层   四川省广安市
谢谢分享
回复 支持 反对

使用道具 举报

发表于 2021-11-26 04:27:22 | 显示全部楼层   德国
感谢发布原创作品,因你更精彩!
回复 支持 反对

使用道具 举报

头像被屏蔽
发表于 2021-11-25 17:29:40 | 显示全部楼层   四川省绵阳市
感谢大佬分享
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表