SpringMVC 参数绑定详解

概述

记得之前跟前端同事联调接口的时候,后端SpringMVC需要接收数组类型的参数,然后跟前端说需要传数组类型过来。后来前端童鞋传了数组,但是后端接收不成功,联调失败。那时候由于时间关系没有仔细研究这块,当时想了个办法就是前端传一个json字符串,后端换成接收json字符串然后转成需要的数组对象。这显然不是一种好的做法,框架帮我们做好的事我们没有用上,还平白多了两次数据的转换。所以今天花时间研究了下,将springMVC的数据绑定做个总结。

1. 简单类型参数

即几种java原生的基本数据类型已经其封装类以及String类型。比较简单,选一种布尔类型来讲解。
测试代码:

    @RequestMapping(value = "test")@ResponseBodypublic Object testDataBind(@RequestParam(name = "test") Boolean test) {System.out.println(test);return "success";}

使用postman工具发送请求:
这里写图片描述

控制台输出:

true1

这种的比较简单,没有太多可说的。**这里需要注意的是,参数如果没有加@RequestParam注解的话,传参需要默认参数的名称test作为传参参数的名称,而且没有加注解的话,前端在发送http请求的时候可以不传该参数,也不会报错。但是如果加了该注解,在没有设置注解的属性required = false的前提下,该参数必传,不然会报400错误。如果该注解中指定了name属性,name前端需要以name的值作为前端传参名称,如果没有指定name属性,在按参数名称test为前端传参名称。**大家可逐一验证。

2. 简单类型数组/list

分别为两种情况:

1) 直接使用数组作为方法的参数,可以用@RequestParam注解修饰,如果使用List,必须使用@RequestParam注解修饰

接口代码:

    @RequestMapping(value = "test")@ResponseBodypublic Object testDataBind(String[] tests) {System.out.println(tests[0] + "    " + tests[1]);return "success";}

这种前端传参需要遵守一定格式。

  • form表单
    表单元素name的值必须一样
name="tests" value="arony1"
name="tests" value="arony2"12

postman发送请求:
这里写图片描述

控制台输出:

arony1    arony21
  • ajax
    数组各个元素值需用“,”隔开。
data:{"tests":"arony1,arony2"}1

值得注意的是,如果后端的springMVC方法参数用的是数组来接收的话,前端用ajax发送请求,那么只能用上面这一种格式传参,使用下面说的tests[0],tests[1]传参是不行的。
postman发送请求:
这里写图片描述

控制台输出:

arony1    arony21

2)使用自定义类里面封装一个数组或者List,用自定义类实例作为方法参数,不能用@RequestParam注解修饰

接口代码:

    @RequestMapping(value = "test")@ResponseBodypublic Object testDataBind(Person person) {System.out.println(person.getTests()[0] + "    " + person.getTests()[1]);return "success";}

Person:

    public class Person {private String[] tests;public String[] getTests() {return tests;}public void setTests(String[] tests) {this.tests = tests;}}
  • form表单

有两种形式进行传值

name="tests" value="arony1"
name="tests" value="arony2"12
name="tests[0]" value="arony1"
name="tests[1]" value="arony2"12

postman发送请求:
这里写图片描述
这里写图片描述

控制台输出:

arony1    arony21
  • ajax

    ajax也有两种方式传值:

data:{"tests":"arony1,arony2"}1
data:{"tests[0]":"arony1","tests[1]":"arony2"}1

效果跟表单完全一样。

3. 自定义类型

首先定义一个自定类型User,包含以下属性,生成get/set方法,toString方法:

    private Integer id;private String loginname;12

接口代码:

    @RequestMapping(value = "test")@ResponseBodypublic Object testDataBind(User user) {System.out.println(user);return "success";}

postman发送请求:
这里写图片描述
控制台输出:

User{id=1, loginname='arony'}1

可以看到,跟User属性名一样的参数如果传了值,就可以被User对象所接受,没有传的为默认值。
我们尝试下,给参数user加上@RequestParam注解看看。使用postman发送请求,会发现返回400。所以我们要理解@RequestParam注解含义,它标示的是该方法参数接受的是一个http参数。因此,如果是用一个自定义对象作为参数的话,不要在之前加上@RequestParam,因为SpringMVC在解析http请求的参数user的时候,不能将接收到的参数转化成一个User对象。

4. 自定义类型数组/list

注意:这种情况只能使用一个自定义类来包装数组/list。
再定义一个参数类:

public class Parameter {private Person[] person;public Person[] getPerson() {return person;}public void setPerson(Person[] person) {this.person = person;}
}

Person:

public class Person {private String tests;public String getTests() {return tests;}public void setTests(String tests) {this.tests = tests;}
}

接口代码:

    @RequestMapping(value = "test")@ResponseBodypublic Object testDataBind(Parameter parameter) {System.out.println(parameter.getPerson()[0].getTests() + "    " + parameter.getPerson()[1].getTests());return "success";}
  • form表单传参
name="person[0].tests" value="arony1"
name="person[1].tests" value="arony2"12
  • ajax传参
data:{"person[0].tests":"arony1","person[1].tests":"arony2"}1

postman发送请求:
这里写图片描述

控制台输出:

arony1    arony21

5. Map<String,基本类型>

与上面一样 这种情况只能使用一个自定义类来包装map。

Parameter:

public class Parameter {private Map<String, String> map;public Map<String, String> getMap() {return map;}public void setMap(Map<String, String> map) {this.map = map;}
}

接口代码:

    @RequestMapping(value = "test")@ResponseBodypublic Object testDataBind(Parameter parameter) {parameter.getMap().forEach((key, value) -> {System.out.println(key + "   " + value);});return "success";}

前端传参格式:

  • form表单
name="map[key1]" value="arony1"
name="map[key2]" value="arony2"
或者
name="map.key1" value="arony1"
name="map.key2" value="arony2"12345
  • ajax
data:{"map[key1]":"arony1","map[key2]":"arony2"}
或者
data:{"map.key1":"arony1","map.key2":"arony2"}123

postman发送请求:
这里写图片描述
这里写图片描述

控制台输出:

key1   arony1
key2   arony212

6. Map<String, 自定义类>

跟5是很类似的。
Parameter:

public class Parameter {private Map<String, Person> map;public Map<String, Person> getMap() {return map;}public void setMap(Map<String, Person> map) {this.map = map;}
}

Person:

public class Person {private String tests;public String getTests() {return tests;}public void setTests(String tests) {this.tests = tests;}
}

接口代码:

    @RequestMapping(value = "test")@ResponseBodypublic Object testDataBind(Parameter parameter) {parameter.getMap().forEach((key, value) -> {System.out.println(key + "   " + value.getTests());});return "success";}

前端传参格式:

  • form表单
name="map[key1].tests" value="arony1"
name="map[key2].test2" value="arony2"12

这里注意,name=”map.key1.tests” value=”arony1”这样传值是不行的。必须用方括号。

  • ajax
data={"map[key1].tests":"arony1","map[key2].test2":"arony2"}1

这里也必须使用方括号。

使用postman发送请求:
这里写图片描述

控制台输出:

key1   arony1
key2   arony212

总结

以上的SpringMVC参数绑定可以总结为下图:

这里写图片描述

其中,Map<String, ①> 前端还可以使用“.”代替方括号。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/555244.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java 连接远程服务器_java实现连接远程服务器并执行命令的基本原理

一、所需jar包需要借助Ganymed SSH的jar包: ganymed-ssh2-build210.jar二、实现原理Ganymed SSH-2 java在整个访问过程中担当SSH的客户端&#xff0c;由于Linux系统自带SSH服务&#xff0c;所以可以直接访问Linux系统并执行相关命令&#xff0c;而 Windows系统则需要首先安装S…

SpringMVC接收基本类型和包装类型

先看一个示例&#xff1a; 注意这两个参数都没有加RequestParam注解。 测试&#xff1a; 直接报错。即没有加RequestParam注解&#xff0c;基本数据类型参数是必填的。 再测试&#xff1a; 直接返回null&#xff0c;也就是说包装类型参数&#xff0c;没有加RequestParam注解&…

SpringMVC 【参数绑定详讲、默认支持参数类型、自定义参数绑定、RequestParam 注解】

SpringMVC 第四篇【参数绑定详讲、默认支持参数类型、自定义参数绑定、RequestParam 注解】 参数绑定 我们在 Controller 使用方法参数接收值&#xff0c;就是把 web 端的值给接收到 Controller 中处理&#xff0c;这个过程就叫做参数绑定… 默认支持的参数类型 从上面的用…

MySQL中 IS NULL、IS NOT NULL、不等于, 能用上索引吗?

MySQL的WHERE子句中包含 IS NULL、IS NOT NULL、! 这些条件时便不能使用索引查询&#xff0c;只能使用全表扫描。 告诉大家结论&#xff1a; MySQL中决定使不使用某个索引执行查询的依据就是成本够不够小&#xff0c;如果null值很多&#xff0c;还是会用到索引的。 自己做了个…

Java EE 企业网站_基于jsp的企业网站系统-JavaEE实现企业网站系统 - java项目源码...

基于jspservletpojomysql实现一个javaee/javaweb的企业网站系统, 该项目可用各类java课程设计大作业中, 企业网站系统的系统架构分为前后台两部分, 最终实现在线上进行企业网站系统各项功能,实现了诸如用户管理, 登录注册, 权限管理等功能, 并实现对各类企业网站系统相关的实体…

MySQL创建联合索引,字段的先后顺序,对查询的影响分析

文章目录前言最左匹配原则为什么会有最左前缀呢&#xff1f;联合索引的存储结构联合索引字段的先后顺序b树可以存储的数据条数总结前言 ​ 对于联合索引我们知道&#xff0c;在使用的时候有一个最左前缀的原则&#xff0c;除了这些呢&#xff0c;比如字段放置的位置&#xff0…

php oracle 操作 sql语句中能不能添加数组_如何在PHP中使用Oracle数据库_php

在php3.0以上版本中&#xff0c;php内置了几乎目前所有的数据库处理函数&#xff0c;包括oracle;在本文中我们通过一个实例来介绍了如何使用这些函数来操作Oracle数据库。PHP提供了2大类API(应用程序接口)来操作Oracle数据库。一个是标准的Oracle处理函数(ORA) 另一个是Oracle …

mysql where过滤条件中and连接的两个条件的顺序不必和建立的联合索引的字段顺序一致_mysql and 顺序_mysql执行过程以及顺序

mysql中and的判断顺序 select * from a join b on 条件一 and 条件二条件一和二都是判断 id 字段&#xff0c; 条件一和条件二哪个先执行&#xff1f; 解析器会自动选择最优的流程执行的 这两个都是平级条件&#xff0c;理论上是没有先后顺序的&#xff01; 没有顺序&#xff…

MySQL优化器_MySQL查询优化器

MySQL优化器 MySQL架构图 讲到MySQL&#xff0c;就绕不开他的架构图。MySQL是一个经典的C/S架构。服务器这边分两层&#xff1a;第一层是Server层&#xff0c;第二层是存储引擎。Server层处理主要的业务操作流程&#xff0c;但不关心具体的存储逻辑。存储逻辑由存储引擎层去…

MySQL性能优化(一)MySQL中SQL语句是如何执行的?

该篇章将开始整理MySQL的优化&#xff0c;不过开始之前&#xff0c;我们想了解清楚那就是MySQL是怎么执行的。 文章目录1.MySQL驱动2.应用系统数据库连接池3.MySQL数据库连接池4.SQL执行过程4.1.线程监听&#xff1a;监听网络请求中的SQL语句4.2.SQL接口&#xff1a;负责处理接…

2023_Spark_实验三十三:配置Standalone模式Spark3.4.2集群

实验目的&#xff1a;掌握Spark Standalone部署模式 实验方法&#xff1a;基于centos7部署Spark standalone模式集群 实验步骤&#xff1a; 一、下载spark软件 下载的时候下载与自己idea里对应版本的spark News | Apache Spark 选择任意一个下载即可 - spark 3.4.1 - spark …

MySQL性能优化(二)InnoDB之日志文件

文章目录1.MySQL日志记录文件1.1.回顾SQL语句的执行1.2.InnoDB内存结构&#xff1a;缓冲池1.3.记录日志&#xff1a;Undo和Redo1.3.1.Undo日志文件&#xff1a;记录数据修改前的值1.3.2.Redo日志文件&#xff1a;记录数据即将修改值1.3.3.Undo和Redo的区别&#xff08;记录、前…

php正则检查QQ,PHP 正则匹配手机号的QQ号

//匹配手机号码//$mode /\d{3}-\d{8}|\d{4}-\d{7}|\d{11}/;//不匹配以-开头的手机号码//$mode /^((?!-).)*\d{3}-\d{8}|^((?!-).)*\d{4}-\d{7}|^((?!-).)*\d{11}/;//不匹配以 / 开头或结束的手机号码$mode /^((?!\/).)*\d{3}-\d{8}((?!\/).)*$|^((?!\/).)*\d{4}-\d{7}…

java获取单击内容,java – 单击菜单链接时,获取元素不是可点击的异常

我想点击菜单链接但没有运气.它总是显示异常 –Exception in thread “main” org.openqa.selenium.WebDriverException:unknown error: Element is not clickable at point (64, 64). Otherelement would receive the click: <div style”position: absolute; left:0px; to…

MySQL性能优化(三)Buffer Pool实现原理

文章目录1.回顾缓冲池 Buffer Pool2.配置Buffer Pool的大小3.Buffer Pool&#xff1a;数据结构3.1.磁盘数据结构&#xff1a;数据页3.2.缓冲池数据结构&#xff1a;数据页(缓存页)3.3.缓存页对应的描述信息4.Buffer Pool&#xff1a;初始化5.Buffer Pool&#xff1a;free链表6.…

MySQL性能优化(四)redo log实现原理

文章目录1.redo log的作用2.redo log的结构2.1.redo log 记录2.2.redo log block2.3.redo log buffer3.redo log buffer 刷盘1.redo log的作用 首先我们都知道&#xff0c;执行增删改SQL语句的时候&#xff0c;都是针对一个表中的某些数据去执行的&#xff0c;此时的话&#x…

MySQL性能优化(五)undo log是如何实现MVCC的?

之前我们最开始的几篇文章就讲过&#xff0c;你除了写redolog日志还必须要写undo log日志&#xff0c;这个undo log日志是至关重要的&#xff0c;没有他&#xff0c;你根本都没办法回滚事务&#xff01; 1.事务 1.1.多线程并发执行多个事务 对于我们的业务系统去访问数据库而…

Linux中Shell脚本--awk的用法

语法格式&#xff1a;awk [选项] ‘指令’ 操作文件 常用选项&#xff1a;-F 指定分隔符&#xff0c;分隔符用""引起来 -v&#xff1a;varvalue在awk程序开始之前指定一个值valu给变量var&#xff0c;这些变量值用于awk程序的BEGIN快 -f&#xff1a;后面跟一个保存…

linux下的shell脚本(基础)

Shell是一种脚本语言&#xff0c;那么&#xff0c;就必须有解释器来执行这些脚本&#xff0c;常见的脚本解释器有&#xff1a; bash&#xff1a;是Linux标准默认的shell。bash由Brian Fox和Chet Ramey共同完成&#xff0c;是BourneAgain Shell的缩写&#xff0c;内部命令一共有…

mysql rsync复制,mysql复制又同步

mysql复制再同步由于一个老旧系统没有使用LVM分区,导致mylvmbackup不能使用。为了重新全量同步数据库&#xff0c;发现rsync可以使用&#xff0c;并且锁住数据库的时间不长。1. 首先刷新数据库到文件flush tables with read lock;unlock tables;2. 执行rsync进行数据库同步/usr…