tp+微信小程序实现多图片上传

        在微信小程序上,我们必不可少的会需要上传图片,更换头像,发表信息等等,都需要上传,今天我们就学习一下微信小程序基于thinkPHP如何实现多图片上传。

        其实图片上传,在thinkPHP也好,在laravel框架也罢,代码几乎差不多,只是一些函数调用上有所区别,但是想应用在laravel框架也是可以的。

        我们先从小程序上开始说起,图片上传分为单图片上传和多图片上传,单图片上传较为简单明了,通常用在更换头像,多图片上传比单图片上传多了一些逻辑数组处理,但是也不难。

        要实现图片上传,首先要调用 wx.chooseImage 函数。该函数的功能是从本地相册选择图片或使用相机拍照,因此我们需要给上传图片的按钮绑定一个事件,触发这个事件之后首先就要调用这个函数。

//按钮绑定
<button catchtap="imageUpload">图片上传</button>

        以下为函数的各属性值,详情访问链接

        https://developers.weixin.qq.com/miniprogram/dev/api/media/image/wx.chooseImage.html

         通常情况下,个人只会用 count 属性和 success 成功回调函数,count 这个属性可以决定你上传的图片个数,最大为9张,最少为1张,一张就是单图片上传。代码实例如图下

//imageUpload 按钮触发事件

imageUpload:function(){
    let _this = this;    //将this赋给一个变量方便后面调用
    wx.chooseImage({    //选择图片方法
      count: 9,        //图片数量 1~9
      success:function(image){    //成功回调函数
          
          
        }
    })
}

         选择成功之后,因为是多图片,我们的 image 里不止有一张图,但是在后台上传云端却是单图片上传,因此我们需要使用 for 循环一下我们的 image ,以此来实现多张图片的上传。代码示例如下

imageUpload:function(){
    let _this = this;
    wx.chooseImage({
      count: 9,
      success:function(image){
          let imagePath = image.tempFilePaths;    //获取image中保存图片路径的数组
          var images = [];                        //定义一个空的数组方便后面使用
          //imagePath中包含了这个数组的长度,因此我们在设置循环的之后直接调length即可
          for (let i=0;i<imagePath.length;i++){    
            
           })
          }
          
      }
    })
}

        在 for 循环中,我们选择了几张图片,那么上传方法就会调用几次,因为我们获取的数组是索引数组,下标是从0开始,因此多次循环我们也不会上传同一张图片,接下来我们就可以调用 wx.uploadFile 函数进行图片上传。

        wx.uploadFile 函数及属性详情:

https://developers.weixin.qq.com/miniprogram/dev/api/network/upload/wx.uploadFile.html

imageUpload:function(){
    let _this = this;
    wx.chooseImage({
      count: 9,
      success:function(image){
          let imagePath = image.tempFilePaths;
          var images = [];
          for (let i=0;i<imagePath.length;i++){
            wx.uploadFile({
            filePath: imagePath[i],    //图片路径
            name: 'image',        //传到后台的图片名称
            url: 'http://www.class14.com/image',       //上述图片的后台路由
            success:function(res){        //成功回调函数
              
            }
           })
          }
      }
    })
  },

        接下来我们就需要在后台进行数据的处理,因为我使用的是七牛云,因此我们在写代码之前需要先安装。

composer require qiniu/php-sdk

         后台就很简单,我们只需要就收文件,定义图片名,定义七牛云的 AK、SK、bucket,然后执行上传代码即可。

public function image(Request $request){
        //接收文件,因为建立在for循环之下,所以我们只会接收到一张图
        $image = $request->file('image');
        //设置文件名,这里不懂的可以dd一下我们接收的图片对象即可
        //因为我们接收到的是对象,不是数组,所以需要使用 getOriginalName 获取上传的图片名
        //rand()生成随机数   substr()字符串截取   strrops()从字符串最后一次出现开始
        $name = rand(11111,99999).substr($image->getOriginalName(),strrpos($image
                ->getOriginalName(),'.'));
        //getPathName   获取图片临时路径
        $path = $image->getPathname();
        
        //七牛云AK
        $accessKey = "*****"; 
        //七牛云SK       
        $secretKey = "*****";        
        $bucket = "*****";        //需要上传到的筒名

        $uploadMgr = new UploadManager();       //实例化图片上传
        $auth = new Auth($accessKey, $secretKey);        //AK、SK验证
        $token = $auth->uploadToken($bucket);        //验证成功调筒名
        //进行上传
        list($ret, $error) = $uploadMgr->putFile($token, $name, $path);        
        $url = "http://rd5bmceib.hn-bkt.clouddn.com/".$name;
        if ($error == ''){
            return json(['code'=>200,'msg'=>'上传成功','data'=>$url]);
        }
    }

        到此我们的图片已经上传到七牛云当中,接下来我们就该处理前台的数据,如何保存后端返回的图片在线链接。这时候就会用到我们在 for 循环之前定义的空数组,我们需要把循环 n 次的返回出来的多个图片在线连接保存在这个数组当中,这个数组不能放在循环内,放在循环内就会出现数据覆盖的情况。代码示例如下

imageUpload:function(){
    let _this = this;
    wx.chooseImage({
      count: 9,
      success:function(image){
          let imagePath = image.tempFilePaths;
          var images = [];
          for (let i=0;i<imagePath.length;i++){
            wx.uploadFile({
            filePath: imagePath[i],
            name: 'image',
            url: 'http://www.class14.com/image',
            success:function(res){
              //将后端返回的数据通过JSON.parse转换为数组形式
              var json = JSON.parse(res.data) 
              if (json.code == 200) {    
                images[i] = json.data    //i 为我们在循环的下标
                //传到data中定义好的一个数组,就可以实现上传图片展示
                _this.setData({    
                  imageFile:images
                })
              }
            }
           })
          }
      }
  },

        多图片上传已经上传成功.

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

旧客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值