SpringMVC(基于Spring 的Web 层MVC 框架)--SpingMVC 执行流程--@RequestMapping的使用

简介: SpringMVC(基于Spring 的Web 层MVC 框架)--SpingMVC 执行流程--@RequestMapping的使用

SpringMVC(基于Spring 的Web 层MVC 框架)–SpingMVC 执行流程–@RequestMapping的使用


SpingMVC 执行流程图


image.png

执行流程可以等对SpringMVC 有一定基础的时候,在Debug 源码,进行深入了解。


@RequestMapping


基本使用


@RequestMapping 注解可以指定控制器/处理器的某个方法的请求的url, RequestMapping : 请求映射。


@RequestMapping 注解其它使用方式


@RequestMapping 可以修饰方法和类


说明: @RequestMapping 注解可以修饰方法,还可以修饰类,当@RequestMapping 同时修饰类和方法时,请求的url 就是组合/类请求值/方法请求值.


应用实例

创建com\web\UserHandler.java

@RequestMapping(value = "/user")
@Controller //UserHandler就是一个处理器/控制器,注入到容器
public class UserHandler {
    /**
     * 1. method=RequestMethod.POST: 表示请求buy目标方法必须是 post
     * 2. RequestMethod 四个常用选项 POST, GET, PUT, DELETE
     * 3. SpringMVC 控制器默认支持GET和POST两种方式
     * 4. buy()方法请求的url: http://ip:port/工程路径/user/buy
     * 5. @PostMapping(value = "/buy")等价 @RequestMapping(value = "/buy",method = RequestMethod.POST)
     */
    @PostMapping(value = "/buy")
    public String buy() {
        System.out.println("购买商品~");
        return "success";
    }
}


创建springmvc\web\request.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>购买商品</title>
</head>
<body>
<h1>购买商品</h1>
    <%--
    1. action="user/buy" 对应 url http://localhost:8080/工程路径/user/buy
    --%>
<form action="user/buy" method="post">
    购买人:<input type="text" name="username"><br>
    够买量:<input type="text" name="nums"><br>
    <input type="submit" value="购买">
</form>


创建springmvc\web\WEB-INF\pages\success.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
    <head>
      <title>操作成功</title>
    </head>
    <body>
      <h1>恭喜, 操作成功~</h1>
    </body>
</html>

启动tomcat在跳出的页面输入请求路径就可以进行测试。也可以使用Postman 方式完成测试。

注意请求方式是否正确,请求方式错误会出现[Request method ‘GET’ not supported].


@RequestMapping 可以指定请求方式


说明: @RequestMapping 还可以指定请求的方式(post/get/put/delete…), 请求的方式需要和指定的一样,否则报错.


SpringMVC 控制器默认支持GET 和POST 两种方式, 也就是你不指定method , 可以接收GET 和POST 请求.


应用实例

  @RequestMapping(value = "/buy",method = RequestMethod.POST)
  public String buy() {
        System.out.println("buy,post方法");
        return "success";
 }


  1. 当明确指定了method , 则需要按指定方式请求, 否则会报错,比如


image.png


@RequestMapping 可指定params 和headers 支持简单表达式


1param1: 表示请求必须包含名为param1 的请求参数

2!=param1: 表示请求不能包含名为param1 的请求参数

3param1 != value1: 表示请求包含名为param1 的请求参数,但其值不能为value1

4{“param1=value1”, “param2”}: 请求必须包含名为param1 和param2 的两个请求参数,且param1 参数的值必须为value1.


应用实例

修改UserHandler.java , 增加方法

// params="bookId" 表示请求该目标方法时,必须给一个bookId 参数
@RequestMapping(value = "/find", params = "bookId", method = RequestMethod.GET)
public String search(String bookId) {
    System.out.println("查询书籍bookId= " + bookId);
    return "success";
}


修改request.jsp , 增加代码

<hr><h1>演示params的使用</h1>
<a href="user/find?bookId=200">查询书籍</a>
<%--搭配params 简单表达式使用--%>


自己使用页面方式完成测试。


@RequestMapping 支持Ant 风格资源地址


  1. ?:匹配文件名中的一个字符
  2. *:匹配文件名中的任意字符
  3. **:匹配多层路径
  4. Ant 风格的url 地址举例


/user/createUser??: 匹配/user/createUseraa、/user/createUserbb 等URL

/user/*/createUser: 匹配/user/aaa/createUser、/user/bbb/createUser 等URL

/user/**/createUser: 匹配/user/createUser、/user/aaa/bbb/createUser 等URL


应用实例


修改UserHandler.java, 增加方法

    /**
     * 要求: 可以配置  /user/message/aa, /user/message/aa/bb/cc
     * 1. @RequestMapping(value = "/message/**") /** 可以匹配多层路径
     */
    @RequestMapping(value = "/message/**")
    public String im() {
        System.out.println("发送消息");
        return "success";
    }


request.jsp, 增加代码

<hr><h1>演示Ant风格的请求资源方式 </h1>
<a href="user/message/aa">发送消息1</a><br>
<a href="user/message/aa/bb/cc">发送消息2</a><br>


@RequestMapping 可配合@PathVariable 映射URL 绑定的占位符


  1. @RequestMapping 还可以配合@PathVariable 映射URL 绑定的占位符。
  2. 这样就不需要在url 地址上带参数名了,更加的简洁明了
    比如: 我们的前端页面是这样的, kristina 和300 是参数值.


应用实例


  1. 修改UserHandler.java, 增加方法, 注意@PathVariable(“username”) 不能少.
    //要求: 我们希望目标方法获取到 username 和 userid, value="/xx/{username}" - @PathVariable("username")..
    //前端页面: <a href="user/reg/kristina/300">占位符的演示</a>
    //(value = "/reg/{username}/{userid}"): 表示kristina->{username} 300=>{userid}
    @RequestMapping(value = "/reg/{username}/{userid}")
    public String register(@PathVariable("username") String name,
                           @PathVariable("userid") String id) {
        System.out.println("接收到参数--" + "username= " + name + "--" + "usreid= " + id);
        return "success";
    }


修改request.jsp, 增加代码

<hr><h1>占位符的演示</h1>
<a href="user/reg/kristina/300">占位符的演示</a>

自己完成页面测试。


注意事项和使用细节


  1. 映射的URL, 不能重复。

举例:

@RequestMapping(value = "/hi")
public String hi() {
        System.out.println("hi");
        return "success";
}
@RequestMapping(value = "/hi")
public String hi2() {
        System.out.println("hi");
        return "success";
}

服务端报错信息:to { [/user/hi]}: There is already ‘userHandler’ bean method。


  1. 各种请求的简写形式

说明

@RequestMapping(value = "/buy",method = RequestMethod.POST) 等价@PostMapping(value = "/buy")
//四种简写方式一览: @GetMapping @PostMapping @PutMapping @DeleteMapping


  1. 如果我们确定表单或者超链接会提交某个字段数据比如(email), 要求提交的参数名和目标方法的参数名保持一致.

应用实例, 修改springmvc\src\com\web\UserHandler.java , 增加方法

 /**
     * hello3(String email): 如果我们的请求参数有 email=xx, 就会将传递的值,赋给String email
     * ,要求名称保持一致, 如果不一致,那么接收不到数据, 而是null
     */
    @GetMapping(value = "/hello3")
    public String hello3(String email) {
        System.out.println("hello3 " + email);
        return "success";
    }

测试的时候输入localhost:9998/user/hello3?email=62355@sohu.com, 一定要注入提交参数名和后台方法的形参名保持一致, 否则后端接收不到参数.


g(value = “/hello3”)

public String hello3(String email) {

System.out.println("hello3 " + email);

return “success”;

}

测试的时候输入localhost:9998/user/hello3?email=62355@sohu.com, 一定要注入提交参数名和后台方法的形参名保持一致, 否则后端接收不到参数.


相关文章
|
27天前
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
|
1月前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
85 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
1月前
|
设计模式 前端开发 Java
步步深入SpringMvc DispatcherServlet源码掌握springmvc全流程原理
通过对 `DispatcherServlet`源码的深入剖析,我们了解了SpringMVC请求处理的全流程。`DispatcherServlet`作为前端控制器,负责请求的接收和分发,处理器映射和适配负责将请求分派到具体的处理器方法,视图解析器负责生成和渲染视图。理解这些核心组件及其交互原理,有助于开发者更好地使用和扩展SpringMVC框架。
56 4
|
2月前
|
前端开发 Java Spring
Spring MVC核心:深入理解@RequestMapping注解
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的核心,它将HTTP请求映射到控制器的处理方法上。本文将深入探讨`@RequestMapping`注解的各个方面,包括其注解的使用方法、如何与Spring MVC的其他组件协同工作,以及在实际开发中的应用案例。
58 4
|
2月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
197 2
|
3月前
|
XML 前端开发 Java
【Spring】@RequestMapping、@RestController和Postman
【Spring】@RequestMapping、@RestController和Postman
43 2
【Spring】@RequestMapping、@RestController和Postman
|
2月前
|
XML Java 网络架构
使用 Spring Boot 公开 SOAP Web 服务端点:详细指南
使用 Spring Boot 公开 SOAP Web 服务端点:详细指南
108 0
|
3月前
|
JSON 前端开发 Java
SSM:SpringMVC
本文介绍了SpringMVC的依赖配置、请求参数处理、注解开发、JSON处理、拦截器、文件上传下载以及相关注意事项。首先,需要在`pom.xml`中添加必要的依赖,包括Servlet、JSTL、Spring Web MVC等。接着,在`web.xml`中配置DispatcherServlet,并设置Spring MVC的相关配置,如组件扫描、默认Servlet处理器等。然后,通过`@RequestMapping`等注解处理请求参数,使用`@ResponseBody`返回JSON数据。此外,还介绍了如何创建和配置拦截器、文件上传下载的功能,并强调了JSP文件的放置位置,避免404错误。
|
4月前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
|
3月前
|
前端开发 Java 应用服务中间件
【Spring】Spring MVC的项目准备和连接建立
【Spring】Spring MVC的项目准备和连接建立
74 2