• SpringMVC进阶:常用注解、参数传递和请求响应以及页面跳转


    目录

    一、常用注解

    1.1.@RequestMapping

    1.2.@RequestParam

    1.3.@ModelAttribute

    1.4.@SessionAttributes

    1.5.@RequestBody

    1.6.@RequestHeader

    1.7.@PathVariable

    1.8.@CookieValue

    二、参数传递

    2.1.基础类型+String

    2.2.复杂类型

    2.3.@RequestParam

    2.4.@PathVariable

    2.5.@RequestBody

    2.6.@RequestHeader

    三、返回值

    3.1.void

    3.2.String

    3.3.String+Model

    3.4.ModelAndView

    四、页面跳转


    一、常用注解

    1.1.@RequestMapping

    @RequestMapping注解是一个用来处理请求地址映射的注解,可用于映射一个请求或一个方法,可以用在类或方法上。

    • 标注在方法上

    用于方法上,表示在类的父路径下追加方法上注解中的地址将会访问到该方法

    1. @Controller
    2. public class HelloController {
    3. @RequestMapping("/requestTest")
    4. public String requestTest(){
    5.   return "success";
    6. }
    7. }
    • 标注在类和方法上

    用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。

    注意:当你在类上添加RequestMapping注解后,如果要请求映射,就意味着请求要先映射到标注类的位置,然后再映射到该类的方法上

    1. @Controller
    2. @RequestMapping("/hello")
    3. public class HelloController {
    4. @RequestMapping("/requestTest")
    5. public String requestTest(){
    6.   return "success";
    7. }
    8. }

    • 参数列表

    参数说明
    value@RequestMapping 的 value 属性必须设值; @RequestMapping 的 value 属性是通过当前请求的请求地址来匹配请求; 从源码中可以看到value属性是一个字符串类型的数组,因此说明可以将多个请求映射到一个方法上,只需要给 value 来指定一个包含多个路径的数组。
    method@RequestMapping的method属性是通过当前请求的请求方式来匹配请求; 浏览器向服务器发送请求,请求方式有很多GET、HEAD、POST、PUT、PATCH、DELETE、OPTIONS、TRACE。可以使用 method 属性来约束请求方式。
    headers@RequestMapping的headers属性是通过当前请求的请求头信息来匹配请求; @RequestMapping的headers属性是一个字符串类型的数组,可以通过下面四种表达是来设置匹配关系 例如: “header”:要求请求映射的请求必须为包含 header的请求头信息 “!header”:要求请求映射的请求必须为不包含 header的请求头信息 “header=value”:要求请求映射的请求必须为包含 header的请求头信息,并且header的值必须为value “header!=value”:要求请求映射的请求必须为包含 header的请求头信息,并且header的值必须不是value
    params@RequestMapping的params属性是通过当前请求的请求参数来匹配请求; @RequestMapping的params属性是一个字符串类型的数组,可以通过下面四种表达是来设置匹配关系 例如: “param”:要求请求映射的请求必须为包含 param的请求参数 “!param”:要求请求映射的请求是不能包含param的请求参数 “param=value”:要求请求映射的请求必须包含 param 的请求参数,且 param 参数的值必须为 value “param!=value”: 要求请求映射的请求是必须包含 param 的请求参数,其值不能为 value。

    示例一:@RequestMapping的params属性

    1. @RequestMapping(value = "/test",params = "username")
    2. public String test(){
    3. return "success";
    4. }

    注意:我们设置了params属性,就意味着该请求映射的请求必须包含username才能够请求成功。

    示例二:@RequestMapping的headers属性

    1. @RequestMapping(value = "/test",headers = "Host = localhost:8081")
    2. public String test(){
    3. return "success";
    4. }

    注意:如果当前请求不满足headers属性,此时页面就会显示404错误,即资源未找到。

    扩展:

    @GetMapping:处理get方式请求的映射 @PostMapping:处理post方式请求的映射 @PutMapping:处理put方式请求的映射 @DeleteMapping:处理delete方式请求的映射 @GetMapping就相当于@RequestMapping(method=RequestMethod.GET),它会将get映射到特定的方法上。

    1.2.@RequestParam

    @RequestParam主要用于将请求参数区域的数据映射到控制层方法的参数上

    参数说明
    value请求中传入参数的名称,如果不设置后台接口的value值,则会默认为该变量名。
    required该参数是否为必传项。默认是true,表示请求中一定要传入对应的参数,否则会报404错误,如果设置为false时,当请求中没有此参数,将会默认为null,而对于基本数据类型的变量,则必须有值,这时会抛出空指针异常。如果允许空值,则接口中变量需要使用包装类来声明。
    defaultValue参数的默认值,如果请求中没有同名的参数时,该变量默认为此值。注意默认值可以使用SpEL表达式,如"#{systemProperties[‘java.vm.version’]}"

    示例:

    1. @RequestMapping("/queryBooks")
    2. public List queryBooks(
    3. @RequestParam(required = false,defaultValue = "0",value="page") int page,
    4.    @RequestParam(required = false,defaultValue = "10",value = "rows") int rows){
    5.        return bookService.queryBooks(page,rows);
    6. }

    1.3.@ModelAttribute

    @ModelAttribute一个具有如下三个作用:

    • 绑定请求参数到命令对象:放在功能处理方法的入参上时,用于将多个请求参数绑定到一个命令对象,从而简化绑定流程,而且自动暴露为模型数据用于视图页面展示时使用;

    • 暴露表单引用对象为模型数据:放在处理器的一般方法(非功能处理方法)上时,是为表单准备要展示的表单引用对象,如注册时需要选择的所在城市等,而且在执行功能处理方法(@RequestMapping注解的方法)之前,自动添加到模型对象中,用于视图页面展示时使用;

    • 暴露@RequestMapping方法返回值为模型数据:放在功能处理方法的返回值上时,是暴露功能处理方法的返回值为模型数据,用于视图页面展示时使用。

    示例一:绑定请求参数到命令对象

    如用户登录,我们需要捕获用户登录的请求参数(用户名、密码)并封装为用户对象,此时我们可以使用@ModelAttribute绑定多个请求参数到我们的命令对象。

    public String test1(@ModelAttribute("user") UserModel user) 

    它的作用是将该绑定的命令对象以“user”为名称添加到模型对象中供视图页面展示使用。我们此时可以在视图页面使用${user.username}来获取绑定的命令对象的属性。

    示例二:暴露表单引用对象为模型数据

    1. @ModelAttribute
    2. public void init(Model model){
    3. model.addAttribute("book",new Book());
    4. }

    如上代码会在执行功能处理方法之前执行,并将其自动添加到模型对象中。

    1. @RequestMapping("/toBookList")
    2. public String toBookList(){
    3.    System.out.println("toBookList");
    4.    return "book/bookList";
    5. }

    示例三:暴露@RequestMapping方法返回值为模型数据

    @ModelAttribute注解的返回值会覆盖@RequestMapping注解方法中的@ModelAttribute注解的同名命令对象。

    public @ModelAttribute("user2") UserModel test3(@ModelAttribute("user2") UserModel user) 

    1.4.@SessionAttributes

    在默认情况下,当ModelMap中的属性作用域是request级别时,也就是说,当本次请求结束后,ModelMap中的属性将销毁。如果希望在多个请求中共享ModelMap中的属性,必须将其属性转存到session中,这样ModelMap的属性才会被跨请求访问;

    spring允许我们有选择地指定ModelMap中的哪些属性需要转存到session中,以便下一个请求属对应的ModelMap的属性列表中还能访问到这些属性。

    SpringMVC为我们提供这样一个注解来实现上面的场景:@SessionAttributes:将ModelMap的属性值共享到session中。

    注意:@SessionAttributes注解只能使用在类上,用于在多个请求之间传递参数,类似于Session的Attribute,但不完全一样,一般来说@SessionAttributes设置的参数只用于暂时的传递(存入sessionAttributeStore),而不是长期的保存,长期保存的数据还是要放到Session中。

    有两种方式将ModelMap中的属性值共享到session中:

    1. 使用注解的value属性:可以通过属性名指定需要放到会话中的属性;

    1. @Controller
    2. @SessionAttributes("user") //将ModelMap中key为user的属性共享到session中
    3. public class DemoController {
    4. @RequestMapping("/hello")  
    5. public String hello(ModelMap model) {
    6. //向ModelMap中添加key为user和user1的属性
    7.        model.addAttribute("user", new User(520, "U love me"));
    8.        model.addAttribute("user1", new User("I love U"));
    9.        return "result";
    10.   }
    11. }

    1. 使用注解的types属性:还可以通过模型属性的对象类型指定哪些模型属性需要放到会话中。

    1. @SessionAttributes(types = {User.class})
    2. @Controller
    3. public class DemoController{
    4.    @RequestMapping("/hello")
    5.    public String hello(Map<String, Object> map){
    6.        map.put("user1", new User(520, "U love me"));
    7.        return "hello";
    8.   }
    9. }

    1.5.@RequestBody

    @RequestBody主要用来接收前端传递给后端的json字符串中的数据的(即请求体中的数据的);

    GET方式无请求体,所以使用@RequestBody接收数据时,前端不能使用GET方式提交数据,而是用POST方式进行提交。在后端的同一个接收方法里,@RequestBody与@RequestParam()可以同时使用,@RequestBody最多只能有一个,而@RequestParam()可以有多个。

    简言之:

    • 一个请求:只有一个@RequestBody;

    • 一个请求:可以有多个@RequestParam。

    Content-type: (1)application/x-www-form-urlencoded:@RequestBody不是必须加的 (2)mutipart/form-data:@RequestBody不能处理这种格式 (3)其他格式,比如application/json,application/xml等,必须使用@RequestBody来处理

    1. @RequestMapping("/hello")
    2. public String toHello1(@RequestBody Book book){
    3.    log.info(">>>> 使用@RequestBody传递JSON格式的参数:{}", JSON.toJSONString(book));
    4.    return "index";
    5. }

    @RequestBody注解对应的类在将HTTP的输入流(含请求体)装配到目标类(即:@RequestBody后面的类)时,会根据json字符串中的key来匹配对应实体类的属性,如果匹配一致且json中的该key对应的值符合(或可转换为)实体类的对应属性的类型要求时,会调用实体类的setter方法将值赋给该属性。

    1.6.@RequestHeader

    使用 @RequestHeader 注解可以获取指定的请求头信息。如果想要获取所有的请求头信息,可以使用 Map、MultiValueMap、HttpHeaders 这三个 Map 中的任何一个封装所有请求头的 name 和 value。

    参数列表

    参数说明
    namename 和 value 互为别名,当只有一个参数时,可以省略 value,直接("xxx") 就可以了
    valuename 和 value 互为别名,当只有一个参数时,可以省略 value,直接("xxx") 就可以了
    required默认情况下,如果请求头中缺少了指定的 name,那么将会报错。 如果没有添加required = false,当请求头中没有这个zking请求头时就会报错。
    defaultValue如果请求头中缺少了指定的 name ,那么会报错,可以使用 defaultValue 这个属性指定默认值,就可以避免报错 ;如果请求头缺少指定 name ,该属性设置的值将会作为默认值,如果该属性不设置值,它有自己的默认值 DEFAULT_NONE

    示例:

    1. @GetMapping("/headParams")
    2. public Map userInfo(
    3.    @RequestHeader(value = "zking",defaultValue = "hello zking") String username,
    4.    // 将请求头中 name=Accept-Encoding 赋值给形参 encoding
    5.    @RequestHeader("Accept-Encoding") String encoding,
    6.    // 将请求头中 name=Host 赋值给形参 host
    7.    @RequestHeader("Host") String host,
    8.    // 将所有请求头的 name 和 value 封装到 Map 集合 headsMap 中
    9.    @RequestHeader Map<String,String> headsMap) {
    10.        Map map = new HashMap<String, Object>();
    11.        map.put("username",username);
    12.        map.put("Accept-Encoding",encoding);
    13.        map.put("Host",host);
    14.        map.put("headsMap",headsMap);
    15.        return map;
    16. }

    由于请求头中不存在 name=zking 这个信息,所以如果只用 value=zking 会抛出异常。

    解决方案: 1、required 的默认值为 true ,也就是请求头中没有 name=zking 会报错,将其值改为 false,即没有该头信息也不报错

    @RequestHeader(value = "zking",required = "false") String username

    2、不修改 required=true 这个默认值,当头信息中不包含 name=zking ,给它一个默认值 hello zking

    @RequestHeader(value = "zking",defaultValue = "hello zking") String username

    1.7.@PathVariable

    该注解请求URI中的模板变量部分到处理器功能处理方法的方法参数上的绑定。

    即当使用@RequestMapping URI template 样式映射时, 即 someUrl/{paramId}, 这时的paramId可通过 @Pathvariable注解绑定它传过来的值到方法的参数上。

    1. //@PathVariable可以用来映射URL中的占位符到目标方法的参数中
    2. @RequestMapping("/testPathVariable/{id}")
    3. public String testPathVariable(@PathVariable("id") Integer id)
    4. {
    5.    System.out.println("testPathVariable:"+id);
    6.    return SUCCESS;
    7. }

    Rest

    即 Representational State Transfer。(资源)表现层状态转化。是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。

    • 资源(Resources):网络上的一个实体,或者说是网络上的一个具体信息。它可以是一段文本、一张图片、一首歌曲、一种服务,总之就是一个具体的存在。可以用一个URI(统一资源定位符)指向它,每种资源对应一个特定的 URI 。要获取这个资源,访问它的URI就可以,因此 URI 即为每一个资源的独一无二的识别符。

    • 表现层(Representation):把资源具体呈现出来的形式,叫做它的表现层(Representation)。比如,文本可以用 txt 格式表现,也可以用 HTML 格式、XML 格式、JSON 格式表现,甚至可以采用二进制格式。

    • 状态转化(State Transfer):每发出一个请求,就代表了客户端和服务器的一次交互过程。HTTP协议,是一个无状态协议,即所有的状态都保存在服务器端。因此,如果客户端想要操作服务器,必须通过某种手段,让服务器端发生状态转化State Transfer)。而这种转化是建立在表现层之上的,所以就是 表现层状态转化。具体说,就是 HTTP 协议里面,四个表示操作方式的动词:GETPOSTPUTDELETE。它们分别对应四种基本操作:GET 用来获取资源,POST 用来新建资源,PUT 用来更新资源,DELETE 用来删除资源。

    示例:

    1. - /order/1 HTTP GET   :得到 id = 1order
    2. - /order/1 HTTP DELETE :删除 id = 1order
    3. - /order/1 HTTP PUT   :更新 id = 1order
    4. - /order   HTTP POST   :新增 order

    1.8.@CookieValue

    @CookieValue注解主要是将请求的Cookie数据,映射到功能处理方法的参数上。

    参数列表

    参数说明
    value绑定的参数名称,String类型。
    required是否必须包含value,boolean类型,默认为 true,表示请求参数中必须包含对应的参数;若不存在,将抛出异常。
    defaultValue默认值,String类型。当没有传参时将使用此值赋值。

    示例:

    1. @RequestMapping("/testCookieValue")
    2. public Map testCookieValue(
    3. @CookieValue("JSESSIONID") String cookie) {
    4.    response.put("cookie", cookie);
    5.    return response;
    6. }

    二、参数传递

    pom.xml

    1. <log4j2.version>2.9.1</log4j2.version>
    2. <log4j2.disruptor.version>3.2.0</log4j2.disruptor.version>
    3. <slf4j.version>1.7.13</slf4j.version>
    4. <!--4.log日志相关依赖-->
    5. <!-- log4j2日志相关依赖 -->
    6. <!-- log配置:Log4j2 + Slf4j -->
    7. <!-- slf4j核心包-->
    8. <dependency>
    9. <groupId>org.slf4j</groupId>
    10. <artifactId>slf4j-api</artifactId>
    11. <version>${slf4j.version}</version>
    12. </dependency>
    13. <dependency>
    14. <groupId>org.slf4j</groupId>
    15. <artifactId>jcl-over-slf4j</artifactId>
    16. <version>${slf4j.version}</version>
    17. <scope>runtime</scope>
    18. </dependency>
    19. <!--核心log4j2jar包-->
    20. <dependency>
    21. <groupId>org.apache.logging.log4j</groupId>
    22. <artifactId>log4j-api</artifactId>
    23. <version>${log4j2.version}</version>
    24. </dependency>
    25. <dependency>
    26. <groupId>org.apache.logging.log4j</groupId>
    27. <artifactId>log4j-core</artifactId>
    28. <version>${log4j2.version}</version>
    29. </dependency>
    30. <!--用于与slf4j保持桥接-->
    31. <dependency>
    32. <groupId>org.apache.logging.log4j</groupId>
    33. <artifactId>log4j-slf4j-impl</artifactId>
    34. <version>${log4j2.version}</version>
    35. </dependency>
    36. <!--web工程需要包含log4j-web,非web工程不需要-->
    37. <dependency>
    38. <groupId>org.apache.logging.log4j</groupId>
    39. <artifactId>log4j-web</artifactId>
    40. <version>${log4j2.version}</version>
    41. <scope>runtime</scope>
    42. </dependency>
    43. <!--需要使用log4j2的AsyncLogger需要包含disruptor-->
    44. <dependency>
    45. <groupId>com.lmax</groupId>
    46. <artifactId>disruptor</artifactId>
    47. <version>${log4j2.disruptor.version}</version>
    48. </dependency>

    2.1.基础类型+String

    1. @RequestMapping("/hello1")
    2.    public String toHello1(Integer bid,String bname){
    3.        log.info(">>>> 基础类型+String传参:{},{}",bid,bname);
    4.        return "index";
    5.   }

    2.2.复杂类型

    1. @RequestMapping("/hello2")
    2.    public String toHello2(Book book,
    3.                           HttpServletRequest req,
    4.                           HttpServletResponse resp,
    5.                           HttpSession session){
    6.        System.out.println(book);
    7.        log.info(">>>> HttpServletRequest/HttpServletResponse/HttpSession等等传参:{}", req.getRequestURI());
    8.        return "index";
    9.   }

    2.3.@RequestParam

    1. @RequestMapping("/hello3")
    2.    public String toHello3(@RequestParam Integer bid,
    3.                           @RequestParam(required = false,value = "price") Integer bookPrice,
    4.                           @RequestParam("bookName") String bname){
    5.        log.info(">>>> 使用@RequestParam注解传递参数:{},{},{}", bid,bname,bookPrice);
    6.        return "index";
    7.   }

    2.4.@PathVariable

    1. @RequestMapping("/hello4/{bid}")
    2.    public String toHello4(@PathVariable("bid") Integer bid){
    3.        log.info(">>>> 使用@PathVariable注解传递参数:{}", bid);
    4.        return "index";
    5.   }

    2.5.@RequestBody

    1. <jackson.version>2.9.3</jackson.version>
    2. <dependency>
    3.     <groupId>com.fasterxml.jackson.core</groupId>
    4.     <artifactId>jackson-databind</artifactId>
    5.     <version>${jackson.version}</version>
    6.   </dependency>
    7.   <dependency>
    8.     <groupId>com.fasterxml.jackson.core</groupId>
    9.     <artifactId>jackson-core</artifactId>
    10.     <version>${jackson.version}</version>
    11.   </dependency>
    12.   <dependency>
    13.     <groupId>com.fasterxml.jackson.core</groupId>
    14.     <artifactId>jackson-annotations</artifactId>
    15.     <version>${jackson.version}</version>
    16.   </dependency>
    17. //   能接受json数据,前提导入了Jackson依赖,没有导入Jackson依赖的话那进不了这个方法
    18.    @RequestMapping("/hello5")
    19.    public String toHello5(@RequestBody Map map){
    20.        System.out.println(map);
    21.        return "index";
    22.   }
    23. // 不能接受json数据
    24.    @RequestMapping("/hello6")
    25.    public String toHello6(Map map){
    26.        System.out.println(map);
    27.        return "index";
        }

    请使用postman或者apipost/eolink等工具发送请求数据。

    2.6.@RequestHeader

    1. @RequestMapping("/hello7")
    2.   public String toHello7(Book book, @RequestBody Map map, @RequestHeader("jwt") String jwt){
    3.       System.out.println(map);
    4.       System.out.println(book);
    5.       System.out.println(jwt);
    6.       return "index";
    7.   }

    综合代码

    1. package com.zking.controller;
    2. import com.zking.model.Book;
    3. import lombok.extern.slf4j.Slf4j;
    4. import org.springframework.stereotype.Controller;
    5. import org.springframework.web.bind.annotation.*;
    6. import javax.servlet.http.HttpServletRequest;
    7. import javax.servlet.http.HttpServletResponse;
    8. import javax.servlet.http.HttpSession;
    9. import java.util.Map;
    10. @Slf4j
    11. @RequestMapping("/demo")
    12. @Controller
    13. public class ParamController {
    14.   @RequestMapping(value="/hello")
    15.   public String hello(){
    16.       System.out.println("被调用了。。。。");
    17.       return "index";
    18.   }
    19.   @RequestMapping("/hello1")
    20.   public String toHello1(Integer bid,String bname){
    21.       log.info(">>>> 基础类型+String传参:{},{}",bid,bname);
    22.       return "index";
    23.   }
    24.   @RequestMapping("/hello2")
    25.   public String toHello2(Book book,
    26.                           HttpServletRequest req,
    27.                           HttpServletResponse resp,
    28.                           HttpSession session){
    29.       System.out.println(book);
    30.       log.info(">>>> HttpServletRequest/HttpServletResponse/HttpSession等等传参:{}", req.getRequestURI());
    31.       return "index";
    32.   }
    33.   @RequestMapping("/hello3")
    34.   public String toHello3(@RequestParam Integer bid,
    35.                           @RequestParam(required = false,value = "price") Integer bookPrice,
    36.                           @RequestParam("bookName") String bname){
    37.       log.info(">>>> 使用@RequestParam注解传递参数:{},{},{}", bid,bname,bookPrice);
    38.       return "index";
    39.   }
    40.   @RequestMapping("/hello4/{bid}")
    41.   public String toHello4(@PathVariable("bid") Integer bid){
    42.       log.info(">>>> 使用@PathVariable注解传递参数:{}", bid);
    43.       return "index";
    44.   }
    45. //   能接受json数据,前提导入了Jackson依赖,没有导入Jackson依赖的话那进不了这个方法
    46.   @RequestMapping("/hello5")
    47.   public String toHello5(@RequestBody Map map){
    48.       System.out.println(map);
    49.       return "index";
    50.   }
    51. // 不能接受json数据
    52.   @RequestMapping("/hello6")
    53.   public String toHello6(Map map){
    54.       System.out.println(map);
    55.       return "index";
    56.   }
    57.   @RequestMapping("/hello7")
    58.   public String toHello7(Book book, @RequestBody Map map, @RequestHeader("jwt") String jwt){
    59.       System.out.println(map);
    60.       System.out.println(book);
    61.       System.out.println(jwt);
    62.       return "index";
    63.   }
    64. }

    三、返回值

    3.1.void

    处理器对请求处理后,无需跳转到其它任何资源,此时可以让处理器方法返回 void。

    处理器方法返回 void 的应用场景,AJAX 响应。

    1. @RequestMapping("/queryStudents")
    2.    public void queryStudents(HttpServletResponse response) throws IOException {
    3.        //处理Ajax,使用json做数据格式
    4.        Student student = new Student();
    5.        student.setName("张三");
    6.        student.setAge(18);
    7.        try {
    8.            ResponseUtil.writeJson(response,student);
    9.       } catch (Exception e) {
    10.            e.printStackTrace();
    11.       }
    12.   }
    13. @Data
    14. class Student{
    15.    private String name;
    16.    private Integer age;
    17. }

    3.2.String

    1. @RequestMapping("/toHello")
    2. public String toHello(){
    3.    //逻辑视图名
    4.    return "hello";
    5. }

    返回类型为String,默认被作为视图名,指定逻辑视图名,经过视图解析器解析为jsp物理路径:/WEB-INF/page/success.jsp

    3.3.String+Model

    通过http://localhost:8080/springmvc01/toHello访问请求方法,并经过视图解析器跳转指定页面,最后完成视图模型数据渲染操作。

    1. @RequestMapping("/toHello1")
    2.    public String toHello1(Model model,HttpServletRequest request){
    3.        //填充模型数据
    4.        model.addAttribute("name","张三");
    5.        request.setAttribute("role","管理员");
    6.        //逻辑视图名
    7.        return "hello";
    8.   }

    3.4.ModelAndView

    1. @RequestMapping("/toHello2")
    2.    public ModelAndView toHello2(){
    3.        ModelAndView mv = new ModelAndView();
    4.        //填充模型数据
    5.        mv.addObject("name","张三");
    6.        mv.addObject("role","管理员");
    7.        mv.setViewName("hello");
    8.        //逻辑视图名
    9.        return mv;
    10.   }

    四、页面跳转

    转发(forward:path)和重定向(redirect:path)这两种跳转方式将会绕开视图解析器的前缀后缀;还有就是如果是在同一controller中则不用使用"/"从根目录开始,而如果是在不同的controller则一定要从根目录开始。

    path为请求处理方法名,而非逻辑视图名。

    • 转发(地址栏不变)

    1. @RequestMapping("/helloPage1")
    2.    public String toHelloPage1(){
    3.        System.out.println("helloPage1");
    4.        return "forward:toHello2";
    5.   }

    它相当于“request.getRequestDispatcher("url").forward(request,response)”。使用转发,既可以转发到jsp, 也可以转发到其他的控制器方法。

    • 重定向(地址栏改变)

    1. @RequestMapping("/helloPage2")
    2.    public String toHelloPage2(){
    3.        System.out.println("helloPage2");
    4.        return "redirect:toHello2";
    5.   }

    它相当于“response.sendRedirect(url)”。需要注意的是,如果重定向到jsp页面,则jsp页面不能写在WEB-INF目录中,否则无法找到。

    跳其它的controller

    1. @RequestMapping("/helloPage3")
    2.   public String toHelloPage3(){
    3.       System.out.println("helloPage3");
    4.       return "forward:/demo/hello";
    5.   }
    6.   @RequestMapping("/helloPage4")
    7.   public String toHelloPage4(){
    8.       System.out.println("helloPage4");
    9.       return "redirect:/demo/hello";
    10.   }

  • 相关阅读:
    JUC P5 自定义线程池,线程池应用 基础+代码
    kubeflow核心功能
    【QT开发(11)】QT 线程QThread
    Qt跨平台(统信UOS)各种坑解决办法
    [网鼎杯 2020 青龙组]AreUSerialz
    基于bp神经网络的pid算法,基于单神经元的pid控制
    事务提交之后再执行某些操作 → 你有哪些实现方式?
    Adobe推出了PS新功能Generative Fill(创成式填充);生成式 AI 将改变电脑架构;
    快速入门C++第四天——继承与派生
    乐高式扩展:在Seal软件供应链防火墙中轻松集成代码规范工具
  • 原文地址:https://blog.csdn.net/weixin_74268571/article/details/132725905