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


相关文章
|
4月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
6月前
|
JavaScript Java 微服务
现代化 Java Web 在线商城项目技术方案与实战开发流程及核心功能实现详解
本项目基于Spring Boot 3与Vue 3构建现代化在线商城系统,采用微服务架构,整合Spring Cloud、Redis、MySQL等技术,涵盖用户认证、商品管理、购物车功能,并支持Docker容器化部署与Kubernetes编排。提供完整CI/CD流程,助力高效开发与扩展。
743 64
|
4月前
|
开发框架 前端开发 Go
【GoGin】(0)基于Go的WEB开发框架,GO Gin是什么?怎么启动?本文给你答案
Gin:Go语言编写的Web框架,以更好的性能实现类似Martini框架的APInet/http、Beego:开源的高性能Go语言Web框架、Iris:最快的Go语言Web框架,完备的MVC支持。
463 1
|
8月前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:路由、中间件、参数校验
Gin框架以其极简风格、强大路由管理、灵活中间件机制及参数绑定校验系统著称。本文详解其核心功能:1) 路由管理,支持分组与路径参数;2) 中间件机制,实现全局与局部控制;3) 参数绑定,涵盖多种来源;4) 结构体绑定与字段校验,确保数据合法性;5) 自定义校验器扩展功能;6) 统一错误处理提升用户体验。Gin以清晰模块化、流程可控及自动化校验等优势,成为开发者的优选工具。
|
8月前
|
开发框架 安全 前端开发
Go Web开发框架实践:模板渲染与静态资源服务
Gin 是一个功能强大的 Go Web 框架,不仅适用于构建 API 服务,还支持 HTML 模板渲染和静态资源托管。它可以帮助开发者快速搭建中小型网站,并提供灵活的模板语法、自定义函数、静态文件映射等功能,同时兼容 Go 的 html/template 引擎,具备高效且安全的页面渲染能力。
|
7月前
|
前端开发 Java API
Spring Cloud Gateway Server Web MVC报错“Unsupported transfer encoding: chunked”解决
本文解析了Spring Cloud Gateway中出现“Unsupported transfer encoding: chunked”错误的原因,指出该问题源于Feign依赖的HTTP客户端与服务端的`chunked`传输编码不兼容,并提供了具体的解决方案。通过规范Feign客户端接口的返回类型,可有效避免该异常,提升系统兼容性与稳定性。
514 0
|
8月前
|
开发框架 JSON 中间件
Go语言Web开发框架实践:使用 Gin 快速构建 Web 服务
Gin 是一个高效、轻量级的 Go 语言 Web 框架,支持中间件机制,非常适合开发 RESTful API。本文从安装到进阶技巧全面解析 Gin 的使用:快速入门示例(Hello Gin)、定义 RESTful 用户服务(增删改查接口实现),以及推荐实践如参数校验、中间件和路由分组等。通过对比标准库 `net/http`,Gin 提供更简洁灵活的开发体验。此外,还推荐了 GORM、Viper、Zap 等配合使用的工具库,助力高效开发。
|
7月前
|
SQL Java 数据库连接
Spring、SpringMVC 与 MyBatis 核心知识点解析
我梳理的这些内容,涵盖了 Spring、SpringMVC 和 MyBatis 的核心知识点。 在 Spring 中,我了解到 IOC 是控制反转,把对象控制权交容器;DI 是依赖注入,有三种实现方式。Bean 有五种作用域,单例 bean 的线程安全问题及自动装配方式也清晰了。事务基于数据库和 AOP,有失效场景和七种传播行为。AOP 是面向切面编程,动态代理有 JDK 和 CGLIB 两种。 SpringMVC 的 11 步执行流程我烂熟于心,还有那些常用注解的用法。 MyBatis 里,#{} 和 ${} 的区别很关键,获取主键、处理字段与属性名不匹配的方法也掌握了。多表查询、动态
214 0
|
7月前
|
JSON 前端开发 Java
第05课:Spring Boot中的MVC支持
第05课:Spring Boot中的MVC支持
322 0
|
10月前
|
人工智能 自然语言处理 JavaScript
测试工程师要失业?Magnitude:开源AI Agent驱动的端到端测试框架,让Web测试更智能,自动完善测试用例!
Magnitude是一个基于视觉AI代理的开源端到端测试框架,通过自然语言构建测试用例,结合推理代理和视觉代理实现智能化的Web应用测试,支持本地运行和CI/CD集成。
1379 15
测试工程师要失业?Magnitude:开源AI Agent驱动的端到端测试框架,让Web测试更智能,自动完善测试用例!

热门文章

最新文章