vuejs+element-ui+laravel5.4上傳文件

前言

以前的文章講得太多安裝了,今天就不說這個了,由於個人項目是先後端分離的,因此基本是分開執行代碼邏輯。其中還有跨域問題,主要仍是在laravel中添加頭信息放行之類的,這裏會提一下作法。php

element-ui的upload組件

個人vue代碼:vue

<template>
    <el-upload
            :action="uploadAction"
            list-type="picture-card"
            :on-remove="handleRemove"
            :on-success="handleSuccess"
            :before-upload="handleBefore"
            :file-list="files">
        <i class="el-icon-plus"></i>
    </el-upload>
    <el-dialog v-model="dialogVisible" size="tiny">
        <img width="100%" :src="dialogImageUrl" alt="">
    </el-dialog>
</template>

這裏說一下 on-previewon-success均可以拿到服務器的返回路徑
其中:action="uploadAction"是服務器接引地址, list-type爲限制上傳格式
而:on-remove="handleRemove"爲移除圖片時對應的方法,:before-upload="handleBefore"
爲上傳前的操做,這裏我用於限制上傳的數量限制, :file-list="files"上傳後數據綁定在這裏
這裏我是使用:on-success="handleSuccess"來拿服務器的返回數據的
laravel

export default {
    data(){
        return {
            files: [],
            uploadAction:'http://服務器地址'
        }
    },
    methods: {
        handleSuccess(response){
            console.log(response)
            this.files = [{name: response.name, url: imgBaseUrl + response.photo}]
        },
        handleBefore(){
            return this.files.length === 1 ? false : true // 只讓它上傳一張
        },
        handleRemove(file, fileList) {
              console.log(file, fileList)
        }
    }
}

laravel跨域

laravel跨域須要添加一箇中間件
在app/Http/middleware下 新建文件Cors.php,輸入element-ui

namespace App\Http\Middleware;

use Closure;

class Cors
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        header('Access-Control-Allow-Origin: *');
        header('Access-Control-Allow-Methods: GET, POST, PATCH, PUT, DELETE, OPTIONS');
        header('Access-Control-Allow-Headers: Origin, Content-Type, X-Auth-Token');
        return $next($request);
    }
}

在appHttpKernel.php
添加json

protected $routeMiddleware = [
        // some class
        'cors' => \App\Http\Middleware\Cors::class,
    ];

laravel 路由

調用中間件來限制路由,這裏用了dingo api,如不清楚請看前面的文章後端

$api->version('v1', ['middleware' => 'cors'], function (Router $api) {
    $api->post('upfile', 'App\\Api\\V1\\Controllers\\Upload\\UploadFiles@upfile');
}

配置Store

打開config/filesystems.php 找到 disksapi

'disks' => [

    // 上面還有不少,下面是本身加的
    // 新建一個本地端uploads空間(目錄) 用於存儲上傳的文件
        'uploads' => [

            'driver' => 'local',

            // 文件將上傳到storage/app/uploads目錄
            'root' => storage_path('app/uploads'),

            // 文件將上傳到public/uploads目錄 若是須要瀏覽器直接訪問 請設置成這個
            //'root' => public_path('uploads'),
        ],
]

開始上傳

新建一個上傳Controller, 下面不少判斷沒有作,自行作吧
AppApiV1ControllersUploadUploadFiles.php跨域

namespace App\Api\V1\Controllers\Upload;


use Dingo\Api\Http\Request;
use Dingo\Api\Exception\StoreResourceFailedException;
use Storage;

class UploadFiles
{
    public function upfile(Request $request) {
        if (!$request->hasFile('file')) {
            return response()->json([], 500, '沒法獲取上傳文件');
        }
        $file = $request->file('file');

        if ($file->isValid()) {
            // 獲取文件相關信息
            $originalName = $file->getClientOriginalName(); // 文件原名
            $ext = $file->getClientOriginalExtension();     // 擴展名
            $realPath = $file->getRealPath();   //臨時文件的絕對路徑
            $type = $file->getClientMimeType();     // image/jpeg

            // 上傳文件
            $filename = date('Ymd/His');
            // 使用咱們新建的uploads本地存儲空間(目錄)
            $path = $file->store($filename, 'uploads');
            return response()->json([
                'status_code' => 200,
                'message' => 'success',
                'photo' => $path,
                'name' => $originalName,
            ]);

        } else {
            return response()->json([], 500, '文件未經過驗證');
        }
    }
}

到此,已經能夠放上所有要用到的代碼了,喜歡的點個贊 =_=瀏覽器

相關文章
相關標籤/搜索