Java后端SSM框架圖片上傳功能實(shí)現(xiàn)方法解析
一、技術(shù)概述
(1)這個(gè)技術(shù)是做什么
這個(gè)技術(shù)是上傳圖片到服務(wù)器上,并且把地址存在數(shù)據(jù)庫中。前端調(diào)用的時(shí)候之間通過地址即可調(diào)用。
(2)學(xué)習(xí)該技術(shù)的原因
由于用戶在寫日記的時(shí)候也可以進(jìn)行圖片的上傳,同時(shí)還有用戶頭像的上傳。
二、技術(shù)詳述
以上傳用戶的頭像為例
(1)接口代碼
@RequestMapping(value = "user/profilePhoto", produces = "application/json; charset=utf-8")
@ResponseBody
public boolean imageUphold(@RequestParam("photo") MultipartFile file, Long phone) throws IOException {
String filePath = ducumentBase;// 保存圖片的路徑
// String filePath = "/image";//保存圖片的路徑
// 獲取原始圖片的拓展名
String originalFilename = file.getOriginalFilename();
System.out.println("originalFilename: " + originalFilename);
// 新的文件名字
String newFileName = UUID.randomUUID() + originalFilename;
// 封裝上傳文件位置的全路徑
filePath += "/" + phone;
System.out.println("filePath: " + filePath);
File targetFile = new File(filePath, newFileName);
if (!targetFile.exists()) {
targetFile.mkdirs();
}
// 把本地文件上傳到封裝上傳文件位置的全路徑
System.out.println("newFileName: " + newFileName);
System.out.println("targetFile: " + targetFile.getName());
System.out.println("phone: " + phone);
//System.out.println("afterPhone");
try {
file.transferTo(targetFile);
} catch (IllegalStateException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
String allPath=mappingPath + "/" + phone+ "/" + newFileName;
System.out.println("存儲路徑為"+allPath);
boolean result=onedayServiceImpl.updProfilePhoto(allPath, phone);//存在數(shù)據(jù)庫中,其中allPath的數(shù)據(jù)庫類型為varchar(1000)
return result;
}
其中的ducumentBase以及mappingPath
@Value("${ducument.base}")
private String ducumentBase;
@Value("${mapping.path}")
private String mappingPath;
為全局變量
配置文件
ducument.base = D://oneday_uphold
mapping.path = /images
(2)解釋
用MultipartFile來接收圖片的二進(jìn)制碼,然后使用路徑+圖片名+隨機(jī)數(shù)保存圖片。
(3)測試jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>image/uphold</title>
</head>
<body>
<form action="user/profilePhoto" method="post" enctype="multipart/form-data">
圖片:<input type="file" name="photo">
電話:<input type="text" name="phone" value="13225942005">
<input type="submit" value="提交">
</form>
</body>
</html>
(4)顯示圖片
<img id="images" alt="頭像" src="/mappingPath/路徑">
三、技術(shù)使用中遇到的問題和解決過程
(1)無法保存:
查看是否已進(jìn)行服務(wù)器的設(shè)置,以Eclipse為例
Servers->Modules->Add External Web Modules 進(jìn)行路徑的設(shè)置
(2)無法訪問接口:
查看是否使用表單形式訪問:method="post" enctype="multipart/form-data"
同時(shí)上傳的名字是否與接口相對應(yīng)
四、總結(jié)
本來進(jìn)行圖片的上傳的時(shí)候考慮過直接上傳二進(jìn)制到數(shù)據(jù)庫用blob進(jìn)行保存,但覺得這樣不好,遂改為保存圖片地址的方式進(jìn)行上傳。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Gradle修改本地倉庫的位置方法實(shí)現(xiàn)
這篇文章主要介紹了Gradle修改本地倉庫的位置方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
springboot集成fastDfs過程代碼實(shí)例
這篇文章主要介紹了springboot集成fastDfs過程代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12
詳解J2EE開發(fā)的網(wǎng)站部署到阿里云服務(wù)器的方法
這篇文章主要介紹了詳解J2EE開發(fā)的網(wǎng)站部署到阿里云服務(wù)器的方法,需要的朋友可以參考下2018-01-01
springboot 用監(jiān)聽器統(tǒng)計(jì)在線人數(shù)案例分析
這篇文章主要介紹了springboot 用監(jiān)聽器統(tǒng)計(jì)在線人數(shù)案例分析,質(zhì)是統(tǒng)計(jì)session 的數(shù)量,思路很簡單,具體實(shí)例代碼大家參考下本文2018-02-02
在IntelliJ IDEA中多線程并發(fā)代碼的調(diào)試方法詳解
這篇文章主要介紹了在IntelliJ IDEA中多線程并發(fā)代碼的調(diào)試方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
Spring AOP常見使用場景、術(shù)語及設(shè)計(jì)模式應(yīng)用方式
AOP是一種編程思想,可以將橫切關(guān)注點(diǎn)從業(yè)務(wù)邏輯中分離出來,以便更好地管理和維護(hù),它通過使用Aspect、JoinPoint、Advice等術(shù)語來實(shí)現(xiàn),代理、裝飾器和攔截器等設(shè)計(jì)模式在AOP中經(jīng)常被使用2024-12-12
使用@RequiredArgsConstructor注解來取代繁瑣的@Autowrired
有了@RequiredArgsConstructor注解,我們就可以減少@Autowired的書寫,本文主要介紹了使用@RequiredArgsConstructor注解來取代繁瑣的@Autowrired,感興趣的可以了解一下2022-04-04
SpringBoot Bean被加載時(shí)進(jìn)行控制
很多時(shí)候我們需要根據(jù)不同的條件在容器中加載不同的Bean,或者根據(jù)不同的條件來選擇是否在容器中加載某個(gè)Bean,這就是Bean的加載控制,一般我們可以通過編程式或注解式兩種不同的方式來完成Bean的加載控制2023-02-02

