当前位置: 首页 > 工具软件 > Niushop > 使用案例 >

Niushop APP端头像上传问题

盖昊东
2023-12-01

这几天修改niusop,遇到niushop APP端头像无法上传问题,以下是解决方案;

niushop版本 4.1.12

后台修改:

1. /app/api/controller/Member.php中

modifyheadimg()方法 修改成:


    /**
     * 修改会员头像
     * @return string
     */
    public function modifyheadimg()
    {
        $token = $this->checkToken();
        if ($token['code'] < 0) return $this->response($token);
        $headimg      = isset($this->params['headimg']) ? $this->params['headimg'] : '';
        // var_dump($headimg);die;
        $member_model = new MemberModel();
     // $res          = $member_model->editMember(['headimg' => $headimg], [['member_id', '=', $token['data']['member_id'], ['site_id', '=', $this->site_id]]]);
      $res   = $member_model->editimg(    $headimg ,  $token['data']['member_id']);
      return $this->response($res);
      
      
    }

模型路径:app/model/member/Member.php中  记得要清除一下缓存,不然需要重新登录,改头像才能生效

新增方法:

    
    //修改头像新增代码
       public function editimg($img, $member_id)
        {
        
        $res=   Db::name('member')
            ->where('member_id', $member_id)
            ->update(['headimg' => $img]);
            
               Cache::clear();    //清除缓存
          
          if (is_dir('runtime/schema')) {  //清除缓存
                        rmdirs("schema");
                    }  


         return $this->success($res);        
        
        }


    //修改头像新增代码结束

前端修改思路:

H5的环境下,图片路径直接变Base64编码了,直接拿着可以用,但是在APP端 不会直接变Base64编码,需要转换一下,不然不会上传成功。

具体如下:

路径:@/components/img-cropping/cropping.vue

修改内容400行左右:

(上部分是指,如果在H5环境下 怎么怎么样,下边是非H5环境下怎么怎么样,)

	// #ifndef MP-ALIPAY
			uni.canvasToTempFilePath(
				{
					x: x,
					y: y,
					width: width,
					height: height,
					destWidth: expWidth,
					destHeight: expHeight,
					canvasId: 'avatar-canvas',
					fileType: this.fType,
					quality: this.qlty,
					success: r => {
							console.log(",,,1111111111,,,,",JSON.stringify(r));
						r = r.tempFilePath;
						// #ifdef H5
						this.btop(r).then(r => {
							console.log(",,,2222222,,,,",this.base64);
							this.$emit('upload', {
								avatar: this.imgSrc,
								path: r,
								index: this.indx,
								data: this.rtn,
								base64: this.base64 || null
							});
							return;
						});
						// #endif
						
						// #ifndef H5
						     const savedFilePath = r 
						        const path = plus.io.convertLocalFileSystemURL(savedFilePath) //绝对路径
						        const fileReader = new plus.io.FileReader()
						        fileReader.readAsDataURL(path)
						        fileReader.onloadend = (res) => { //读取文件成功完成的回调函数
						            //console.log(".................",res.target.result) //输出base64内容
						          this.$emit('upload', {
						          	avatar: this.imgSrc,
						          	path: res.target.result,
						          	index: this.indx,
						          	data: this.rtn,
						          	base64: res.target.result || null
						          });
								} 
						// #endif
					},

 类似资料: