网易首页 > 网易号 > 正文 申请入驻

【317期】@RequestBody 接收数组、List 参数、@Deprecated 标记废弃方法

0
分享至

点击上方“Java精选”,选择“设为星标”

别问别人为什么,多问自己凭什么!

下方有惊喜,留言必回,有问必答!

每一天进步一点点,是成功的开始...


目录

  • @RequestBody 概述

  • 接收单个 String 参数

  • 接收 字符串数组 参数

  • 接收 List 参数

  • 接收整形数组

  • 接收单个 POJO 对象

  • 接收 POJO List 参数

  • @Deprecated 标记废弃方法

1、@RequestBody主要用来接收前端传递给后端的 json 格式的数据的(请求体中的数据的),有一个属性 required,表示参数是否必须要传,默认为 true.

2、GET 方式无请求体,所以@RequestBody接收数据时,前端必须是 POST 方式进行提交,然后给页面的数据默认也是 json

3、同一个方法中,@RequestBody@RequestParam()可以同时使用,前者最多只能有一个,后者可以有多个,

4、@RequestBody 接收的是请求体里面的数据,@RequestParam接收的是key-value里面的参数。

后台代码:


* 单个参数时使用 String 类型传输,比如 int、long、flout 等等,都使用 String
* @param uid
* @return
@PostMapping("save4")
public String save4(@RequestBody String uid) {
logger.info("保存单个参数:" + uid);
return "保存完毕:" + uid;

前端 ajax 代码:

$.ajax({
//默认传输的内容类型为 key-value 型,后台使用数组、List 接收参数时,
// headers 中必须指定内容类型为 json 类型,否则会报415错误
headers: {
'Content-Type': 'application/json;charset=utf8'
},
type: "post",
url: "http://localhost:8080/user/save4",
//指定 json 类型后,传输的数据理所当然应该是 json 格式。
data: JSON.stringify({"uid": "9527"}),
success: function (data) {
console.log(data);
},
error: function (data) {
console.log("ERROR:" + JSON.stringify(data));

后台 MVC 代码:


* @param ids :接收页面单个:参数字符串数组。必须加 org.springframework.web.bind.annotation.RequestBody 注解。
* 如果是整形数组,则换成 Integer[] ids 即可。
* @return
@PostMapping("save1")
public String save1(@RequestBody String[] ids) {
logger.info("save1--->" + Arrays.asList(ids));
return new Date() + "传输完毕:" + Arrays.asList(ids);

前端 ajax 代码:

var data = ["18ui", "89uj", "987u", "98uj"];//如果后台接收的是整形数组,则 data 中使用整形即可,如:data = [80, 90, 100, 110,120];
$.ajax({
//默认传输的内容类型为 key-value 型,后台使用数组、List 接收参数时,
// headers 中必须指定内容类型为 json 类型,否则会报415错误
headers: {
'Content-Type': 'application/json'
},
type: "post",
url: "http://localhost:8080/user/save1",
//指定 json 类型后,传输的数据理所当然应该是 json 格式。
data: JSON.stringify(data),
success: function (data) {
console.log(data);
},
error: function (data) {
console.log("ERROR:" + JSON.stringify(data));

完全与数组同理,后台 MVC 代码:


* @param ids :接收页面单个:字符串 List。必须加 @RequestBody 注解
* @return
@PostMapping("save2")
public String save2(@RequestBody List ids) {
logger.info("save2--->" + ids);
return new Date() + "传输完毕:" + ids;

前端 ajax 代码(与数组前端完全一致):

//因为 ArrayList 底层也是数组,不难明白前端都传数组
var data = [{"name": "华安", "id": 9527, "salary": 8890.98}, {"name": "张三", "id": 9528, "salary": 8790.98}];

$.ajax({
//默认传输的内容类型为 key-value 型,后台使用数组、List 接收参数时,
// headers 中必须指定内容类型为 json 类型,否则会报415错误
headers: {
'Content-Type': 'application/json'
},
type: "post",
url: "http://localhost:8080/user/save2",
//指定 json 类型后,传输的数据理所当然应该是 json 格式。
data: JSON.stringify(data),
success: function (data) {
console.log(data);
},
error: function (data) {
console.log("ERROR:" + JSON.stringify(data));
}
});
/**
* http://localhost:8080/sys/backupSalary
* 页面传入 json 数据:[{"name":"华安","id":9527,"salary":8890.98}]
* 直接转换为 List
*
* @param mapList
* @return
* @throws JsonProcessingException
*/
@PostMapping("backupSalary")
public String backupSalary(@RequestBody List> mapList) throws JsonProcessingException {
System.out.println(mapList);
ObjectMapper objectMapper = new ObjectMapper();
String result = objectMapper.writeValueAsString(mapList);
return result;
}

整型 List 、Flout等其它类型也是同理,会自动转型。后台代码:


* Long[] ids 参数时,前端也使用整型
* @param ids
* @return
@PostMapping("save5")
public String save5(@RequestBody Long[] ids) {
logger.info("save5--->" + Arrays.asList(ids));
return new Date() + "传输完毕:" + Arrays.asList(ids);

前端 ajax 代码:

var data = [1, 2, 3, 4, 5, 10, 22];
$.ajax({
//默认传输的内容类型为 key-value 型,后台使用数组、List 接收参数时,
// headers 中必须指定内容类型为 json 类型,否则会报415错误
headers: {
'Content-Type': 'application/json;charset=utf8'
},
type: "post",
url: "http://localhost:8080/user/save5",
//指定 json 类型后,传输的数据理所当然应该是 json 格式。
data: JSON.stringify(data),
success: function (data) {
console.log(data);
},
error: function (data) {
console.log("ERROR:" + JSON.stringify(data));

后台提供一个 POJO 对象:

class User {
private Integer uId;
private String uName;

public Integer getuId() {
return uId;
}

public void setuId(Integer uId) {
this.uId = uId;
}

public String getuName() {
return uName;
}

public void setuName(String uName) {
this.uName = uName;
}

@Override
public String toString() {
return "User{" +
"uId=" + uId +
", uName='" + uName + '\'' +
'}';
}
}

后台 mvc 代码:


* 保存单个实体
* @param user
* @return
@PostMapping("save6")
public String save6(@RequestBody User user) {
logger.info("save6=> " + user.toString());
return "保存完成:" + user;

前端 ajax 代码:

var data = {"uId": 1000, "uName": "华安"};
$.ajax({
//默认传输的内容类型为 key-value 型,后台使用数组、List 接收参数时,
// headers 中必须指定内容类型为 json 类型,否则会报415错误
headers: {
'Content-Type': 'application/json;charset=utf8'
},
type: "post",
url: "http://localhost:8080/user/save6",
//指定 json 类型后,传输的数据理所当然应该是 json 格式。
data: JSON.stringify(data),
success: function (data) {
console.log(data);
},
error: function (data) {
console.log("ERROR:" + JSON.stringify(data));

POJO 数组也是同理。后台 MVC 代码:


* @param userList :接收页面单个:POJO List。必须加 @RequestBody 注解
* @return
@PostMapping("save3")
public String save3(@RequestBody List userList) {
for (User user : userList) {
logger.info("save3--->" + user);
return new Date() + "传输完毕:" + userList;

前端 ajax 代码:

//后台是 List,则前台使用数组([])表示 List,使用 json 对象表示 User 对象
var data = [];
for (var i = 0; i < 3; i++) {
var user = {};//每一个 json 对象相当于后台的 User 对象,因为都是 key-value 格式。
user.uId = (i + 1);//key 值必须与后台 POJO 属性一致。value 的类型必须与后台数据类型一致。
user.uName = "huaAn_" + (i + 1);
data.push(user);//将 json 对象添加到数组中
$.ajax({
//默认传输的内容类型为 key-value 型,后台使用数组、List 接收参数时,
// headers 中必须指定内容类型为 json 类型,否则会报415错误
headers: {
'Content-Type': 'application/json'
},
type: "post",
url: "http://localhost:8080/user/save3",
//指定 json 类型后,传输的数据理所当然应该是 json 格式。
data: JSON.stringify(data),
success: function (data) {
console.log(data);
},
error: function (data) {
console.log("ERROR:" + JSON.stringify(data));

1、应用中对于外部正在调用或者二方库依赖的接口,不允许修改方法签名,避免对接口调用方产生影响,过时接口可以加上@Deprecated注解,并清晰地说明采用的新接口或新服务是什么。

2、@Deprecated注解表示 "废弃;不赞成;不推荐使用",可以标注的位置有:@Target(value={CONSTRUCTOR, FIELD, LOCAL_VARIABLE, METHOD, PACKAGE, PARAMETER, TYPE})

3、比如某个类或某方法加上该注解之后,表示此方法或类不再建议使用,调用时编辑器也会自动提示删除线,但并不代表不能用,只是不推荐使用,因为还有更好的方法可以调用。

public class HelloWorld {
//id 不再推荐使用,请使用 uId
@Deprecated
private String id;
private String uId;

//showInfo() 方法不再推荐使用,1.5 版本开始请使用 getInfo
@Deprecated
public void showInfo() {
String info = "天下归心";
System.out.println(info);
}
/**
* @since 1.5
*/
public String getInfo() {
String info = "天下归心";
return info;
}
}

作者:蚩尤后裔 https://wangmaoxiong.blog.csdn.net/article/details/95042420

公众号“Java精选”所发表内容注明来源的,版权归原出处所有(无法查证版权的或者未注明出处的均来自网络,系转载,转载的目的在于传递更多信息,版权属于原作者。如有侵权,请联系,笔者会第一时间删除处理!

------ THE END ------

精品资料,超赞福利!


3000+ 道各类技术面试题在线刷,最新、最全 Java 面试题!

期往精选 点击标题可跳转

技术交流群!

最近有很多人问,有没有读者交流群!想知道如何加入?方式很简单,兴趣相投的朋友,只需要点击下方卡片,回复“加群”,即可无套路入交流群!

文章有帮助的话,在看,转发吧!

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
41分+42分+50分!联盟第1!对不起,约基奇,他也要抢MVP

41分+42分+50分!联盟第1!对不起,约基奇,他也要抢MVP

世界体育圈
2026-01-09 22:23:13
一路走好!2026年不到3天,4位名人接连去世,最年轻的仅25岁

一路走好!2026年不到3天,4位名人接连去世,最年轻的仅25岁

胡一舸南游y
2026-01-06 13:19:29
周薪30万英镑!枪手头牌即将续约5年 超越哈弗茨成队内第一高薪

周薪30万英镑!枪手头牌即将续约5年 超越哈弗茨成队内第一高薪

雪狼侃体育
2026-01-10 13:31:53
罗塞尼尔:我会带领切尔西争冠

罗塞尼尔:我会带领切尔西争冠

体坛周报
2026-01-10 13:38:09
脏到包浆、不堪入目!又一网红店跌落神坛,多位明星网红曾打卡

脏到包浆、不堪入目!又一网红店跌落神坛,多位明星网红曾打卡

品牌观察官
2025-12-30 17:28:27
俄反潜机首次在北极完成空中加油!联合国安理会将召开乌克兰局势紧急会议!乌全境频遭空袭,我使馆发布重要提醒

俄反潜机首次在北极完成空中加油!联合国安理会将召开乌克兰局势紧急会议!乌全境频遭空袭,我使馆发布重要提醒

每日经济新闻
2026-01-10 14:13:09
今晚开播!央视又一40集黑马年代剧来袭,演员阵容不错,值得期待

今晚开播!央视又一40集黑马年代剧来袭,演员阵容不错,值得期待

蓝莓影视推荐
2026-01-10 13:25:10
特朗普重磅表态:台湾属于中国,郑丽文访陆时间确定,王金平回应

特朗普重磅表态:台湾属于中国,郑丽文访陆时间确定,王金平回应

卷史
2026-01-09 16:26:16
1月10日,多家上市公司发布重大利好利空消息

1月10日,多家上市公司发布重大利好利空消息

A股数据表
2026-01-10 06:25:03
中组部有关干部局负责同志宣布党中央决定:曲光吉履新职

中组部有关干部局负责同志宣布党中央决定:曲光吉履新职

上观新闻
2026-01-09 16:52:05
特朗普一句轻飘飘的话,把日本给吓得不轻,李在明:马上就去日本

特朗普一句轻飘飘的话,把日本给吓得不轻,李在明:马上就去日本

青烟小先生
2026-01-10 14:22:51
中国再生资源开发集团有限公司党委书记、董事长、总经理邢宏伟被查

中国再生资源开发集团有限公司党委书记、董事长、总经理邢宏伟被查

新京报
2026-01-10 10:26:06
“冻龄岳父”火了,婚礼牵女儿被认成“新郎”,伴娘:以为换人了

“冻龄岳父”火了,婚礼牵女儿被认成“新郎”,伴娘:以为换人了

大果小果妈妈
2026-01-08 13:25:42
体育圈又曝大瓜!13岁体操少女遭教练打骂索财,跳楼致重伤

体育圈又曝大瓜!13岁体操少女遭教练打骂索财,跳楼致重伤

全景体育V
2026-01-10 06:20:32
哇塞!香港知名富家千金低调完婚,闭门婚礼竟只摆十桌宴!

哇塞!香港知名富家千金低调完婚,闭门婚礼竟只摆十桌宴!

智凌纵横
2025-11-18 15:29:56
那个连登14次春晚的歌坛巨星,如今家产被拍卖“住进”养老院?

那个连登14次春晚的歌坛巨星,如今家产被拍卖“住进”养老院?

车窗起雾q
2026-01-09 22:15:01
罗晋携任素汐去祈福后,唐嫣连发三文表态,婚变传闻终于真相大白

罗晋携任素汐去祈福后,唐嫣连发三文表态,婚变传闻终于真相大白

瓜汁橘长Dr
2025-12-29 11:29:56
他可能是有史以来最受欢迎的男人

他可能是有史以来最受欢迎的男人

最爱历史
2026-01-09 11:26:09
国民党新主席提“一国两区”,大陆回应欢迎来访,两岸关系有新变化?

国民党新主席提“一国两区”,大陆回应欢迎来访,两岸关系有新变化?

林子说事
2026-01-09 08:43:58
秦昊没想到,离春节不到俩月,57岁伊能静凭一举动,再次给他长脸

秦昊没想到,离春节不到俩月,57岁伊能静凭一举动,再次给他长脸

青史楼兰
2026-01-10 09:16:15
2026-01-10 15:08:49
Java精选
Java精选
一场永远也演不完的戏
1766文章数 3859关注度
往期回顾 全部

科技要闻

传DeepSeek准备第二次震惊全世界

头条要闻

媒体:中国若在其任期统一特朗普不悦 中方回应滴水不漏

头条要闻

媒体:中国若在其任期统一特朗普不悦 中方回应滴水不漏

体育要闻

怒摔水瓶!杜兰特30+12 难阻火箭遭双杀

娱乐要闻

赵樱子称和蒋毅试婚三天:像试面膜

财经要闻

投资必看!瑞银李萌给出3大核心配置建议

汽车要闻

宝马25年全球销量246.3万台 中国仍是第一大市场

态度原创

艺术
游戏
时尚
本地
数码

艺术要闻

你能认出毛主席手书的全部吗?揭秘其中隐藏的秘密!

拉瑞安确认《神界》新作不会再用AI生成概念艺术

专栏 | 做“主语”的体验

本地新闻

云游内蒙|“包”你再来?一座在硬核里酿出诗意的城

数码要闻

最快续航最久的XM模具 雷柏 VT0/VT0 Max鼠标实测:这是目前最均衡的轻量化旗舰

无障碍浏览 进入关怀版