基于MVC
的RESTful
风格的实现
1.RESTful
风格阐述
1.1REST
风格资源路径
REST
风格的资源路径设计是面向资源的,资源的名称应该是准确描述该资源的名词。
1.2HTTP
方法
资源地址和HTTP
方法结合在一起就可以实现对资源的完整定位
1.3RESTful
风格API
设计
上文讲述了通过HTTP方法和资源路径对服务器的一个资源进行定位的过程
接下来看一个REST风格API
的设计
可以看到通过这个RESTAPI
都是通过对同一个资源的操作,所不同的就是通过不同的HTTP方法来实现对资源不同的处理。
2.MVC
对REST
的支持
1.1主要通过注解来实现
@Controller
声名一个处理请求的控制器@RequestMapping
请求映射地址,它存在几个子注解对于实现REST
风格来说更加具有语义性@GETMapping
GET请求@PUTMapping
PUT请求@POSTMapping
POST请求@DELETEMapping
DELETE请求
@ResponseBody
将响应内容转换为JSON
格式@RequestBody
请求内容转换为JSON
格式@PathVariable("id")
用于绑定一个参数@RESTController
等同于@Controller
+@ResponseBody
在类上写了这个注解,标识这个类的所有方法只返回数据,而不进行视图跳转
1.2返回HTTP
状态码
REST
风格API
一个最鲜明的特点通过返回对应的HTTPStatus
来判断客户端的操作是否完成
下面是spring中关于Http
状态码描述的枚举类,本文列举了常见的状态码(读者若对此感兴趣可以查看HttpStatus
源码)
public enum HttpStatus{
OK(200, "OK"),//用于服务器有实体响应
CREATED(201, "Created"),//创建了新实体,响应该实体
NO_CONTENT(204, "No Content"),//服务器正常响应,但无实体响应
BAD_REQUEST(400, "Bad Request"),//客户端请求语法错误
NOT_FOUND(404, "Not Found"),//目标资源不存在
INTERNAL_SERVER_ERROR(500, "Internal Server Error"),//服务器内部错误
NOT_IMPLEMENTED(501, "Not Implemented"),//服务器不支持当前请求
}
Spring返回状态码是通过@ResponseStatus
注解或者ResponseEntity<?>
类实现的。
@ResponseStatus
方式
@GetMapping(path = "/user/{id}" , produces = "application/json;charset=utf-8")
@ResponseStatus(HttpStatus.OK)
public User findUserById(@PathVariable("id")Integer id){
User user = userService.findUserById(id);
return user ;
}
ResponseEntity<?>
方式
@GetMapping(produces = "application/json;charset=utf-8")
public ResponseEntity<List<User>> findAll(){
List<User> users = userService.findAll();
return new ResponseEntity<List<User>>(users , HttpStatus.OK);
}
1.3由于MVC
默认不支持PUT
和DELETE
方法,所以需要手动开启
在tomcat
服务器的web.xml
文件中开启一下配置
<servlet>
<servlet-name>default</servlet-name>
<servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>0</param-value>
</init-param>
<init-param>
<param-name>listings</param-name>
<param-value>false</param-value>
</init-param>
<init-param>
<param-name>readonly</param-name>
<param-value>true</param-value><!--开启这个-->
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
在项目的web.xml
中配置
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<servlet-name>dispathcherServlet</servlet-name>
</filter-mapping>
3.MVC
实现REST
代码实现
3.1实例环境
JDK1.8
maven3.60
tomcat9
3.2API
设计
3.3控制层代码
@RestController
@RequestMapping("/users")
public class UserControler {
@Autowired
private IUserService userService ;
//REST风格实现方法
/**
* 查询所有
* @return
*/
@GetMapping(produces = "application/json;charset=utf-8")
public ResponseEntity<List<User>> findAll(){
List<User> users = userService.findAll();
return new ResponseEntity<List<User>>(users , HttpStatus.OK);
}
/**、
* 根据ID查询
* @param id
* @return
*/
@GetMapping(path = "/{id}" , produces = "application/json;charset=utf-8")
@ResponseStatus(HttpStatus.OK)
public User findUserById(@PathVariable("id")Integer id){
User user = userService.findUserById(id);
return user ;
}
/**
* 增加一个用户
* 返回该用户
*/
@PostMapping(produces = "application/json;charset=utf-8")
@ResponseStatus(HttpStatus.CREATED)
public User addUser(@RequestBody User user){
User newUser = userService.addUser(user);
return