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; /** * 文件上傳控制器 * * @author ASUS * */ @RestController public class FileUploadController { @Autowired private FileServlet fileServlet; /** * 執行圖片上傳 * * 解決前端獲取後臺數據中文亂碼:produces={"application/json;charset=UTF-8"} */ @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 srcPath = path + "\\" + newFileName; fileServlet.addUploadFIle(srcPath); return new Result(true, srcPath); } return new Result(false, "文件不存在"); } }
這裡用瞭一個Result類來返回數據,用來封裝返回的結果信息,以JSON格式返回給前端。代碼如下:
public class Result { private boolean flag;//處理結果標識 private String message;//返回的結果信息 /* 省略get()和set()*/ }
前端Vue界面,發送請求給後臺後,通過動態綁定src屬性,獲取拿到的圖片路徑
<template> <div class="upload"> <div class="img-container"> <!-- 上傳預覽圖片 --> <img :src="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 { src:require('../../assets/dist/images/admin.jpg'), 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.srcPath = result.data.message this.src = `/imgURL${this.srcPath}` }else{ console.log(result.data.message) } }) } } }; </script>
到這一步,基本能實現圖片的上傳和預覽。但是有bug,中文亂碼問題。如果圖片路徑帶中文,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"/>
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- spring boot實現文件上傳
- 用IDEA創建SpringBoot項目的詳細步驟記錄
- SpringMvc實現簡易計算器功能
- SpringBoot監控Tomcat活動線程數來判斷是否完成請求處理方式
- springboot文件上傳保存路徑的問題