首页 技术 正文
技术 2022年11月23日
0 收藏 964 点赞 3,849 浏览 2597 个字

为什么一定要使用formdata格式……很大原因是因为当时我犯蠢……

前端肯定是JS了,具体不写了,使用Postman测试,后端语言是Java,框架Spring Boot,使用IntelliJ IDEA

一、基本类型

例:

可以看到form-data只能传递键值对形式。

简单类型直接传递就可以了。

使用FormData格式在前后端传递数据

使用FormData格式在前后端传递数据

二、对象类型

Java代码:

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;class User {
String name;
int age; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
}
}@RestController
@RequestMapping(value={"/example"})
public class Example { @RequestMapping(value={"/user"})
public void objectType(User user) {
return;
}}

前端数据:

name: 'xiaoming'
age: 18

三、复杂情况

行吧……直接说我遇到的问题,接收一个对象和一个对象数组。

同时接收两个参数时不可能的(至少我没发现),首先要建一个对象包含这两个参数。

上代码…

public class CLS1 {
int id;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
}
/***********************/
public class CLS2 {
String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
/***********************/
import java.util.ArrayList;public class Wrapper {
CLS1 cls1;
ArrayList<CLS2> cls2List;
public CLS1 getCls1() {
return cls1;
}
public void setCls1(CLS1 cls1) {
this.cls1 = cls1;
}
public ArrayList<CLS2> getCls2List() {
return cls2List;
}
public void setCls2List(ArrayList<CLS2> cls2List) {
this.cls2List = cls2List;
}
}
/***********************/
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.util.ArrayList;@RestController
@RequestMapping(value={"/example"})
public class Example {
@RequestMapping(value={"/complex"})
public void complexType(Wrapper wrapper) {
CLS1 cls1 = wrapper.getCls1();
ArrayList<CLS2> cls2s = wrapper.getCls2List();
}}

重点在于前端的数据格式:

cls1.id: 233
cls2List[0].name: 'hello'
cls2List[1].name: 'world'

四、前端格式化工具类

前端手打肯定很麻烦,写了一个对象转formdata键值对的函数,自己试了下没什么问题,有没有bug就不知道了……

function objToFd(obj, form, name) {
const fd = form || new FormData() if (typeof obj !== 'object' || obj instanceof File) {
fd.append(name, obj)
return fd
} const keyName = name ? name + '.' : '' for (const prop in obj) {
// 判断是自己的属性 且不为空
if (prop != null && obj.hasOwnProperty(prop) && obj[prop] != null && obj[prop] !== '') {
const val = obj[prop]
if (val instanceof Array) {
// 如果是数组
val.map((item, index) => {
objToFd(item, fd, keyName + prop + '[' + index + ']')
})
} else {
objToFd(val, fd, keyName + prop)
}
}
} return fd
}

测试:

let data = {
k1: "k1-v",
k2: 345,
k3: {
k31: [1, 2, { k313: 'k313-v' }],
k32: {
k321: 'k321-v',
k322: true,
k323: ['con', 'ff']
}
},
k4: '',
k5: undefined,
k6: ['m', 'd', 'z', 'z']
}const fd = objToFd(data);
for (var pair of fd.entries()) {
console.log(pair[0] + ': ' + pair[1])
}/******* 输出 *******/
k1: k1-v
k2: 345
k3.k31[0]: 1
k3.k31[1]: 2
k3.k31[2].k313: k313-v
k3.k32.k321: k321-v
k3.k32.k322: true
k3.k32.k323[0]: con
k3.k32.k323[1]: ff
k6[0]: m
k6[1]: d
k6[2]: z
k6[3]: z

以上全是自己在网上查资料&瞎试出来了,不保证准确性。

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,000
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,512
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,358
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,141
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,771
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,849