SpringMVC请求与响应(一)

简介: SpringMVC请求与响应(一)

1. 请求映射路径【重点】


问题导入

@RequestMapping注解注解可以写在哪?有什么作用?


1.1 @RequestMapping注解


名称:@RequestMapping

类型:方法注解 类注解

位置:SpringMVC控制器方法定义上方

作用:设置当前控制器方法请求访问路径,如果设置在类上统一设置当前控制器方法请求访问路径前缀

范例


@Controller
//类上方配置的请求映射与方法上面配置的请求映射连接在一起,形成完整的请求映射路径
@RequestMapping("/user")
public class UserController {
    //请求路径映射
    @RequestMapping("/save") //此时save方法的访问路径是:/user/save
    @ResponseBody
    public String save(){
        System.out.println("user save ...");
        return "{'module':'user save'}";
    }
}


2. 请求参数


2.1 发送普通类型参数【重点】


问题导入


如何解决POST请求中文乱码问题?


2.1.1 请求方式


GET请求

POST请求


2.1.2 GET请求传递普通参数


普通参数:url地址传参,地址参数名与形参变量名相同,定义形参即可接收参数


c2656b6f8c1dc8023f31dcc1943d012c_09a22844984032724cd1b6a71c806b78.png


//普通参数:请求参数与形参名称对应即可完成参数传递
@RequestMapping("/commonParam")
@ResponseBody
public String commonParam(String name ,int age){
    System.out.println("普通参数传递 name ==> "+name);
    System.out.println("普通参数传递 age ==> "+age);
    return "{'module':'common param'}";
}


问题:如果传递的参数是中文试试,你们会发现接收到的参数出现了中文乱码问题。

原因:tomcat 8.5版本之后GET请求就不再出现中文乱码问题,但是我们使用的是tomcat7插件,所以会出现GET请求中文乱码问题。


解决:在pom.xml添加tomcat7插件处配置UTF-8字符集,解决GET请求中文乱码问题。
<build>
    <plugins>
      <plugin>
        <groupId>org.apache.tomcat.maven</groupId>
        <artifactId>tomcat7-maven-plugin</artifactId>
        <version>2.1</version>
        <configuration>
          <port>80</port><!--tomcat端口号-->
          <path>/</path> <!--虚拟目录-->
          <uriEncoding>UTF-8</uriEncoding><!--访问路径编解码字符集-->
        </configuration>
      </plugin>
    </plugins>
  </build>


2.1.3 POST请求传递普通参数


普通参数:form表单post请求传参,表单参数名与形参变量名相同,定义形参即可接收参数


d41fb14e595ce18c4cec8f8ad2efad38_db62a71ec4af08377a0d1fc0dc62d77c.png


//普通参数:请求参数与形参名称对应即可完成参数传递
@RequestMapping("/commonParam")
@ResponseBody
public String commonParam(String name ,int age){
    System.out.println("普通参数传递 name ==> "+name);
    System.out.println("普通参数传递 age ==> "+age);
    return "{'module':'common param'}";
}


问题:我们发现,POST请求传递的参数如果包含中文那么就会出现中文乱码问题,说明我们之前配置的tomcat插件uri路径编解码字符集无法解决POST请求中文乱码问题。那么如何解决呢?


2.1.4 POST请求中文乱码处理


在加载SpringMVC配置的配置类中指定字符过滤器。


public class ServletContainersInitConfig extends AbstractAnnotationConfigDispatcherServletInitializer {
    protected Class<?>[] getRootConfigClasses() {
        return new Class[0];
    }
    protected Class<?>[] getServletConfigClasses() {
        return new Class[]{SpringMvcConfig.class};
    }
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }
    //乱码处理
    @Override
    protected Filter[] getServletFilters() {
        CharacterEncodingFilter filter = new CharacterEncodingFilter();
        filter.setEncoding("UTF-8");
        return new Filter[]{filter};
    }
}



2.2 五种类型参数传递


问题导入


当请求参数名与形参变量名不同,该如何接收请求参数?


2.2.1 五种类型参数介绍


普通参数

POJO类型参数

嵌套POJO类型参数

数组类型参数

集合类型参数


2.2.2 普通参数【重点】


普通参数:当请求参数名与形参变量名不同,使用@RequestParam绑定参数关系


be80819d78ac37474c84c2c2d120b28f_0ca4a45293408324fadbdfc956da6693.png


//普通参数:请求参数名与形参名不同时,使用@RequestParam注解关联请求参数名称与形参名称之间的关系
@RequestMapping("/commonParamDifferentName")
@ResponseBody
public String commonParamDifferentName(@RequestParam("name") String userName , int age){
    System.out.println("普通参数传递 userName ==> "+userName);
    System.out.println("普通参数传递 age ==> "+age);
    return "{'module':'common param different name'}";
}


名称:@RequestParam

类型:形参注解

位置:SpringMVC控制器方法形参定义前面

作用:绑定请求参数与处理器方法形参间的关系

参数:


required:是否为必传参数

defaultValue:参数默认值


2.2.3 POJO类型参数【重点】


POJO参数:请求参数名与形参对象属性名相同,定义POJO类型形参即可接收参数


4811f417be102611c08cc9f37df3b665_d2cbb4cd47e967fa82ee6ad615315fd9.png


public class User {
    private String name;
    private int age;
    //同学们自己添加getter/setter/toString()方法
}


// POJO参数:请求参数与形参对象中的属性对应即可完成参数传递
@RequestMapping("/pojoParam")
@ResponseBody
public String pojoParam(User user){
    System.out.println("pojo参数传递 user ==> "+user);
    return "{'module':'pojo param'}";
}


注意事项:请求参数key的名称要和POJO中属性的名称一致,否则无法封装。


2.2.4 嵌套POJO类型参数


POJO对象中包含POJO对象
public class User {
    private String name;
    private int age;
    private Address address;
    //同学们自己添加getter/setter/toString()方法
}
public class Address {
    private String province;
    private String city;
    private Address address;
}


嵌套POJO参数:请求参数名与形参对象属性名相同,按照对象层次结构关系即可接收嵌套POJO属性参数


c20b0050e0dc03668f4d118edca597d2_097b0da51743d4665596ea6d8fa52ade.png


//嵌套POJO参数:嵌套属性按照层次结构设定名称即可完成参数传递
@RequestMapping("/pojoContainPojoParam")
@ResponseBody
public String pojoContainPojoParam(User user){
    System.out.println("pojo嵌套pojo参数传递 user ==> "+user);
    return "{'module':'pojo contain pojo param'}";
}


注意事项:请求参数key的名称要和POJO中属性的名称一致,否则无法封装。


2.2.5 数组类型参数


数组参数:请求参数名与形参对象属性名相同且请求参数为多个,定义数组类型即可接收参数


3268495f52a8e36aac63b7692c6a3194_078e49e0b879c1198a7c2e33b166874b.png


//数组参数:同名请求参数可以直接映射到对应名称的形参数组对象中
@RequestMapping("/arrayParam")
@ResponseBody
public String arrayParam(String[] likes){
    System.out.println("数组参数传递 likes ==> "+ Arrays.toString(likes));
    return "{'module':'array param'}";
}


2.2.6 集合类型参数


集合保存普通参数:请求参数名与形参集合对象名相同且请求参数为多个,@RequestParam绑定参数关系


474d6f5f06c166c59a5c89a0506a7064_8d262f93857061d303858e6c9911977a.png


//集合参数:同名请求参数可以使用@RequestParam注解映射到对应名称的集合对象中作为数据
@RequestMapping("/listParam")
@ResponseBody
public String listParam(@RequestParam List<String> likes){
    System.out.println("集合参数传递 likes ==> "+ likes);
    return "{'module':'list param'}";
}



2.3 json数据参数传递


问题导入


问题:@EnableWebMvc注解和@ResponseBody注解有什么用?


2.3.1 json数据参数介绍


json普通数组([“”,“”,“”,…])

json对象({key:value,key:value,…})

json对象数组([{key:value,…},{key:value,…}])


2.3.2 传递json普通数组


2.3.2.1 代码演示


添加json数据转换相关坐标


<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.9.0</version>
</dependency>


设置发送json数据(请求body中添加json数据)


818e1103bd41f5ab2c2c329d83b8f84b_6075ed59cfe3ab1545a6a1ebf8df6ed0.png


开启自动转换json数据的支持


@Configuration
@ComponentScan("com.itheima.controller")
//开启json数据类型自动转换
@EnableWebMvc
public class SpringMvcConfig {
}


注意事项:


@EnableWebMvc注解功能强大,该注解整合了多个功能,此处仅使用其中一部分功能,即json数据进行自动类型转换


在Controller中编写方法接收json参数


//集合参数:json格式
//1.开启json数据格式的自动转换,在配置类中开启@EnableWebMvc
//2.使用@RequestBody注解将外部传递的json数组数据映射到形参的集合对象中作为数据
@RequestMapping("/listParamForJson")
@ResponseBody
public String listParamForJson(@RequestBody List<String> likes){
    System.out.println("list common(json)参数传递 list ==> "+likes);
    return "{'module':'list common for json param'}";
}


2.3.2.2 @EnableWebMvc注解介绍


名称:@EnableWebMvc

类型:配置类注解

位置:SpringMVC配置类定义上方

作用:开启SpringMVC多项辅助功能

范例:


@Configuration
@ComponentScan("com.itheima.controller")
@EnableWebMvc
public class SpringMvcConfig {
}


2.3.2.3 @RequestBody注解介绍


名称:@RequestBody

类型:形参注解

位置:SpringMVC控制器方法形参定义前面

作用:将请求中请求体所包含的数据传递给请求参数,此注解一个处理器方法只能使用一次

范例:


@RequestMapping("/listParamForJson")
@ResponseBody
public String listParamForJson(@RequestBody List<String> likes){
    System.out.println("list common(json)参数传递 list ==> "+likes);
    return "{'module':'list common for json param'}";
}


2.3.3 传递json对象


POJO参数:json数据与形参对象属性名相同,定义POJO类型形参即可接收参数


b1104a30566ce69490e8f91e539ebc46_3d1bdd6449630df5280d2bc4e5909f43.png


//POJO参数:json格式
//1.开启json数据格式的自动转换,在配置类中开启@EnableWebMvc
//2.使用@RequestBody注解将外部传递的json数据映射到形参的实体类对象中,要求属性名称一一对应
@RequestMapping("/pojoParamForJson")
@ResponseBody
public String pojoParamForJson(@RequestBody User user){
    System.out.println("pojo(json)参数传递 user ==> "+user);
    return "{'module':'pojo for json param'}";
}


2.3.4 传递json对象数组


POJO集合参数:json数组数据与集合泛型属性名相同,定义List类型形参即可接收参数


fa85f87070654e7f84a5ab5070cfd1a1_1216ef2a42e9900b3206bf4d2e836cdb.png


//集合参数:json格式
//1.开启json数据格式的自动转换,在配置类中开启@EnableWebMvc
//2.使用@RequestBody注解将外部传递的json数组数据映射到形参的保存实体类对象的集合对象中,要求属性名称一一对应
@RequestMapping("/listPojoParamForJson")
@ResponseBody
public String listPojoParamForJson(@RequestBody List<User> list){
    System.out.println("list pojo(json)参数传递 list ==> "+list);
    return "{'module':'list pojo for json param'}";
}


2.3.5 @RequestBody与@RequestParam区别


区别

@RequestParam用于接收url地址传参,表单传参【application/x-www-form-urlencoded】

@RequestBody用于接收json数据【application/json】

应用

后期开发中,发送json格式数据为主,@RequestBody应用较广

如果发送非json格式数据,选用@RequestParam接收请求参数

相关文章
|
2月前
|
JSON 前端开发 Java
【JavaEE进阶】 关于Spring MVC 响应
【JavaEE进阶】 关于Spring MVC 响应
35 3
|
2月前
|
JSON Java fastjson
SpringMVC(二)【请求与响应】(2)
SpringMVC(二)【请求与响应】
|
2月前
|
JSON 前端开发 数据格式
SpringMVC的数据响应-直接回写json字符串
SpringMVC的数据响应-直接回写json字符串
|
2月前
|
前端开发 Java Spring
SpringMVC的数据响应-19
SpringMVC的数据响应-19
|
2月前
|
JSON 前端开发 Java
spring mvc 请求与响应
spring mvc 请求与响应
14 0
|
2月前
|
前端开发 Java 应用服务中间件
SpringMVC(二)【请求与响应】(1)
SpringMVC(二)【请求与响应】
|
10月前
|
JSON 前端开发 Java
构建健壮的Spring MVC应用:JSON响应与异常处理
构建健壮的Spring MVC应用:JSON响应与异常处理
45 0
|
3月前
|
JSON 前端开发 Java
SpringMVC请求和响应
Spring MVC通过请求和响应的处理来实现Web应用程序的开发。请求通过控制器处理,响应通过视图渲染器生成最终的HTML响应,并返回给客户端。
67 4
|
3月前
|
JSON 前端开发 Java
Spring MVC响应结合RESTful风格开发,打造具有强大功能和良好体验的Web应用!
Spring MVC响应结合RESTful风格开发,打造具有强大功能和良好体验的Web应用!
|
3月前
|
JSON 前端开发 Java
【JavaEE进阶】 关于Spring mvc 响应
【JavaEE进阶】 关于Spring mvc 响应