SpringMVC-@RequestMapping

  |   0 评论   |   0 浏览

@RequestMapping

1.基本使用

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

image-20220603173052593

2.@RequestMapping 注解其它使用方式

1.@RequestMapping 可以修饰方法和类

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

1)创建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两种方式
     * <p>
     * 4. buy()方法请求的url: http://ip:port/工程路径/user/buy
     * 5. @PostMapping(value = "/buy")等价 @RequestMapping(value = "/buy",method = RequestMethod.POST)
     * @return
     */
    //@RequestMapping(value = "/buy",method = RequestMethod.POST)
    @PostMapping(value = "/buy")
    public String buy() {
        System.out.println("购买商品~");
        return "success";
    }
}

2) 创建\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>
</body>
</html>

3) 创建 \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>

2.@RequestMapping 可以指定请求方式

  1. 说明: @RequestMapping 还可以指定请求的方式(post/get/put/delete..), 请求的方式需 要和指定的一样,否则报错
  2. SpringMVC 控制器默认支持GET和POST两种方式, 也就是你不指定 method , 可以接收 GET 和 POST 请求
  3. 应用实例
@RequestMapping(value = "/buy",method = RequestMethod.POST)
public String buy() {
    System.out.println("购买商品~");
    return "success";
}
  1. 当明确指定了 method , 则需要按指定方式请求, 否则会报错,比如

image-20220603230403765

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

  1. param1: 表示请求必须包含名为 param1 的请求参数
  2. !=param1: 表示请求不能包含名为 param1 的请求参数
  3. param1 != value1: 表示请求包含名为 param1 的请求参数,但其值不能为 value1
  4. {"param1=value1", "param2"}: 请求必须包含名为 param1 和 param2 的两个请求参数, 且 param1 参数的值必须为 value1
  5. 应用实例

1)修改UserHandler

/**
 * 1. params="bookId" 表示请求该目标方法时,必须给一个bookId参数, 值没有限定
 * 2. search(String bookId): 表示请求目标方法时, 携带的bookId=100, 就会将请求携带的 bookId对应的
 * 值 100, 赋给 String bookId
 * 3. params = "bookId=100" 表示必须给一个bookId参数, 而且值必须是100
 * @return
 */
@RequestMapping(value = "/find", params = "bookId=100", method = RequestMethod.GET)
public String search(String bookId) {
    System.out.println("查询书籍 bookId= " + bookId);
    return "success";
}

2) 修改 request.jsp , 增加代码

<hr><h1>演示params的使用</h1>
<a href="user/find?bookId=200">查询书籍</a>

注意:

1.需要有 bookId 参数,并且值为 100, 否则报错

image-20220603230836205

2.需要有 bookId 参数,并且值不为 100, 否则报错

image-20220603230948837

4.@RequestMapping 支持 Ant 风格资源地址

  1. ?:匹配文件名中的一个字符
  2. *:匹配文件名中的任意字符 *
  3. **:匹配多层路径
  4. Ant 风格的 url 地址举例 /user/*/createUser: 匹配 /user/aaa/createUser、/user/bbb/createUser 等 URL /user/**/createUser: 匹配 /user/createUser、/user/aaa/bbb/createUser 等 URL /user/createUser??: 匹配 /user/createUseraa、/user/createUserbb 等 URL
  5. 应用实例

1) 修改 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";
}

2) request.jsp, 增加代码

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

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

  1. @RequestMapping 还可以配合 @PathVariable 映射 URL 绑定的占位符。
  2. 这样就不需要在 url 地址上带参数名了,更加的简洁明了 比如: 我们的前端页面是 这样的, kristina 和 300 是参数值
<hr><h1>占位符的演示</h1>
<a href="user/reg/kristina/300">占位符的演示</a>
3. 应用实例
//要求: 我们希望目标方法获取到 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";
}

6.注意事项和使用细节

  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

  2. 各种请求的简写形式

说明 @RequestMapping(value = "/buy",method = RequestMethod.POST) 等 价 @PostMapping(value = "/buy") 简写方式一览: @GetMapping @PostMapping @PutMapping @DeleteMapping
  1. 如果我们确定表单或者超链接会提交某个字段数据比如(email), 要求提交的参数名和目 标方法的参数名保持一致
@GetMapping(value = "/hello3") 
public String hello3(String email) { 
    System.out.println("hello3 " + email); return "success"; 
}

一定要注入提交参数名 和后台方法的形参名保持一致, 否则后端接收不到参数

4.如果我们在参数中加入了@RequestParam注解,默认参数是必填的,否则会抛出异常;如果指定@RequestParam(name = "email",required = false)required属性为false则不会抛出异常
@GetMapping(value = "/hello3")
public String hello3(@RequestParam(name = "email") String email) {
    System.out.println("hello3 " + email);
    return "success";
}

image-20220603232229975

image-20220603232602032


标题:SpringMVC-@RequestMapping
作者:llp
地址:https://llinp.cn/articles/2022/06/03/1654270111840.html