七、RESTFul
1、RESTFu简介
REST:Representational State Transfer,表现层资源状态转移。
a>资源
资源是一种看待服务器的方式,即,将服务器看作是由很多离散的资源组成。每个资源是服务器上一个可命名的抽象概念。因为资源是一个抽象的概念,所以它不仅仅能代表服务器文件系统中的一个文件、数据库中的一张表等等具体的东西,可以将资源设计的要多抽象有多抽象,只要想象力允许而且客户端应用开发者能够理解。与面向对象设计类似,资源是以名词为核心来组织的,首先关注的是名词。一个资源可以由一个或多个URI来标识。URI既是资源的名称,也是资源在Web上的地址。对某个资源感兴趣的客户端应用,可以通过资源的URI与其进行交互。
b>资源的表述
资源的表述是一段对于资源在某个特定时刻的状态的描述。可以在客户端服务器端之间转移(交换)。资源的表述可以有多种格式,例如HTML/XML/JSON/纯文本/图片/视频/音频等等。资源的表述格式可以通过协商机制来确定。请求-响应方向的表述通常使用不同的格式。
c>状态转移
状态转移说的是:在客户瑞和服务器端之间转移(transfer)代表资源状态的表述。遥过转移和操作资原的表述,来间接实现操作资源的目的。
2、RESTFul的实现
具体说,就是HTTP协议里面,四个表示操作方式的动词:GET、POST、PUT、DELETE。
它们分别对应四种基本操作:GET用来获取资源、POST用来新建资源、PUT用来更新资源、DELETE用来删除资源。
REST风格提倡URL地址使用同一的风格设计,从前到后各个单词使用斜杠分开,不使用问号键值对方式携带请求参数,而是将要发送给服务器的数据作为URL地址的一部分,以保证整体风格的一致性。
操作 | 传统方式 | REST风格 |
---|---|---|
查询操作 | getUserById?id=1 | user/1-->get请求方式 |
保存操作 | saveUser | user-->post请求方式 |
删除操作 | deleteUser?id=1 | user/1-->delete请求方式 |
更新操作 | updateUser | user-->put请求方式 |
在resources根目录下的springMVC中,配置主控制器,确保能够跳转到主页面test_rest
<mvc:view-controller path="/test_rest" view-name="test_rest" /> <mvc:annotation-driven />
2.1、查询操作GET
2.1.1、查询所有用户信息
html中的设置
<a th:href="@{/user}">查询所有用户信息</a><br>
控制器设置
//使用GET查询所有用户信息 @RequestMapping(value = "/user", method = RequestMethod.GET) public String getAllUser(){ System.out.println("查询所有用户信息"); return "success"; }
2.1.2、根据id查询用户信息
html中的设置
<!--/user/1等同于/user?id=1,表示为id为1的用户信息--> <a th:href="@{/user/1}">根据id查询用户信息</a><br>
控制器设置
//使用GET查询指定id的用户信息,用/user/{id}来表示指定id的用户 @RequestMapping(value = "/user/{id}", method = RequestMethod.GET) public String getUserById(){ System.out.println("根据id查询用户信息"); return "success"; }
2.2、添加操作POST
html中的设置
<form th:action="@{/user}" method="post"> 用户名:<input type="text" name="username"><br> 密码:<input type="password" name="password"><br> <input type="submit" value="添加"><br> </form>
控制器设置
//使用POST添加用户信息 @RequestMapping(value = "/user", method = RequestMethod.POST) public String insertUser(String username, String password){ System.out.println("添加用户信息:"+username+","+password); return "success"; }
2.3、修改/更新操作PUT
在web.xml文件中配置HiddenHttpMethodFilter过滤器,以适配浏览器发送put和delete请求
<!--配置HiddenHttpMethodFilter过滤器,以适配浏览器发送put和delete请求--> <filter> <filter-name>HiddenHttpMethodFilter</filter-name> <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class> </filter> <!--设置HiddenHttpMethodFilter过滤器的映射--> <filter-mapping> <filter-name>HiddenHttpMethodFilter</filter-name> <!--使用'/*'表示对所有请求进行处理--> <url-pattern>/*</url-pattern> </filter-mapping>
html中的设置
<!--使用PUT操作时,method必须为post--> <form th:action="@{/user}" method="post"> <!--使用hidden是为了不让用户看见此条操作, 此时的value值才是真正的操作方式(PUT也可以是小写put)--> <input type="hidden" name="_method" value="PUT"> 用户名:<input type="text" name="username"><br> 密码:<input type="password" name="password"><br> <input type="submit" value="修改"><br> </form>
控制器设置
//使用PUT修改/更新用户信息 @RequestMapping(value = "/user", method = RequestMethod.PUT) public String updateUser(String username, String password){ System.out.println("修改用户信息:"+username+","+password); return "success"; }
2.4、删除操作DELETE
详见第八章
3、HiddenHttpMethodFilter
由于浏览器只支持发送get和post方式的请求,那么该如何发送put和delete请求呢?
SpringMVC提供了HiddenHttpMethodFilter帮助我们将POST请求转换为DELETE或PUT请求
HiddenHttpMethodFilter处理put和delete请求的条件:
a>当前请求的请求方式必须为post
b>当前请求必须传输请求参数method
注:在配置HiddenHttpMethodFilter过滤器和CharacterEncodingFilter编码过滤器时,要先配置CharacterEncodingFilter编码过滤器,然后再配置HiddenHttpMethodFilter过滤器。因为如果先配置HiddenHttpMethodFilter过滤器,再配置CharacterEncodingFilter编码过滤器的话,可能会出现乱码问题。(因为设置编码之前不能获取任何请求参数,不然编码设置就无效了)
在web.xml文件中配置HiddenHttpMethodFilter过滤器,以适配浏览器发送put和delete请求
<!--配置HiddenHttpMethodFilter过滤器,以适配浏览器发送put和delete请求--> <filter> <filter-name>HiddenHttpMethodFilter</filter-name> <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class> </filter> <!--设置HiddenHttpMethodFilter过滤器的映射--> <filter-mapping> <filter-name>HiddenHttpMethodFilter</filter-name> <!--使用'/*'表示对所有请求进行处理--> <url-pattern>/*</url-pattern> </filter-mapping>