VUE+axios+php實(shí)現(xiàn)圖片上傳
本文實(shí)例為大家分享了VUE+axios+php實(shí)現(xiàn)圖片上傳的具體代碼,供大家參考,具體內(nèi)容如下
前端部分
執(zhí)行函數(shù),注意file那有個(gè)await,獲取到文件數(shù)據(jù)后,裝在FormData里面,然后調(diào)用下文axios的uploadFile
async uploadFiles() {
? ? ? let inputObj = document.createElement("input");
? ? ? let file = await new Promise((res) => {
? ? ? ? inputObj.setAttribute("id", "file");
? ? ? ? inputObj.setAttribute("type", "file");
? ? ? ? inputObj.setAttribute("name", "file");
? ? ? ? inputObj.setAttribute("style", "visibility:hidden");
? ? ? ? document.body.appendChild(inputObj);
? ? ? ? inputObj.click();
? ? ? ? document.querySelector("#file").addEventListener("change", (e) => {
? ? ? ? ? console.log(e.target.files);
? ? ? ? ? res(e.target.files)
? ? ? ? });
? ? ? });
? ? ? let formdata = new FormData()
? ? ? formdata.append('myFile', file[0])
? ? ? await this._http.uploadFile(formdata).then(console.log);
? ? ? document.body.removeChild(inputObj)
? ? },http請(qǐng)求集中管理
async uploadFile(file) {
? ? return axios.post(`/Upload.php`,file,{
? ? ? headers: {"Content-Type": "multipart/form-data"}
? ? })
? }php后端部分
接收參數(shù),調(diào)用uploadFile
<?php
header('content-type:text/html;charset=utf-8');
$fileInfo=$_FILES["myFile"];
$maxSize=10485760;//10M,10*1024*1024
$allowExt=array('jpeg','jpg','png','tif');
$path="uploads";
include_once 'UploadFile.php';
uploadFile($fileInfo, $path, $allowExt, $maxSize);封裝uploadFile函數(shù)
<?php
function uploadFile($fileInfo, $path, $allowExt, $maxSize)
{
? $filename = $fileInfo["name"];
? $tmp_name = $fileInfo["tmp_name"];
? $size = $fileInfo["size"];
? $error = $fileInfo["error"];
? $type = $fileInfo["type"];
? //服務(wù)器端設(shè)定限制
? $ext = pathinfo($filename, PATHINFO_EXTENSION);
? //目的信息
? if (!file_exists($path)) {
? ? mkdir($path, 0777, true);
? ? chmod($path, 0777);
? }
? $uniName = md5(uniqid(microtime(true), true)) . '.' . $ext;
? $destination = $path . "/" . $uniName;
? if ($error == 0) {
? ? if ($size > $maxSize) {
? ? ? exit("上傳文件過大!");
? ? }
? ? if (!in_array($ext, $allowExt)) {
? ? ? exit("非法文件類型");
? ? }
? ? if (!is_uploaded_file($tmp_name)) {
? ? ? exit("上傳方式有誤,請(qǐng)使用post方式");
? ? }
? ? //判斷是否為真實(shí)圖片(防止偽裝成圖片的病毒一類的
? ? if (!getimagesize($tmp_name)) { //getimagesize真實(shí)返回?cái)?shù)組,否則返回false
? ? ? exit("不是真正的圖片類型");
? ? }
? ? if (@move_uploaded_file($tmp_name, $destination)) { //@錯(cuò)誤抑制符,不讓用戶看到警告
? ? ? echo "文件" . $filename . "上傳成功!";
? ? } else {
? ? ? echo "文件" . $filename . "上傳失敗!";
? ? }
? } else {
? ? switch ($error) {
? ? ? case 1:
? ? ? ? echo "超過了上傳文件的最大值,請(qǐng)上傳2M以下文件";
? ? ? ? break;
? ? ? case 2:
? ? ? ? echo "上傳文件過多,請(qǐng)一次上傳20個(gè)及以下文件!";
? ? ? ? break;
? ? ? case 3:
? ? ? ? echo "文件并未完全上傳,請(qǐng)?jiān)俅螄L試!";
? ? ? ? break;
? ? ? case 4:
? ? ? ? echo "未選擇上傳文件!";
? ? ? ? break;
? ? ? case 7:
? ? ? ? echo "沒有臨時(shí)文件夾";
? ? ? ? break;
? ? }
? }
? return $destination;
}以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
幾個(gè)你不知道的技巧助你寫出更優(yōu)雅的vue.js代碼
本文參考自油管上某個(gè)國外大神的公開演講視頻,學(xué)習(xí)了一下覺得很不錯(cuò),所以在項(xiàng)目中也使用了這些不錯(cuò)的技巧。趁周末有空,寫個(gè)博客記錄一下2018-06-06
vue element封裝form表單的實(shí)現(xiàn)
本文主要介紹了vue element封裝form表單的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
利用Vue3的Teleport實(shí)現(xiàn)模態(tài)對(duì)話框功能
在前端開發(fā)中,模態(tài)對(duì)話框是一種常見的用戶交互方式,它能夠有效地提示用戶、收集信息或確認(rèn)操作,隨著現(xiàn)代框架的演進(jìn),Vue 3 的出現(xiàn)為我們提供了更便捷、高效的方式來處理復(fù)雜的界面布局,今天,我們將深入探討如何利用 Vue 3 的新特性 Teleport 來實(shí)現(xiàn)模態(tài)對(duì)話框2025-02-02
Vue3 去除 vue warn 及生產(chǎn)環(huán)境去除console.log的方法
這篇文章主要介紹了Vue3 去除 vue warn 及生產(chǎn)環(huán)境去除console.log的方法,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06
Vite創(chuàng)建項(xiàng)目的實(shí)現(xiàn)步驟
隨著 Vite2 的發(fā)布并日趨穩(wěn)定,現(xiàn)在越來越多的項(xiàng)目開始嘗試使用它。本文我們就介紹了Vite創(chuàng)建項(xiàng)目的實(shí)現(xiàn)步驟,感興趣的可以了解一下2021-07-07
詳解vuejs中執(zhí)行npm run dev出現(xiàn)頁面cannot GET/問題
這篇文章主要介紹了詳解vuejs中執(zhí)行npm run dev出現(xiàn)頁面cannot GET/問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04

