使用SpringMVC 实现RESTful,并解决PUT,DELETE请求无法提交表单数据的问题
了解RESTful,使用SpringMVC 实现RESTful
关于REST:
1.表述性状态转移,是web服务的一种架构风格,是一种思想,而非标准或软件。
2. 通常基于使用HTTP,URI,XML、JSON、HTML这些现广泛流行的协议。
3.属于轻量级(使用时没有太多依赖,耦合性低),跨平台、跨语言的架构设计。
REST式(RESTful)的web服务
1.Web service的两种标准:JAX-WS 、JAX-RS
2.REST式的web服务是ROA(面向资源的架构)、执行JAX-RS标准
REST架构原则
1.同一资源具有多种表现形式,比如xml,json;
2.每个资源具有唯一资源标识符
3.操作无状态(服务器只处理当前request,利用pool技术提高稳定性和性能)
4.符合REST原则的架构方式即为 RESTful
URI和URL
uri http://example.com/users/
url http://example.com/users/{user} ,带参
URI范围大于URL。
经验告诉我们,uri和url在定义时限定不要使用大写字母,使用中线 - 代替下划线_,参数列表应该被encode过
注:[https 和http区别,https属于加密传输,更安全,需要收费]
资源的四种操作CRUD
RESTful中要求:获取资源 GET,创建资源 POST,修改资源状态 PUT,删除资源 DELETE。同http请求方法。
demo:
之前的操作:
http://127.0.0.1/user/query/1 GET 根据用户id查询用户数据
http://127.0.0.1/user/save POST 新增用户
http://127.0.0.1/user/update POST 修改用户信息
http://127.0.0.1/user/delete GET/POST 删除用户信息
每次都对操作做描述,这是没有必要的
RESTful用法:
http://127.0.0.1/user/1 GET 根据用户id查询用户数据
http://127.0.0.1/user POST 新增用户
http://127.0.0.1/user PUT 修改用户信息
http://127.0.0.1/user DELETE 删除用户信息
REST响应设计
http响应状态码
SpringMVC实现RESTful服务
实例展示:`//restful的应用
@RequestMapping("new/user")
@Controller
public class NewUserController {
@Autowired
private UserService userService;
// 根据用户id查询用户信息 运用restful
//测试 http://127.0.0.1/rest/new/user/100 返回404
// http://127.0.0.1/rest/new/user/1 以json形式返回具体的用户信息
@RequestMapping(value = "{id}", method = RequestMethod.GET)
@ResponseBody
public ResponseEntity<User> queryUserById(@PathVariable("id") Long id) {
try {
User user = this.userService.queryUserById(id);
if (null == user) {
// 资源不存在,响应404
return ResponseEntity.status(HttpStatus.NOT_FOUND).body(null);
}
// 资源存在,响应200
// return ResponseEntity.status(HttpStatus.OK).body(user);
return ResponseEntity.ok(user);
} catch (Exception e) {
e.printStackTrace();
}
//查询失败,返回500
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
}
/**
* 新增用户
*
* @param user
* @return
*/
@RequestMapping(method = RequestMethod.POST)
public ResponseEntity<Void> saveUser(User user) {//响应的为void类型,响应可用bulid()
try {
Boolean bool = this.userService.saveUser(user);
if (bool) {
// 新增成功,响应201
return ResponseEntity.status(HttpStatus.CREATED).build();
}
} catch (Exception e) {
e.printStackTrace();
}
// 新增失败,响应500
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build();
}
/**
* 更新用户
* @param user
* @return
*/
@RequestMapping(method = RequestMethod.PUT)//默认情况下put请求无法提交表单数据,故应在web.xml中配置过滤器
public ResponseEntity<Void> updateUser(User user) {
try {
Boolean bool = this.userService.updateUser(user);
if (bool) {
// 更新成功,响应204
return ResponseEntity.status(HttpStatus.NO_CONTENT).build();
}
} catch (Exception e) {
e.printStackTrace();
}
// 新增失败,响应500
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build();
}
/**
* 删除用户
*
* @param id
* @return
*/
@RequestMapping(method = RequestMethod.DELETE)
//需要在web.xml中添加过滤器解决DELETE请求无法提交表单数据的问题
public ResponseEntity<Void> deleteUser(@RequestParam(value = "id", defaultValue = "0") Long id) {
try {
if (id.longValue() == 0) {
// 没有传递参数,响应状态码400
return ResponseEntity.status(HttpStatus.BAD_REQUEST).build();
}
Boolean bool = this.userService.deleteUser(id);
if (bool) {
// 删除成功,响应204
return ResponseEntity.status(HttpStatus.NO_CONTENT).build();
}
} catch (Exception e) {
e.printStackTrace();
}
// 删除失败,响应500
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build();
}
}`
web.xml中配置:
<!-- 解决PUT请求无法提交表单数据的问题 -->
<filter>
<filter-name>HttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HttpPutFormContentFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!--
将POST请求转化为DELETE或者是PUT
要用_method指定真正的请求方法
-->
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
推荐用书:
链接:https://pan.baidu.com/s/13zmq6zV3UUTh9SLa-JvB0A
提取码:5atm
`