VUE+axios+php实现图片上传

本文实例为大家分享了VUE+axios+php实现图片上传的具体代码,供大家参考,具体内容如下

前端部分

执行函数,注意file那有个await,获取到文件数据后,装在FormData里面,然后调用下文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请求集中管理

async uploadFile(file) {
    return axios.post(`/Upload.php`,file,{
      headers: {"Content-Type": "multipart/form-data"}
    })
  }

php后端部分

接收参数,调用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函数

<?php
function uploadFile($fileInfo, $path, $allowExt, $maxSize)
{
  $filename = $fileInfo["name"];
  $tmp_name = $fileInfo["tmp_name"];
  $size = $fileInfo["size"];
  $error = $fileInfo["error"];
  $type = $fileInfo["type"];
  //服务器端设定限制
  $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("上传方式有误,请使用post方式");
    }
    //判断是否为真实图片(防止伪装成图片的病毒一类的
    if (!getimagesize($tmp_name)) { //getimagesize真实返回数组,否则返回false
      exit("不是真正的图片类型");
    }
    if (@move_uploaded_file($tmp_name, $destination)) { //@错误抑制符,不让用户看到警告
      echo "文件" . $filename . "上传成功!";
    } else {
      echo "文件" . $filename . "上传失败!";
    }
  } else {
    switch ($error) {
      case 1:
        echo "超过了上传文件的最大值,请上传2M以下文件";
        break;
      case 2:
        echo "上传文件过多,请一次上传20个及以下文件!";
        break;
      case 3:
        echo "文件并未完全上传,请再次尝试!";
        break;
      case 4:
        echo "未选择上传文件!";
        break;
      case 7:
        echo "没有临时文件夹";
        break;
    }
  }
  return $destination;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Vue2.0实现调用摄像头进行拍照功能 exif.js实现图片上传功能

    本文实例为大家分享了Vue2.0实现调用摄像头进行拍照功能的具体代码,以及图片上传功能引用exif.js,供大家参考,具体内容如下 可以在github 上下载demo链接 vue组件代码 <template> <div> <div style="padding:20px;"> <div class="show"> <div class="picture" :style="'backg

  • vue+elementUI实现图片上传功能

    本文实例为大家分享了vue+elementUI图片上传的具体代码,供大家参考,具体内容如下 1.html <el-form-item label="图片" prop="logo"> <el-upload name="file" v-if="optype==0" :action="'/upload'" accept=".jpg, .png" list-type="

  • Vue+elementUI实现多图片上传与回显功能(含回显后继续上传或删除)

    最近有使用vue+elementUI实现多图片上传的需求,遂做此纪录. 本次主要写一下前端的实现细节,至于后台以Multipart[ ]数组接收即可,不再赘述,网上一搜大把文章可供参考. 本次使用elementui的上传图片控件的照片墙类型,其使用示例可具体查看官方文档 Elementui 多图上传控件 需要注意的是,官方文档中的示例采用自动上传的方式,大多数情况我们是需要点击上传按钮或和表单一起提交才开始上传的(即手动上传),此时官方的示例就不满足我们的需求了.怎么办?当然是自己动手丰衣足食啦

  • vue-quill-editor实现图片上传功能

    问题描述   项目使用的vue2.0开发,项目中需要一个富文本编辑器,楼主经过一番心理挣扎选择了vue-quill-editor.具体如何引用作者在项目中已经写得很明白了,我在这里就不再赘述.   vue-quill-editor插入图片的方式是将图片转为base64再放入内容中,这样就会产生一个问题,如果图片比较大的话,富文本的内容就会很大,楼主是将内容存在数据库中的,这样一来,一方面会占用大量的数据库存储空间,另一方面当图片太大的时候富文本的内容,会超过数据库的存储上限,从而会产生内容被截断

  • vue实现图片上传功能

    本文实例为大家分享了vue实现图片上传功能的具体代码,供大家参考,具体内容如下 先看效果 图片上传使用vant组件库中的 van-uploader, 使用方法参考官网 vant组件库 下面看代码 UploadPicture.vue <template> <div class="content"> <!-- 底部模块start --> <div class="bottom_bg"> <p class="f

  • vue.js 图片上传并预览及图片更换功能的实现代码

    这里讲解是图片上传和图片预览.主要是围绕我们常用功能的列子做讲解 ,并且没有格外引入其他js 所以你复制过去做简单修改便可以看到效果 效果图: 样式以及效果图一并展示 1.HTML <div class="rz-picter"> <img :src="avatar" class="img-avatar"> <input type="file" name="avatar" id=

  • Vue.js 2.0 移动端拍照压缩图片上传预览功能

    在学习和使用Vue.js 2.0 的过程中遇到不少不一样的地方,本来移动端开发H5应用,准备将mui框架和Vue.js+vue-router+vuex 全家桶结合起来使用,但是在拍照上传的实现过程中遇到了无法调用plus的H5+接口的问题,所以最后拍照上传功能还是使用input file方式里解决的.但是内心还是不甘心的,由于项目进度推进,迭代版本,所以不得不放弃,后续可能我将此功能使用调用H5+接口实现. 首先我来讲我实现这个拍照预览压缩上传的思路,准确的说应该是拍照或选择图片压缩之后预览及上

  • 使用Vue实现图片上传的三种方式

    项目中需要上传图片可谓是经常遇到的需求,本文将介绍 3 种不同的图片上传方式,在这总结分享一下,有什么建议或者意见,请大家踊跃提出来. 没有业务场景的功能都是耍流氓,那么我们先来模拟一个需要实现的业务场景.假设我们要做一个后台系统添加商品的页面,有一些商品名称.信息等字段,还有需要上传商品轮播图的需求. 我们就以Vue.Element-ui,封装组件为例子聊聊如何实现这个功能.其他框架或者不用框架实现的思路都差不多,本文主要聊聊实现思路. 1.云储存 常见的 七牛云,OSS(阿里云)等,这些云平

  • vue+elementUI实现表单和图片上传及验证功能示例

    本文实例讲述了vue+elementUI实现表单和图片上传及验证功能.分享给大家供大家参考,具体如下: 最终实现需求如下图: form表单内容与重点人员图片同时上传且图片为必填项 分析弹框页需要解决的问题有: 1.表单内容的验证及必填项 2.新增和编辑用同一个组件如何处理数据 3.图片需要和信息一起传递(即不允许自动上传) 4.图片必填的验证问题 针对上述问题作出方案: 1.el-form的表单验证需要注意几个地方: a:el-form-item的prop值需要和表单标签的v-model值保持一

  • vue+element实现图片上传及裁剪功能

    本文实例为大家分享了vue+element实现图片上传及裁剪的具体代码,供大家参考,具体内容如下 随便写的一个小demo 功能是没有任何问题 可能里面会有一些小细节没有优化 1 .安装 vue-cropper npm install vue-cropper 2.组件内使用 import { VueCropper } from 'vue-cropper' components: { VueCropper, }, 具体可见官网 demo <template> <div> <h1&

随机推荐