简介
REST(Representational State Transfer),表现形式状态转换。
- 传统风格资源描述形式
http://localhost/user/getById?id=1
http://localhost/user/saveUser
- REST风格描述形式
http://localhost/user/1
http://localhost/user
优点:
- 隐藏资源的访问行为,无法通过地址得知对方是何种操作
- 书写简化
按照REST风格访问资源时使用行为动作区分对资源进行了何种操作,如:
- http://localhost/users // 查询全部用户信息 GET(查询)
- http://localhost/users/1 // 查询指定用户信息 GET(查询)
- http://localhost/users // 添加用户信息 POST(新增/保存)
- http://localhost/users // 修改用户信息 PUT(修改/更新)
- http://localhost/users/1 // 删除用户信息 DELETE(删除)
提供REST风格对资源进行访问成为RESTFUL。
REST风格实现
- 将相关的所有方法前缀设置为USERS
- 使用method 参数将对应的方法行为进行设定。
例如无参的方法:
@RequestMapping(value = "/users", method = RequestMehtod.POST)
@RequestBody
public String save() {
System.out.println("user save");
return "{'module' : 'save success!'}";
}
对于有参数的时候:
@RequestMapping(value = "/users/{id}", method = RequestMehtod.DELETE)
@RequestBody
public String delete(@PathVariable Integer id) {
System.out.println("user : " + id + " delete");
return "{'module' : 'delete id success!'}";
}
- 使用
@PathVariable注解 - 在mapping路径后添加
/{id},保证id名称跟形参一致

RESTful快速开发
- 简化前面的路径名
将
@RequestMapping(value = "/users/{id}", method = RequestMehtod.DELETE)中的路径放到类上
@RequestMapping(value = "/users/{id}"}
- 简化方法前面的
@RequestBody注解
- 在类上添加
@RequestBody- 将
@Controller、@RequestBody合并,使用@RestController
- 将方法参数上指定的方法使用注解来优化:
修改前:
@RequestMapping(value = "/users/{id}", method = RequestMehtod.DELETE)修改后:
@DeleteMapping("{/id}")
234

被折叠的 条评论
为什么被折叠?



