我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue+SSM实现图片上传预览效果

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue+SSM实现图片上传预览效果

现在的需求是:有一个上传文件按钮,当我们点击按钮时,可以选择需要上传的文件,确定后图片显示在界面上。

说明:本项目前端使用的Vue,后台用的SSM搭建的,服务器是Tomcat,数据库是MySQL

实现思路:

前端界面:当用户点击上传文件按钮,选中待上传图片并点击确认后,这时应该把图片数据传给后台。当后台经过处理后返回结果,前端在根据响应结果做后续工作。

后端:后台拿到前端传过来的数据时,将图片文件存到固定的文件夹下(这个问题是我思考了很久的,我认为应该存在服务器下,原先我是存在本地文件夹下,然后用路径去引,这样说实话真的好笨,遇到了好多问题,搞了好久,被自己蠢哭)。文件存入后,返回响应结果。如果成功直接返回当前图片的相对路径,然后前端根据这个路径展示图片。

现在主要思考的问题是如何将图片资源放在Tomcat下。

实现这个问题,我是在Tomcat下创建了一个虚拟目录,今后所有的图片文件视频等资源都放在这个目录文件夹下

后端实现上传图片步骤如下:

1. 在Tomcat下创建虚拟目录

在tomcat的根目录下创建一个名为FileDir的目录(当然这个目录也可以建立在其它的地方)

在tomcat的conf/server.xml,配置虚拟目录。增加下面这行
<Context path="/FileDir" docBase="G:\安装包\Tomcat\安装包\Tomcat 7.0\FileDir"/>

添加一张图片1.jpg到虚拟目录中,并启动tomcat测试。访问:http://localhost:8080/FileDir/1.jpg。可以请求到图片,说明配置成功。

2. 后端配置

引入文件上传下载jar包:commons-fileupload-1.3.2.jar和commons-io-1.3.2.jar

编写SpringMVC配置文件,添加如下代码:


<!-- 配置文件上传解析器 -->
 <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
  <!-- 设置请求编码格式 -->
  <property name="defaultEncoding" value="UTF-8"></property>
</bean>

创建一个用于文件上传的控制器类FileUploadController


package com.wyf.controller;

import java.io.File;
import java.util.UUID;

import javax.servlet.http.HttpServletRequest;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

import com.wyf.po.Result;
import com.wyf.service.FileServlet;


@RestController
public class FileUploadController {

 @Autowired
 private FileServlet fileServlet;

 
 @RequestMapping(value = "/uploadImg", method = RequestMethod.POST, produces = { "application/json;charset=UTF-8" })
 public Result handleUploadImg(@RequestParam("file") MultipartFile file, HttpServletRequest request) {
  // 判断所上传文件是否存在
  if (!file.isEmpty()) {
   // 获取文件上传的原始名称
   String originalFilename = file.getOriginalFilename();
   //存储图片的路径
   String rootPath = "G:\\安装包\\Tomcat\\安装包\\Tomcat 7.0\\FileDir\\";
   // 设置上传文件的保存地址目录
   String path = "\\upload\\images\\applyShop";
   String dirPath = rootPath + path + "\\";
   File filePath = new File(dirPath);
   // 如果保存文件的地址不存在,就先创建目录
   if (!filePath.exists()) {
    filePath.mkdirs();
   }
   // 重新命名
   String newFileName = UUID.randomUUID() + "_" + originalFilename;
   try {
    // 使用MultipartFile接口的方法完成文件上传到指定位置
    file.transferTo(new File(dirPath + newFileName));
   } catch (Exception e) {
    e.printStackTrace();
    return new Result(false, "上传错误");
   }
   // 返回相对路径
   String class="lazy" data-srcPath = path + "\\" + newFileName;
   fileServlet.addUploadFIle(class="lazy" data-srcPath);
   return new Result(true, class="lazy" data-srcPath);
  }
  return new Result(false, "文件不存在");
 }
}

这里用了一个Result类来返回数据,用来封装返回的结果信息,以JSON格式返回给前端。代码如下:


public class Result {

 private boolean flag;//处理结果标识
 private String message;//返回的结果信息
 
}

前端Vue界面,发送请求给后台后,通过动态绑定class="lazy" data-src属性,获取拿到的图片路径


<template>
  <div class="upload">
    <div class="img-container">
      <!-- 上传预览图片 -->
      <img :class="lazy" data-src="class="lazy" data-src" alt />
    </div>
    <!-- 文件上传的input -->
    <form class="input-file" enctype="multipart/form-data" method="post">
      <input type="file" ref="upload" name="uploadImg" id="file" @change="getFile" multiple />
      <!-- label一个 for 属性指向input的唯一 id ,这样点击label就相当于点击input -->
      <label for="file">上传图片</label>
    </form>
  </div>
</template>
<script>
export default {
  data() {
    return {
     class="lazy" data-src:require('../../assets/dist/images/admin.jpg'),
     class="lazy" data-srcPath:''//图片相对路径
    };
  },
  methods: {
   getFile(e) {
    let files = e.target.files[0]; //获取上传图片信息
  let formData = new FormData()
       formData.append('file',files)
      this.$axios.post("/api/uploadImg",formData).then(result=>{
       if(result.data.flag){
            this.class="lazy" data-srcPath = result.data.message
            this.class="lazy" data-src = `/imgURL${this.class="lazy" data-srcPath}`
            }else{
            console.log(result.data.message)
        }
      })
    }
  }
};
</script>

到这一步,基本能实现图片的上传和预览。但是有bug,中文乱码问题。如果图片路径带中文,class="lazy" data-src解析不出来,这个问题我也解决了很久。

找了各种百度,最后还是用的修改tomcat的server.xml配置文件方法。
我思考了一下出现乱码的原因,因为我的图片资源是通过访问tomcat拿到的,所以当img标签动态绑定后台传过来的路径时,提交的方式是get请求。前台拿到的路径中文是正确的,但是在tomcat下就会乱码,tomcat默认的编码方式是iso8859-1对中文编码,而前端设置的编码方式是utf-8,所以就出现了乱码。

我的解决办法是修改tomcat的server.xml配置文件

在tomcat的server.xml中找到


<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>

将这行修改为


<!--解决地址栏输入中文乱码问题在<Connector中加入 useBodyEncodingForURI="true" URIEncoding="UTF-8" -->
<!--useBodyEncodingForURI="true":代表get和post请求用一样的编码  -->
<!--URIEncoding="UTF-8":请求编码为utf-8  -->
<Connector URIEncoding="UTF-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"     useBodyEncodingForURI="true"/>

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue+SSM实现图片上传预览效果

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

javascript实现上传图片并预览的效果实现代码

图片上传预览,就是在使用文件选择框选择了文件之后就可以在页面上看见图片的效果,关于这个效果我一直认为是无法做到的
2022-11-21

基于jquery实现的上传图片及图片大小验证、图片预览效果代码

基于jquery实现的上传图片及图片大小验证、图片预览效果代码,需要的朋友可以参考下。
2022-11-21

Vue和UpLoad怎么实现上传预览和删除图片

这篇文章主要介绍“Vue和UpLoad怎么实现上传预览和删除图片”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue和UpLoad怎么实现上传预览和删除图片”文章能帮助大家解决问题。1、用vue+E
2023-06-29

thinkphp5加layui实现图片上传功能(带图片预览)

这篇文章主要介绍了thinkphp5加layui实现图片上传功能(带图片预览)的相关资料,需要的朋友可以参考下
2023-03-11

vue如何实现图片预览放大以及缩小效果

这篇文章主要介绍了vue如何实现图片预览放大以及缩小效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue如何实现图片预览放大以及缩小效果文章都会有所收获,下面我们一起来看看吧。vue图片预览放大以及缩小在v
2023-07-05

Android实现图片点击预览效果(zoom动画)

参考:https://developer.android.google.cn/training/animation/zoom.html 1.创建Views 下面的布局包括了你想要zoom的大版本和小版本的view。 1.ImageButto
2022-06-06

编程热搜

目录