以前的文章講得太多安裝了,今天就不說這個了,由於個人項目是先後端分離的,因此基本是分開執行代碼邏輯。其中還有跨域問題,主要仍是在laravel中添加頭信息放行之類的,這裏會提一下作法。php
個人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-preview
與on-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跨域須要添加一箇中間件
在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, ];
調用中間件來限制路由,這裏用了dingo api
,如不清楚請看前面的文章後端
$api->version('v1', ['middleware' => 'cors'], function (Router $api) { $api->post('upfile', 'App\\Api\\V1\\Controllers\\Upload\\UploadFiles@upfile'); }
打開config/filesystems.php
找到 disks
api
'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, '文件未經過驗證'); } } }
到此,已經能夠放上所有要用到的代碼了,喜歡的點個贊 =_=瀏覽器