文章詳情頁(yè)
使用AJAX實(shí)現(xiàn)上傳文件
瀏覽:61日期:2022-06-12 11:05:06
本文實(shí)例為大家分享了使用AJAX實(shí)現(xiàn)上傳文件的具體代碼,供大家參考,具體內(nèi)容如下
需求:
在前端頁(yè)面選擇文件上傳到服務(wù)器的指定位置
前端代碼
<form id="uploadForm" method="post" enctype="multipart/form-data"> <label >上傳電子書(shū)</label> <input type="file" name="file" > <button id="upload" type="button" name="button" >上傳</button> </form>
$("#upload").click(function () { var formData = new FormData($("#uploadForm")[0]); $.ajax({ type: "post", url: "https://****:8443/fileUpload", //上傳文件的請(qǐng)求路徑必須是絕對(duì)路勁 data: formData, cache: false, processData: false, contentType: false, }).success(function (data) { console.log(data); alert("上傳成功"+data); filename=data; }).error(function () { alert("上傳失敗"); }); });
首先創(chuàng)建一個(gè)FormData實(shí)例,也就是空對(duì)象,將頁(yè)面中現(xiàn)有form表單將他初始化。通過(guò)AJAX提交給后臺(tái)
后端代碼
@PostMapping(value = "/fileUpload") @ResponseBody public String fileUpload(@RequestParam(value = "file") MultipartFile file, Model model, HttpServletRequest request) { if (file.isEmpty()) { System.out.println("文件為空空"); } String fileName = file.getOriginalFilename(); // 文件名 System.out.println(file.getOriginalFilename()); String suffixName = fileName.substring(fileName.lastIndexOf(".")); // 后綴名 String filePath = "C://pdf//"; // 上傳后的路徑 fileName = UUID.randomUUID() + suffixName; // 新文件名 File dest = new File(filePath + fileName); System.out.println("pdf文件路徑為:"+dest.getPath()); if (!dest.getParentFile().exists()) { dest.getParentFile().mkdirs(); System.out.println("上傳pdf文件+++++++++++"); System.out.println("pdf文件路徑為:"+dest.getPath()); } try { file.transferTo(dest); } catch (IOException e) { e.printStackTrace(); } String filename = "/pdf/" + fileName; return fileName; }
注意
1.@RequestParam(value = “file”) 中的file需要和input中的name屬性一致。
2.提交按鈕類(lèi)型Type=“Button”如果為“submit”的話(huà),提交完數(shù)據(jù)會(huì)刷新一次頁(yè)面。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持。
標(biāo)簽:
Ajax
相關(guān)文章:
1. php 使用html5 XHR2實(shí)現(xiàn)上傳文件與進(jìn)度顯示功能示例2. PHP處理Ajax請(qǐng)求與Ajax跨域3. SpringBoot基于Shiro處理ajax請(qǐng)求代碼實(shí)例4. PHP與 xajax使用方法說(shuō)明5. ajax實(shí)現(xiàn)提交時(shí)校驗(yàn)表單方法6. Ajax對(duì)xml信息的接收和處理操作實(shí)例分析7. 基于django和dropzone.js實(shí)現(xiàn)上傳文件8. 原生js實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求操作示例9. Ajax 的初步實(shí)現(xiàn)(使用vscode+node.js+express框架)10. vue3使用el-upload上傳文件示例詳解
排行榜
