springMVC使用ajaxFailUpload上傳圖片的方法
1.在jsp頁面<head>標(biāo)簽內(nèi)引入script文件(注意順序)
<script type="text/javascript" src="resources/js/jquery-3.3.1.min.js"></script> <script type="text/javascript" src="resources/js/ajaxFileUpload.js"></script>
2.springMVC.xml配置文件中(必須進(jìn)行配置)
<!--使用springMVC上傳圖片 ajaxFileUpload--> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="10485760" /> </bean>
3.<input>標(biāo)簽(id屬性,<script>中 ajaxFileUpload的fileElementId會用到)
<input type="file" id="headImg" name="headImg"/>
4.在<script>標(biāo)簽中,我將ajaxFileUpload寫在一個(gè)函數(shù)里,在需要用到上傳圖片的位置,調(diào)用該函數(shù)
function headImgUpload(){ //圖片上傳函數(shù) var results = ""; var account = $("#account").val(); //account、identity 這兩個(gè)變量,根據(jù)我的需求會在后面用到,閱讀者可以根據(jù)自己的需求刪掉或者修改這兩個(gè)變量 var identity = $("input[name='identity']:checked").val(); $.ajaxFileUpload({ url:"register/headImgUpload?account="+account+"&identity="+identity,//根據(jù)url訪問controller層中的方法 secureuri:false, fileElementId:"headImg", //<input>標(biāo)簽中的id屬性 type:"POST", dataType:"text", //服務(wù)器返回的數(shù)據(jù)類型 success:function (result) { result = result.replace(/<pre.*?>/g, ''); //ajaxFileUpload會對服務(wù)器響應(yīng)回來的text內(nèi)容加上<pre style="....">text</pre>前后綴 result = result.replace(/<PRE.*?>/g, ''); result = result.replace("<PRE>", ''); result = result.replace("</PRE>", ''); result = result.replace("<pre>", ''); result = result.replace("</pre>", ''); result = JSON.parse(result);//轉(zhuǎn)換為json格式 results = result.result; alert(result); }, error:function (data,status,error) { alert("失敗?。?!"+error); } }); }
5.controller層
@Controller @RequestMapping(value = "register") public class RegisterController { //用戶頭像上傳 @RequestMapping(value = "/headImgUpload",method = RequestMethod.POST) @ResponseBody public Map<String,Object> headImgUpload(@RequestParam MultipartFile headImg, String account, String identity, HttpServletRequest request){ //上傳的結(jié)果 String result = "fail"; //頭像上傳到的位置 String imgRealPath = ""; try{ //確保上傳的圖片不為空 if(headImg != null && !headImg.isEmpty()){ //判斷注冊用戶的身份,商戶還是會員 if(identity.equals("member")){ //會員 imgRealPath = request.getSession().getServletContext().getRealPath("/resources/image/member"); }else if(identity.equals("businessman")){ //商戶 imgRealPath = request.getSession().getServletContext().getRealPath("/resources/image/businessman"); } System.out.println(imgRealPath);//在控制臺打印一下路徑 //上傳完成后保存的文件名 String fileName= account + ".jpg"; //文件夾不存在的話,新建一個(gè) File fileFolder = new File(imgRealPath); if(!fileFolder.exists()){ fileFolder.mkdirs(); } File file = new File(fileFolder,fileName); //transferTo(),springMVC的方法,用于圖片上傳時(shí),將內(nèi)存中的圖片寫入磁盤 headImg.transferTo(file);//會報(bào)IO異常 result = "success"; } }catch (IOException e){ e.printStackTrace(); } Map<String,Object> resultMap = new HashMap<String,Object>(); resultMap.put("result",result); return resultMap; } }
總結(jié)
以上所述是小編給大家介紹的springMVC使用ajaxFailUpload上傳圖片,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Spring Boot Jar 包部署腳本的實(shí)例講解
在本篇文章里小編給大家整理的是一篇關(guān)于Spring Boot Jar 包部署腳本的實(shí)例講解內(nèi)容,對此有興趣的朋友們可以跟著學(xué)習(xí)下。2021-12-12解決@NonNull @org.jetbrains.annotations.NotNull報(bào)紅的問題
這篇文章主要介紹了解決@NonNull @org.jetbrains.annotations.NotNull報(bào)紅的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01Spring?Security實(shí)現(xiàn)HTTP認(rèn)證
本文主要介紹了Spring?Security實(shí)現(xiàn)HTTP認(rèn)證,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧<BR>2022-06-06SpringBoot請求參數(shù)加密、響應(yīng)參數(shù)解密的實(shí)現(xiàn)
在項(xiàng)目開發(fā)工程中,有的項(xiàng)目可能對參數(shù)安全要求比較高,在整個(gè)http數(shù)據(jù)傳輸?shù)倪^程中都需要對請求參數(shù)、響應(yīng)參數(shù)進(jìn)行加密,本文主要介紹了SpringBoot請求參數(shù)加密、響應(yīng)參數(shù)解密的實(shí)現(xiàn),感興趣的可以了解一下2024-01-01MyBatis在Spring環(huán)境下的事務(wù)管理
MyBatis的設(shè)計(jì)思想很簡單,可以看做是對JDBC的一次封裝,并提供強(qiáng)大的動(dòng)態(tài)SQL映射功能。這篇文章主要介紹了MyBatis在Spring環(huán)境下的事務(wù)管理 ,需要的朋友可以參考下2019-07-07