美文网首页
Yii2 图片上传,使用ajax上传。非官方组件

Yii2 图片上传,使用ajax上传。非官方组件

作者: KoPa | 来源:发表于2018-08-24 11:09 被阅读0次

由于通过ajax等方式上传图片并返回URL路径,因此没有使用Yii2本身自带的组件进行上传。

使用背景:
使用Yii2基础版本,非高级版。
图片存放在 web/uploads文件夹(uploads为新建文件夹)
创建 /app/下,创建 services 业务文件夹,主要写 业务类 文件。
services下创建 Upload.php 图片上传类

代码如下


<?php
/**
 * Created by PhpStorm.
 * User: kopa
 * Date: 2018/8/9
 * Time: 下午2:53
 */

namespace app\services;

Class Upload{
    public $uploadName; //文件名
    public $uploadTmpName;//临时文件名
    public $uploadFinalName; //最终文件名
    public $uploadTargetDir='../web/uploads';//最终文件夹
    public $uploadTargetFile;//最终路径
    public $uploadFileType;//文件类型
    public $allowUploadType = ['image/png','image/jpeg','image/jpg','image/gif'];

    public $uploadFileSize;//上传文件大小
    public $allowUploadedMaxsize    =   100000000;//上传文件最大值

    public function __construct()
    {
        $this->uploadName   =   $_FILES['image']['name'];
        $this->uploadFileType   =   $_FILES['image']['type'];
        $this->uploadTmpName    =   $_FILES['image']['tmp_name'];
        $this->uploadFileSize   =   $_FILES['image']['size'];
    }

    public function getImage()
    {
        if(!$this->isAllowFile($this->uploadFileType))
            throw new \Exception('不允许上传该类型',10001);
        if(!$this->isAllowSize($this->uploadFileSize))
            throw new \Exception('文件超出限制',10001);

        $dirName    =   $this->createUploadDir();//创建文件夹
        $newFileName    =   uniqid().'.png';//新文件名称
        $this->uploadTargetFile = $dirName.'/'.$newFileName;
        if(!move_uploaded_file($this->uploadTmpName,$this->uploadTargetFile))
            throw new \Exception('文件类型上传失败',10001);

        return [
            'path'=>$this->uploadTargetFile,
            'dirName'=>str_replace($this->uploadTargetDir,"",$dirName),
            'fileName'=>$newFileName
        ];
    }

    protected function isAllowFile($file_type)
    {
        // $info = pathinfo($file_name);
        return in_array($file_type, $this->allowUploadType) ? true : false;
        // return true;

    }

    protected function isAllowSize($size)
    {
        return $size < $this->allowUploadedMaxsize ? true : false;
    }

    protected function createUploadDir()
    {
        $dir_name = $this->uploadTargetDir . "/" . date("YmdH");
        if (!is_dir($dir_name)) {
            mkdir($dir_name, 0777, true);
            chmod($dir_name, 0777);
        }
        return $dir_name;
    }

}

控制器类UploadController


<?php

namespace app\controllers\api;

use Yii;
use yii\web\Controller;
use app\services\Upload;
use app\services\Utils;


class UploadController extends Controller
{
   /*
    * 图片上传
    * */
    public function actionUploadimg()
    {
        try{
            $upload = new Upload();
            $info   =   $upload->getImage();
            $imgUrl     =   '/web/uploads'.$info['dirName'].'/'.$info['fileName'];
            Utils::apiDisplay(['status'=>0,'data'=>$imgUrl]);
        }catch(Exception $e){
            $data['status']  = 1;
            $data['message'] = $e->getMessage();
            Utils::apiDisplay( $data );
        }
    }
}


最终返回结果

{
    "status": 0,
    "data": "/web/uploads/2018082403/5b7f74ea6a950.png"
}

相关文章

网友评论

      本文标题:Yii2 图片上传,使用ajax上传。非官方组件

      本文链接:https://www.haomeiwen.com/subject/bilbiftx.html