当前位置:   article > 正文

Java开发学习(二十六)----SpringMVC返回响应结果_java 根据输入不同的地址 响应不同的页面

java 根据输入不同的地址 响应不同的页面

SpringMVC接收到请求和数据后,进行了一些处理,当然这个处理可以是转发给Service,Service层再调用Dao层完成的,不管怎样,处理完以后,都需要将结果告知给用户。

比如:根据用户ID查询用户信息、查询用户列表、新增用户等。

对于响应,主要就包含两部分内容:

  • 响应页面

  • 响应数据

    • 文本数据

    • json数据

因为异步调用是目前常用的主流方式,所以我们需要更关注的就是如何返回JSON数据。

一、环境准备

  • 创建一个Web的Maven项目

  • pom.xml添加Spring依赖

    1. <?xml version="1.0" encoding="UTF-8"?>
    2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    3.  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    4.  <modelVersion>4.0.0</modelVersion>
    5.  <groupId>com.itheima</groupId>
    6.  <artifactId>springmvc_05_response</artifactId>
    7.  <version>1.0-SNAPSHOT</version>
    8.  <packaging>war</packaging>
    9.  <dependencies>
    10.    <dependency>
    11.      <groupId>javax.servlet</groupId>
    12.      <artifactId>javax.servlet-api</artifactId>
    13.      <version>3.1.0</version>
    14.      <scope>provided</scope>
    15.    </dependency>
    16.    <dependency>
    17.      <groupId>org.springframework</groupId>
    18.      <artifactId>spring-webmvc</artifactId>
    19.      <version>5.2.10.RELEASE</version>
    20.    </dependency>
    21.    <dependency>
    22.      <groupId>com.fasterxml.jackson.core</groupId>
    23.      <artifactId>jackson-databind</artifactId>
    24.      <version>2.9.0</version>
    25.    </dependency>
    26.  </dependencies>
    27.  <build>
    28.    <plugins>
    29.      <plugin>
    30.        <groupId>org.apache.tomcat.maven</groupId>
    31.        <artifactId>tomcat7-maven-plugin</artifactId>
    32.        <version>2.1</version>
    33.        <configuration>
    34.          <port>80</port>
    35.          <path>/</path>
    36.        </configuration>
    37.      </plugin>
    38.    </plugins>
    39.  </build>
    40. </project>
  • 创建对应的配置类

    1. public class ServletContainersInitConfig extends AbstractAnnotationConfigDispatcherServletInitializer {
    2.    protected Class<?>[] getRootConfigClasses() {
    3.        return new Class[0];
    4.   }
    5.    protected Class<?>[] getServletConfigClasses() {
    6.        return new Class[]{SpringMvcConfig.class};
    7.   }
    8.    protected String[] getServletMappings() {
    9.        return new String[]{"/"};
    10.   }
    11.    //乱码处理
    12.    @Override
    13.    protected Filter[] getServletFilters() {
    14.        CharacterEncodingFilter filter = new CharacterEncodingFilter();
    15.        filter.setEncoding("UTF-8");
    16.        return new Filter[]{filter};
    17.   }
    18. }
    19. @Configuration
    20. @ComponentScan("com.itheima.controller")
    21. //开启json数据类型自动转换
    22. @EnableWebMvc
    23. public class SpringMvcConfig {
    24. }
  • 编写模型类User

    1. public class User {
    2.    private String name;
    3.    private int age;
    4.    //getter...setter...toString省略
    5. }
  • webapp下创建page.jsp

    1. <html>
    2. <body>
    3. <h2>Hello Spring MVC!</h2>
    4. </body>
    5. </html>
  • 编写UserController

    1. @Controller
    2. public class UserController {
    3.    
    4. }

最终创建好的项目结构如下:

二、响应页面

步骤1:设置返回页面

  1. @Controller
  2. public class UserController {
  3.    
  4.    @RequestMapping("/toJumpPage")
  5.    //注意
  6.    //1.此处不能添加@ResponseBody,如果加了该注入,会直接将page.jsp当字符串返回前端
  7.    //2.方法需要返回String
  8.    public String toJumpPage(){
  9.        System.out.println("跳转页面");
  10.        return "page.jsp";
  11.   }
  12.    
  13. }

步骤2:启动程序测试

此处涉及到页面跳转,所以不适合采用PostMan进行测试,直接打开浏览器,输入

http://localhost/toJumpPage

三、返回文本数据

步骤1:设置返回文本内容

  1. @Controller
  2. public class UserController {
  3.    
  4.   @RequestMapping("/toText")
  5. //注意此处该注解就不能省略,如果省略了,会把response text当前页面名称去查找,如果没有回报404错误
  6.    @ResponseBody
  7.    public String toText(){
  8.        System.out.println("返回纯文本数据");
  9.        return "response text";
  10.   }
  11.    
  12. }

步骤2:启动程序测试

此处不涉及到页面跳转,因为我们现在发送的是GET请求,可以使用浏览器也可以使用PostMan进行测试,输入地址http://localhost/toText访问

四、响应JSON数据

响应POJO对象

  1. @Controller
  2. public class UserController {
  3.    
  4.    @RequestMapping("/toJsonPOJO")
  5.    @ResponseBody
  6.    public User toJsonPOJO(){
  7.        System.out.println("返回json对象数据");
  8.        User user = new User();
  9.        user.setName("itcast");
  10.        user.setAge(15);
  11.        return user;
  12.   }
  13.    
  14. }

返回值为实体类对象,设置返回值为实体类类型,即可实现返回对应对象的json数据,需要依赖@ResponseBody注解和@EnableWebMvc注解

重新启动服务器,访问http://localhost/toJsonPOJO

响应POJO集合对象

  1. @Controller
  2. public class UserController {
  3.    
  4.    @RequestMapping("/toJsonList")
  5.    @ResponseBody
  6.    public List<User> toJsonList(){
  7.        System.out.println("返回json集合数据");
  8.        User user1 = new User();
  9.        user1.setName("传智播客");
  10.        user1.setAge(15);
  11.        User user2 = new User();
  12.        user2.setName("黑马程序员");
  13.        user2.setAge(12);
  14.        List<User> userList = new ArrayList<User>();
  15.        userList.add(user1);
  16.        userList.add(user2);
  17.        return userList;
  18.   }
  19.    
  20. }

重新启动服务器,访问http://localhost/toJsonList

知识点1:@ResponseBody

名称@ResponseBody
类型方法\类注解
位置SpringMVC控制器方法定义上方和控制类上
作用设置当前控制器返回值作为响应体, 写在类上,该类的所有方法都有该注解功能
相关属性pattern:指定日期时间格式字符串

说明:

  • 该注解可以写在类上或者方法上

  • 写在类上就是该类下的所有方法都有@ReponseBody功能

  • 当方法上有@ReponseBody注解后

    • 方法的返回值为字符串,会将其作为文本内容直接响应给前端

    • 方法的返回值为对象,会将对象转换成JSON响应给前端

此处又使用到了类型转换,内部还是通过Converter接口的实现类完成的,所以Converter除了前面所说的功能外,它还可以实现:

  • 对象转Json数据(POJO -> json)

  • 集合转Json数据(Collection -> json)

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号