详解 SpringMVC 的 @RequestMapping 注解
@RequestMapping
是一个用来映射请求的注解,它可以用于 controller 的类定义以及方法定义上。用于类定义时,表示类中的所有响应请求的方法都是以该地址作为父路径;用于方法定义时,表示该方法响应的具体请求路径。
解决方案:
- 基本使用:
@Controller
@RequestMapping("/users")
public class UserController {
@RequestMapping("/list")
public String getUserList() {
// 处理请求
return "userList";
}
}
在这个例子中,/users/list
映射到 getUserList()
方法。
- 指定请求方法:
@RequestMapping(value = "/list", method = RequestMethod.GET)
public String getUserList() {
// 处理请求
return "userList";
}
在这个例子中,/users/list
只接受 GET 请求。
- 接受多种 HTTP 请求方法:
@RequestMapping(value = "/list", method = {RequestMethod.GET, RequestMethod.POST})
public String getUserList() {
// 处理请求
return "userList";
}
在这个例子中,/users/list
接受 GET 和 POST 请求。
- 接受请求参数:
@RequestMapping(value = "/list", params = "type=admin")
public String getAdminUserList() {
// 处理请求
return "adminUserList";
}
在这个例子中,/users/list
只接受包含 type=admin
参数的请求。
- 路径变量的使用:
@RequestMapping(value = "/{userId}/detail")
public String getUserDetail(@PathVariable("userId") String userId) {
// 处理请求,使用userId参数
return "userDetail";
}
在这个例子中,/users/{userId}/detail
映射到 getUserDetail()
方法,并将路径变量 userId
作为参数传递。
- 使用正则表达式:
@RequestMapping(value = "/{symbolicName:[a-z-]+}-{version:\\d\\.\\d\\.\\d}{extension:\\.[a-z]+}")
public String getLibrary(
@PathVariable String symbolicName,
@PathVariable String version,
@PathVariable String extension) {
// 处理请求
return "library";
}
在这个例子中,/users/{symbolicName:[a-z-]+}-{version:\\d\\.\\d\\.\\d}{extension:\\.[a-z]+}
映射到 getLibrary()
方法,并提取符号名称和版本作为参数。
以上例子展示了 @RequestMapping
的基本用法,实际应用中可以根据具体需求进行调整和复杂组合。
评论已关闭