SpringMVC(基于Spring 的Web 层MVC 框架)–SpingMVC 执行流程–@RequestMapping的使用
SpingMVC 执行流程图
执行流程可以等对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"; }
- 当明确指定了method , 则需要按指定方式请求, 否则会报错,比如
@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 风格资源地址
- ?:匹配文件名中的一个字符
- *:匹配文件名中的任意字符
- **:匹配多层路径
- 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 绑定的占位符
- @RequestMapping 还可以配合@PathVariable 映射URL 绑定的占位符。
- 这样就不需要在url 地址上带参数名了,更加的简洁明了
比如: 我们的前端页面是这样的, kristina 和300 是参数值.
应用实例
- 修改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>
自己完成页面测试。
注意事项和使用细节
- 映射的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。
- 各种请求的简写形式
说明
@RequestMapping(value = "/buy",method = RequestMethod.POST) 等价@PostMapping(value = "/buy") //四种简写方式一览: @GetMapping @PostMapping @PutMapping @DeleteMapping
- 如果我们确定表单或者超链接会提交某个字段数据比如(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, 一定要注入提交参数名和后台方法的形参名保持一致, 否则后端接收不到参数.