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, 一定要注入提交参数名和后台方法的形参名保持一致, 否则后端接收不到参数.


相关文章
|
5月前
|
缓存 安全 Java
《深入理解Spring》过滤器(Filter)——Web请求的第一道防线
Servlet过滤器是Java Web核心组件,可在请求进入容器时进行预处理与响应后处理,适用于日志、认证、安全、跨域等全局性功能,具有比Spring拦截器更早的执行时机和更广的覆盖范围。
|
5月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
7月前
|
JavaScript Java 微服务
现代化 Java Web 在线商城项目技术方案与实战开发流程及核心功能实现详解
本项目基于Spring Boot 3与Vue 3构建现代化在线商城系统,采用微服务架构,整合Spring Cloud、Redis、MySQL等技术,涵盖用户认证、商品管理、购物车功能,并支持Docker容器化部署与Kubernetes编排。提供完整CI/CD流程,助力高效开发与扩展。
806 64
|
6月前
|
存储 安全 Java
如何在 Spring Web 应用程序中使用 @SessionScope 和 @RequestScope
Spring框架中的`@SessionScope`和`@RequestScope`注解用于管理Web应用中的状态。`@SessionScope`绑定HTTP会话生命周期,适用于用户特定数据,如购物车;`@RequestScope`限定于单个请求,适合无状态、线程安全的操作,如日志记录。合理选择作用域能提升应用性能与可维护性。
278 1
|
7月前
|
存储 NoSQL Java
探索Spring Boot的函数式Web应用开发
通过这种方式,开发者能以声明式和函数式的编程习惯,构建高效、易测试、并发友好的Web应用,同时也能以较小的学习曲线迅速上手,因为这些概念与Spring Framework其他部分保持一致性。在设计和编码过程中,保持代码的简洁性和高内聚性,有助于维持项目的可管理性,也便于其他开发者阅读和理解。
225 0
|
8月前
|
前端开发 Java API
Spring Cloud Gateway Server Web MVC报错“Unsupported transfer encoding: chunked”解决
本文解析了Spring Cloud Gateway中出现“Unsupported transfer encoding: chunked”错误的原因,指出该问题源于Feign依赖的HTTP客户端与服务端的`chunked`传输编码不兼容,并提供了具体的解决方案。通过规范Feign客户端接口的返回类型,可有效避免该异常,提升系统兼容性与稳定性。
571 0
|
8月前
|
SQL Java 数据库连接
Spring、SpringMVC 与 MyBatis 核心知识点解析
我梳理的这些内容,涵盖了 Spring、SpringMVC 和 MyBatis 的核心知识点。 在 Spring 中,我了解到 IOC 是控制反转,把对象控制权交容器;DI 是依赖注入,有三种实现方式。Bean 有五种作用域,单例 bean 的线程安全问题及自动装配方式也清晰了。事务基于数据库和 AOP,有失效场景和七种传播行为。AOP 是面向切面编程,动态代理有 JDK 和 CGLIB 两种。 SpringMVC 的 11 步执行流程我烂熟于心,还有那些常用注解的用法。 MyBatis 里,#{} 和 ${} 的区别很关键,获取主键、处理字段与属性名不匹配的方法也掌握了。多表查询、动态
234 0
|
8月前
|
JSON 前端开发 Java
第05课:Spring Boot中的MVC支持
第05课:Spring Boot中的MVC支持
347 0
|
前端开发 Java BI
Spring3 Web MVC 集成Jasper Report生成PDF例子
Spring3 Web MVC 集成Jasper Report生成PDF例子
252 7
|
JSON 前端开发 Java
Spring Web MVC入门(3)——响应
Spring Web MVC入门(3)——响应
232 1