java fetch_java前后分离使用fetch上传文件失败500

这次不是写什么技术要点,仅仅是记录一下 最近遇到的一个问题

背景

使用fetch向java后台上传文件时,前端调试报错500,后端的报错为multipart 无法解析,翻译过来大概是这个意思。

由于本人不会java所以这里只是记录一下前端的注意事项。

原因

问题的主要原因在于,我在上传时设置了contenttype,这里就不得不提一下,fetch中由于之前使用的时候如果我不设置contenttype那么我向后端传送json时就会报错。

因为contenttype本来就是用于设置http的格式的,所以我在上传之前手动的在配置里设置了contenttype 为 multipart/form-data。

没想到问题就出在这里,当我们手动设置后fetch将不再为form-data自动添加文件边界,所以造成后端无法解析。

其实这个问题在使用ajax时也是存在的,不知道大家记不记得在使用jq的ajax上传时要设置这样的两个属性:

contentType: false, //false即不设置contenttype

processData: false //是否对参数进行序列化处理

contentType设为false即不设置本次http请求的contentType,而下面的processData则是不让jq处理我们在data中添加的数据,

否则ajax会在传输之前使用JSON.stringify()方法帮我们将数据转为json字符串

解决

最后的fetch上传成功的配置如下:

var options ={"method": 'post',"credentials": "include","headers": {'Accept': 'application/json'}

};

上传时千万不要自己设置contenttype,不要设置!不要设置!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java前后端分离是一种常见的架构模式,它将前端和后端的开发分离,使得两者可以独立开发、测试和部署。以下是实现Java前后端分离的一般步骤: 1. 定义接口:首先,前后端需要共同定义接口,即前后端交互的数据格式和接口规范。可以使用类似Swagger的工具来定义和生成接口文档。 2. 前端开发:前端开发人员使用HTML、CSS和JavaScript等技术开发用户界面,通过Ajax或其他方式调用后端接口获取数据。 3. 后端开发:后端开发人员使用Java等后端技术开发业务逻辑和数据处理部分,并提供RESTful API或其他方式的接口供前端调用。 4. 接口对接:前端通过调用后端提供的接口来获取数据或提交请求。可以使用类似Axios或Fetch等工具来发送HTTP请求。 5. 跨域处理:由于前后端分离时,前端和后端可能运行在不同的域名或端口下,需要处理跨域请求。可以在后端配置允许跨域访问的设置,或使用反向代理服务器如Nginx进行跨域代理。 6. 测试与调试:前后端可以独立进行测试和调试。前端可以使用类似Postman或浏览器插件来测试后端接口的返回数据,后端可以使用单元测试框架如JUnit来进行接口测试。 7. 部署与发布:前后端可以独立进行部署和发布。前端可以将静态资源(HTML、CSS、JavaScript等)部署到Web服务器上,后端可以将Java应用部署到应用服务器上。 通过Java前后端分离的架构模式,可以提高开发效率、降低耦合度,并且使得前后端团队可以并行开发,更好地实现功能需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值