微信小程序上传

后台

 public function upload()
    {
        //要上传文件的临时路径
        $filePath = $_FILES['file']['tmp_name'];
        //阿里云上传对象存储
        $fileName = (new Oss())->uploadFile($filePath);
        return json(['code'=>200,'msg'=>'上传成功','url'=>$fileName]);

    }

封装oss

​
return[
  "accessKeyId"=>"LTAI5tGsyR7ppvCCFWw3Ykee",
    "accessKeySecret"=>"MeQyMHXrKlnUK9nbtcUo4gm2i94p9j",
    "bucket"=>"zhaochongbin",
    "endpoint"=>"oss-cn-hangzhou.aliyuncs.com"
];

​
public function uploadFile($filePath)
    {
        // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
        $accessKeyId = config('oss.accessKeyId');
        $accessKeySecret = config('oss.accessKeySecret');
        // Endpoint以杭州为例,其它Region请按实际情况填写。
        $endpoint = config('oss.endpoint');
        // 存储空间名称
        $bucket = config('oss.bucket');
        // <yourObjectName>上传文件到OSS时需要指定包含文件后缀在内的完整路径,例如abc/efg/123.jpg
        $fileName = date('Y-m-d', time()) . '/' . md5(time() . rand(1111, 9999999)) . '.png';
        try {
            $ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint);
            $result = $ossClient->putObject($bucket, $fileName, file_get_contents($filePath));
        } catch (OssException $e) {
            print $e->getMessage();
        }
        return $result['info']['url'];
    }

index.wxml

<l-textarea  placeholder="说说你的想法吧..."  bind:linblur="getContent"/>

<l-image-picker count="9" bind:linchange="onChangeTap" bind:linremove="removeImage"/>

<l-button bind:tap="pushDiary">发布</l-button>

index.js

Page({

  /**
   * 页面的初始数据
   */
  data: {
     urls:[]
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

  },


  onChangeTap(evn){
     //获取最新上传的所有图片临时路径
     let tempFilePaths = evn.detail.current;
     //定义一个空数组,进行存放上传图片url
     var urlArr = [];
     for (let index = 0; index < tempFilePaths.length; index++) {
       wx.uploadFile({
         url: 'http://www.week.com/api/login/upload', //仅为示例,非真实的接口地址
         filePath: tempFilePaths[index],
         name: 'file',
         success: res => {
           const data = JSON.parse(res.data);
           //do something
           urlArr.push(data.url)
           this.setData({
             urls: urlArr
           })
         }
       })
 
     }

},


 //删除图片,处理数据
 removeImage(event) {
  //图片数组
  let urls = this.data.urls;
  //js根据指定下标删除元素,第一个参数是下标,第二个参数是从这个下标移出几个元素
  urls.splice(event.detail.index, 1)
  this.setData({
    urls
  })
},



  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值