使用ajax+SpringBoot传输文件时踩得坑

博主在实训项目中使用SpringBoot传输文件和字符串,采用Ajax异步传输,初次使用时问题频出。经排查,大部分问题源于在方法外声明变量,导致一系列问题,折磨两天后才发现正确做法,记录下来以作提醒。
最近在写实训项目时要用到SpringBoot传输文件+字符串,想到ajax异步传输,真正用起来,才发现自己在前端真的一窍不通,初次使用ajax也是漏洞百出,出现了许多问题,但是大部分问题都来源于一个原因,看下面
  • 这是我的Script代码

    <script>
        
        var formData = new FormData();//表单对象
    
    				var type = $("#type").val();
    				var name = $("#name").val();
    				var date = $("#date").val();
    				var actors = $("#actors").val();
    				var introduction = $("#introduction").val();
    
    				formData.append("type",type);
    				formData.append("name",name);
    				formData.append("date",date);
    				formData.append("actors",actors);
    				formData.append("introduction",introduction);
    
    				formData.append("filename1",$("#filename")[0].files[0]);
    				formData.append("picname1",$("#picname")[0].files[0]);
    
    			function upload() {
                    
    				//json传输
    				$.ajax({
    					url: "/upload",
    					data: formData,
    					dataType: "JSON",
    					type: "POST",
    					contentType: false,
    					processData: false,
    					success: function (data) {
    						if (data > 0) {
    							alert("上传成功")
    						} else {
    							alert("上传失败");
    						}
    					}
    				});
    			}
    
    		</script>
    

    可能一眼就能看出哪里不对,我在方法外声明变量了,这导致了一系列的问题,折磨了我两天

    正确的是这样的

    function upload() {
    
    				var formData = new FormData();//表单对象
    
    				var type = $("#type").val();
    				var name = $("#name").val();
    				var date = $("#date").val();
    				var actors = $("#actors").val();
    				var introduction = $("#introduction").val();
        
    				formData.append("type",type);
    				formData.append("name",name);
    				formData.append("date",date);
    				formData.append("actors",actors);
    				formData.append("introduction",introduction);
        
    				formData.append("filename1",$("#filename")[0].files[0]);
    				formData.append("picname1",$("#picname")[0].files[0]);
        
    				//json传输
    				$.ajax({
    					url: "/upload",
    					data: formData,
    					dataType: "JSON",
    					type: "POST",
    					contentType: false,
    					processData: false,
    					success: function (data) {
    						if (data > 0) {
    							alert("上传成功")
    						} else {
    							alert("上传失败");
    						}
    					}
    				});
    			}
    

可能除了我没人会踩这个坑了吧,写给自己,让自己长点记性。

### 使用 Vue 和 Spring Boot 构建文件传输管理系统 #### 后端实现:Spring Boot 文件上传和下载接口 为了支持文件的上传与下载操作,在后端可以基于 Spring Boot 来创建 RESTful API 接口。具体来说,通过 `@RestController` 注解定义控制器类,并利用 `MultipartFile` 参数处理客户端发送过来的二进制数据流来完成文件保存逻辑[^2]。 ```java @RestController @RequestMapping("/api/files") public class FileController { @PostMapping("/upload") public ResponseEntity<String> uploadFile(@RequestParam("file") MultipartFile file){ try { // 处理文件存储业务... return new ResponseEntity<>("Upload successful", HttpStatus.OK); } catch (Exception e) { return new ResponseEntity<>(e.getMessage(), HttpStatus.EXPECTATION_FAILED); } } @GetMapping("/{fileName:.+}") public ResponseEntity<Resource> downloadFile(@PathVariable String fileName, HttpServletRequest request){ // 实现文件读取并返回给前端的功能... } } ``` #### 前端实现:Vue.js 页面交互设计 对于前端部分,则采用 Vue.js 框架搭建用户界面。页面上提供表单用于选择本地文件并通过 AJAX 请求提交至服务器;同也可以展示已有的资源列表供浏览者点击链接触发下载行为。 ```html <template> <div id="app"> <!-- 文件上传组件 --> <input type="file" ref="fileInput"/> <button v-on:click="handleUpload">上传</button> <!-- 已有文件列表 --> <ul> <li v-for="(item,index) in fileList" :key="index"><a href="#" @click.prevent="download(item.name)"> {{ item.name }}</a></li> </ul> </div> </template> <script> export default { data() { return {fileList:[], selectedFile:null}; }, methods:{ handleUpload(){ this.selectedFile=this.$refs.fileInput.files[0]; const formData=new FormData(); formData.append('file',this.selectedFile); fetch('/api/files/upload',{ method:'POST', body:formData, }).then(response=>response.json()).then(result=>{ console.log('Success:',result); }); }, download(filename){ window.location.href=`/api/files/${filename}`; } } } </script> ``` #### 完整解决方案集成 结合上述前后端技术栈,能够快速建立起一套简易但实用的企业级文档共享平台或者个人网盘服务应用。当然实际项目中还需要考虑诸如安全性验证、并发性能优化等方面因素[^1]。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值