hincky的主页 hincky的主页
  • 学习笔记

    • Vue笔记
    • Vuepress
    • nginx
  • 语言类

    • java
    • go
    • python
    • 设计模式
  • 框架类

    • Spring
    • Spring Security
    • Mybatis
  • 容器技术

    • docker
    • k8s
    • helm
    • prometheus
    • grafana
    • jenkins
  • 命令集合

    • linux命令
    • docker命令
    • git命令
    • vim命令
    • k8s命令
  • 数据库

    • sql
    • mysql
  • 协议

    • 网络模型
    • http/1.1
    • WebSocket
    • http/2
    • TLS/SSL
    • tcp
    • IP
    • tcpdump抓包命令
    • wireshark抓包工具
  • 通用

    • Git
  • 技术分享

    • git push/pull总是超时怎么办
    • idea debug技巧
    • postman使用
    • 问题总结
    • idea使用技巧
  • Oauth2

    • Oauth2原理
  • 项目列表

    • redis项目
    • 微服务项目
  • 分类
  • 标签
  • 归档
  • 随笔
GitHub (opens new window)

Hincky

当有趣的人,做想做的事
  • 学习笔记

    • Vue笔记
    • Vuepress
    • nginx
  • 语言类

    • java
    • go
    • python
    • 设计模式
  • 框架类

    • Spring
    • Spring Security
    • Mybatis
  • 容器技术

    • docker
    • k8s
    • helm
    • prometheus
    • grafana
    • jenkins
  • 命令集合

    • linux命令
    • docker命令
    • git命令
    • vim命令
    • k8s命令
  • 数据库

    • sql
    • mysql
  • 协议

    • 网络模型
    • http/1.1
    • WebSocket
    • http/2
    • TLS/SSL
    • tcp
    • IP
    • tcpdump抓包命令
    • wireshark抓包工具
  • 通用

    • Git
  • 技术分享

    • git push/pull总是超时怎么办
    • idea debug技巧
    • postman使用
    • 问题总结
    • idea使用技巧
  • Oauth2

    • Oauth2原理
  • 项目列表

    • redis项目
    • 微服务项目
  • 分类
  • 标签
  • 归档
  • 随笔
GitHub (opens new window)
  • java

  • python

  • Spring

  • SpringMVC

    • 入门
      • 入门案例
        • ①导入相关依赖
        • ②配置web.xml
        • ③配置SpringMVC
        • ④创建测试用的jsp页面
        • ⑤编写Controller
    • 请求映射注解
      • 3.设置请求映射规则@RequestMapping
        • 3.1 指定请求路径
        • 3.2 指定请求方式
        • 3.3 指定请求参数
        • 3.4 指定请求头
        • 3.5 指定请求头Content-Type
        • 范例一
        • 范例二
    • RestFul
      • 4.RestFul风格
      • 5.获取请求参数
        • 5.1 获取路径参数
        • 范例一
        • 范例二
        • 5.2 获取请求体中的Json格式参数
        • 5.2.1 配置
        • 5.2.2 使用
        • 范例一
        • 1.获取参数封装成实体对象
        • 2.获取参数封装成Map集合
        • 范例二
        • 5.2.3 注意事项
        • 5.3 获取QueryString格式参数
        • 5.3.1 使用
        • 范例一
        • 1.参数单独的获取
        • 2.获取参数封装成实体对象
        • 5.4 相关注解其他属性
        • 5.4.1 required
        • 5.4.2 defaultValue
    • 类型转换器
      • 1.类型转换器
        • 1.1 自定义类型转换器
        • ①创建类实现Converter接口
        • ②实现convert方法
        • ③配置让SpringMVC使用自定义转换器
        • 1.2 日期转换简便解决方案
    • 响应体响应数据
      • 数据放到响应体
      • 数据转换成Json
        • 配置
        • ①导入jackson依赖
        • ②开启mvc的注解驱动
        • 使用
      • 范例
        • 范例一
        • 范例二
      • 3.页面跳转
      • 4.视图解析器
        • 4.1使用步骤
        • ①配置视图解析器
        • ②页面跳转
        • 4.2 不进行前后缀拼接
      • 5.获取原生对象
      • 6.获取请求头和Cookie
        • 6.1获取请求头
        • 6.2 获取Cookie
      • 7.JSP开发模式(了解)
        • 7.1 往Requet域存数据并跳转
        • 7.1.1 使用Model
        • 7.1.2 使用ModelAndView
        • 7.2 从Request域中获取数据
        • 7.3 往Session域存数据并跳转
        • 7.4 获取Session域中数据
  • SpringSecurity

  • Mybatis

  • 设计模式

  • Go

  • 后端
  • SpringMVC
hincky
2022-11-09
目录

响应体响应数据

​ 无论是RestFul风格还是我们之前web阶段接触过的异步请求,都需要把数据转换成Json放入响应体中。

# 数据放到响应体

​ 我们的SpringMVC为我们提供了**@ResponseBody**来非常方便的把Json放到响应体中。

​ @ResponseBody可以加在哪些东西上面?类上和方法上

​ 具体代码请参考范例。

# 数据转换成Json

​ SpringMVC可以把我们进行Json的转换,不过需要进行相应配置(已经配置过)。

# 配置

# ①导入jackson依赖

        <!-- jackson,帮助进行json转换-->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.9.0</version>
        </dependency>
1
2
3
4
5
6

# ②开启mvc的注解驱动

    <mvc:annotation-driven></mvc:annotation-driven>
1

# 使用

​ 只要把要转换的数据直接作为方法的返回值返回即可。SpringMVC会帮我们把返回值转换成json。具体代码请参考范例。

# 范例

# 范例一

​ 要求定义个RestFul风格的接口,该接口可以用来根据id查询用户。请求路径要求为 /response/user ,请求方式要求为GET。

​ 而请求参数id要写在请求路径上,例如 /response/user/1 这里的1就是id。

​ 要求获取参数id,去查询对应id的用户信息(模拟查询即可,可以选择直接new一个User对象),并且转换成json响应到响应体中。

@Controller
@RequestMapping("/response")
public class ResponseController {
    @GetMapping("/user/{id}")
    @ResponseBody //这方法的返回值放入响应体中
    public User testResponse(@PathVariable Integer id){
        User user = new User(id,null,null,null);
        return user;//因为以及做过配置,所以会把返回值转换成json
    }
}

1
2
3
4
5
6
7
8
9
10
11

# 范例二

​ 要求定义个RestFul风格的接口,该接口可以查询所有用户。请求路径要求为 /response/user ,请求方式要求为GET。

​ 去查询所有的用户信息(模拟查询即可,可以选择直接创建集合,添加几个User对象),并且转换成json响应到响应体中。

@Controller
@RequestMapping("/response")
@ResponseBody  //这类中所有方法的返回值都会放到响应体中
public class ResponseController {

    @GetMapping("/user/{id}")
    public User testResponse(@PathVariable Integer id){
        User user = new User(id,null,null,null);
        return user;
    }

    @GetMapping("/user")
    public List<User> testResponse2(){
        List<User> list = new ArrayList<User>();
        list.add(new User(1,"三更",15,null));
        list.add(new User(2,"四更",16,null));
        list.add(new User(3,"五更",17,null));
        return list;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

​ 如果一个Controller中的所有方法返回值都要放入响应体,那么我们可以直接在Controller类上加@ResponseBody。

​ 我们可以使用**@RestController** 注解替换@Controller和@ResponseBody两个注解

@RequestMapping("/response")
@RestController //相当于  @Controller+@ResponseBody
public class ResponseController {

    @GetMapping("/user/{id}")
    public User testResponse(@PathVariable Integer id){
        User user = new User(id,null,null,null);
        return user;
    }

    @GetMapping("/user")
    public List<User> testResponse2(){
        List<User> list = new ArrayList<User>();
        list.add(new User(1,"三更",15,null));
        list.add(new User(2,"四更",16,null));
        list.add(new User(3,"五更",17,null));
        return list;
    }
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

# 3.页面跳转

​ 在SpringMVC中我们可以非常轻松的实现页面跳转,只需要把方法的返回值写成要跳转页面的路径即可。

例如:

@Controller
public class PageJumpController {
    @RequestMapping("/testJump")
    public String testJump(){
        return "/success.jsp";
    }
}
1
2
3
4
5
6
7

​

​ 默认的跳转其实是转发的方式跳转的。我们也可以选择加上标识,在要跳转的路径前加上forward: 。这样SpringMVC也会帮我们进行请求转发。

例如:

@Controller
public class PageJumpController {
    @RequestMapping("/testJump")
    public String testJump(){
        return "forward:/success.jsp";
    }
}
1
2
3
4
5
6
7

​ 如果想实现重定向跳转则可以在跳转路径前加上 redirect: 进行标识。这样SpringMVC就会帮我们进行重定向跳转。

例如:

@Controller
public class PageJumpController {
    @RequestMapping("/testJump")
    public String testJump(){
        return "redirect:/success.jsp";
    }
}

1
2
3
4
5
6
7
8

# 4.视图解析器

​ 如果我们经常需要跳转页面,并且页面所在的路径比较长,我们每次写完整路径会显的有点麻烦。我们可以配置视图解析器,设置跳转路径的前缀和后缀。这样可以简化我们的书写。

# 4.1使用步骤

# ①配置视图解析器

​ 我们需要完SpringMVC容器中注入InternalResourceViewResolver对象。

    <!--配置视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="viewResolver">
        <!--要求拼接的前缀-->
        <property name="prefix" value="/WEB-INF/page/"></property>
        <!--要拼接的后缀-->
        <property name="suffix" value=".jsp"></property>
    </bean>
1
2
3
4
5
6
7

# ②页面跳转

​ 视图解析器会在逻辑视图的基础上拼接得到物理视图。

    @RequestMapping("/testJumpToJsp")
    public String testJumpToJsp(){
//        return "/WEB-INF/page/test.jsp";
        return "test";
    }
1
2
3
4
5

# 4.2 不进行前后缀拼接

​ 如果在配置了视图解析器的情况下,某些方法中并不想拼接前后缀去跳转。这种情况下我们可以在跳转路径前加forward: 或者**redirect:**进行标识。这样就不会进行前后缀的拼接了。

​ 例如:

    @RequestMapping("/testJumpHtml")
    public String testJumpHtml(){
        //如果加了forward:  或者redirect: 就不会进行前后缀的拼接
        return "forward:/hello1.html";
    }
1
2
3
4
5

# 5.获取原生对象

​ 我们之前在web阶段我们经常要使用到request对象,response,session对象等。我们也可以通过SpringMVC获取到这些对象。(不过在MVC中我们很少获取这些对象,因为有更简便的方式,避免了我们使用这些原生对象相对繁琐的API。)

​ 我们只需要在方法上添加对应类型的参数即可,但是注意数据类型不要写错了,SpringMVC会把我们需要的对象传给我们的形参。

​ 例如:

@Controller
public class RequestResponseController {
    @RequestMapping("/getReqAndRes")
    public String getReqAndRes(HttpServletRequest request, HttpServletResponse response, HttpSession session){
        System.out.println();
        return "test";
    }
}
1
2
3
4
5
6
7
8

​

# 6.获取请求头和Cookie

# 6.1获取请求头

​ 在方法中定义一个参数,参数前加上**@RequestHeader**注解,知道要获取的请求头名即可获取对应请求头的值。

例如:

​ 想要获取 device-type 这个请求头则可以按照如下方式定义方法。

@Controller
public class RequestResponseController {


    @RequestMapping("/getHeader")
    public String getHeader(@RequestHeader(value = "device-type") String deviceType){
        System.out.println(deviceType);
        return "test";
    }
}

1
2
3
4
5
6
7
8
9
10
11

# 6.2 获取Cookie

​ 在方法中定义一个参数,参数前加上**@CookieValue** 注解,知道要获取的cookie名即可获取对应cookie的值。

例如:

​ 想要获取 JSESSIONID 的cookie值。则可以按照如下方式定义方法。

@Controller
public class RequestResponseController {

    @RequestMapping("/getCookie")
    public String getCookie(@CookieValue("JSESSIONID") String sessionId){
        System.out.println(sessionId);
        return "test";
    }
}

1
2
3
4
5
6
7
8
9
10

# 7.JSP开发模式(了解)

​ 如果我们使用JSP进行开发,那我们就需要在域中存数据,然后跳转到对应的JSP页面中,在JSP页面中获取域中的数据然后进行相关处理。

​ 使用如果是类似JSP的开发模式就会涉及到往域中存数据和携带数据跳转页面的操作。

​ 所以我们来看下如果用SpringMVC进行相关操作。

# 7.1 往Requet域存数据并跳转

# 7.1.1 使用Model

​ 我们可以使用Model来往域中存数据。然后使用之前的方式实现页面跳转。

例如

​ 我们要求访问 /testRequestScope 这个路径时能往Request域中存name和title数据,然后跳转到 /WEB-INF/page/testScope.jsp 这个页面。在Jsp中获取域中的数据。

​ 则可以使用如下写法:

@Controller
public class JspController {
    @RequestMapping("/testRquestScope")
    public String testRquestScope(Model model){
        //往请求域存数据
        model.addAttribute("name","三更");
        model.addAttribute("title","不知名Java教程UP主");
        return "testScope";
    }
}
1
2
3
4
5
6
7
8
9
10

# 7.1.2 使用ModelAndView

​ 我们可以使用ModelAndView来往域中存数据和页面跳转。

例如

​ 我们要求访问 /testRequestScope2 这个路径时能往域中存name和title数据,然后跳转到 /WEB-INF/page/testScope.jsp 这个页面。在Jsp中获取域中的数据。

​ 则可以使用如下写法:

@Controller
public class JspController {
    @RequestMapping("/testRquestScope2")
    public ModelAndView testRquestScope2(ModelAndView modelAndView){
        //往域中添加数据
        modelAndView.addObject("name","三更");
        modelAndView.addObject("title","不知名Java教程UP主");
        //页面跳转
        modelAndView.setViewName("testScope");
        return modelAndView;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12

​ 注意要把modelAndView对象作为方法的返回值返回。

# 7.2 从Request域中获取数据

​ 我们可以使用**@RequestAttribute** 把他加在方法参数上,可以让SpringMVC帮我们从Request域中获取相关数据。

例如

@Controller
public class JspController {

    @RequestMapping("/testGetAttribute")
    public String testGetAttribute(@RequestAttribute("org.springframework.web.servlet.HandlerMapping.bestMatchingPattern")
                                               String value,HttpServletRequest request){
        System.out.println(value);
        return "testScope";
    }
}

1
2
3
4
5
6
7
8
9
10
11

# 7.3 往Session域存数据并跳转

​ 我们可以使用**@SessionAttributes**注解来进行标识,用里面的属性来标识哪些数据要存入Session域。

例如

​ 我们要求访问 /testSessionScope 这个路径时能往域中存name和title数据,然后跳转到 /WEB-INF/page/testScope.jsp 这个页面。在jsp中获取Session域中的数据。

​ 则可以使用如下写法

@Controller
@SessionAttributes({"name"})//表示name这个数据也要存储一份到session域中
public class JspController {


    @RequestMapping("/testSessionScope")
    public String testSessionScope(Model model){
        model.addAttribute("name","三更");
        model.addAttribute("title","不知名Java教程UP主");
        return "testScope";
    }
}
1
2
3
4
5
6
7
8
9
10
11
12

# 7.4 获取Session域中数据

​ 我们可以使用**@SessionAttribute把他加在方法参数上,可以让SpringMVC帮我们从Session域**中获取相关数据。

例如:

@Controller
@SessionAttributes({"name"})
public class JspController {
    @RequestMapping("/testGetSessionAttr")
    public String testGetSessionAttr(@SessionAttribute("name") String name){
        System.out.println(name);
        return "testScope";
    }

}

1
2
3
4
5
6
7
8
9
10
11
编辑 (opens new window)
#SpringMVC
类型转换器
SpringSecurity入门

← 类型转换器 SpringSecurity入门→

最近更新
01
人生前期重要的能力
05-17
02
防火墙命令
04-11
03
docker-compose部署mysql主从集群
03-22
更多文章>
Theme by Vdoing | Copyright © 2022-2023 Hincky | MIT License | 粤ICP备2022120427号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式