使用rest风格 url(保护key值)
REST: 即 Representational State Transfer。 (资源)表现层状态转化。 是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、 扩展方便,所以正得到越来越多网站的采用。
资源(Resources) : 网络上的一个实体,或者说是网络上的一个具体信息。它可以是一段文本、一张图片、一首歌曲、一种服务, 总之就是一个具体的存在。可以用一个URI(统一资源定位符)指向它, 每种资源对应一个特定的 URI 。 要获取这个资源, 访问它的URI就可以, 因此 URI 即为每一个资源的独一无二的识别符。
表现层(Representation) : 把资源具体呈现出来的形式,叫做它的表现层(Representation) 。比如,文本可以用 txt 格式表现,也可以用 HTML 格式、 XML 格式、 JSON 格式表现,甚至可以采用二进制格式。
状态转化(State Transfer) : 每发出一个请求, 就代表了客户 端和服务器的一次交互过程。 HTTP协议,是一个无状态协议,即所有的状态都保存在服务器端。因此, 如果客户端想要操作服务器,必须通过某种手段, 让服务器端发生“
状态转化”(State Transfer)。而这种转化是建立在表现层之上的,所以就是 “表现层状态转化”。 具体说, 就是 HTTP 协议里面,四个表示操作方式的动词: GET、 POST、 PUT、 DELETE。它们分别对应四种基本操作: GET 用来获取资源, POST 用来新建资源, PUT 用来更新资源, DELETE 用来删除资源。
但是要用spring实现四个方法需要一个过滤器:
HiddenHttpMethodFilter: 浏览器 form 表单只支持 GET与 POST 请求,而DELETE、 PUT 等 method 并不支持, Spring3.0 添加了一个过滤器,可以将这些请求转换为标准的 http 方法,使得支持 GET、 POST、 PUT 与DELETE 请求。
带占位符的 URL 是 Spring3.0 新增的功能, 该功能在SpringMVC 向 REST 目 标挺进发展过程中具有里程碑的意义。
通过 @PathVariable 可以将 URL 中占位符参数绑定到控制器处理方法的入参中: URL 中的 {xxx} 占位符可以通过@PathVariable("xxx") 绑定到操作方法的入参中。
该过滤器为HiddenHttpMethodFilter。HiddenHttpMethodFilter的父类是OncePerRequestFilter,它继承了父类的doFilterInternal方法,工作原理是将jsp页面的form表单的method属性值在doFilterInternal方法中转化为标准的Http方法,即GET,、POST、 HEAD、OPTIONS、PUT、DELETE、TRACE,然后到Controller中找到对应的方法。例如,在使用注解时我们可能会在Controller中用于@RequestMapping(value = "save", method = RequestMethod.PUT),所以如果你的表单中使用的是 ,那么这个表单会被提交到标了Method="PUT"的方法中。需要注意的是,由于doFilterInternal方法只对method为post的表单进行过滤。
HiddenHttpMethodFilter必须作用于dispatcher前,所以在web.xml中配置HiddenHttpMethodFilter时放在最上面。
web.xml配置文件(请求处理)
1.
2. filter>
3. <</span>filter-name>hiddenHttpMethodFilter</</span>filter-name>
4. <</span>filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</</span>filter-class>
5. filter>
6.
7. filter-mapping>
8. <</span>filter-name>hiddenHttpMethodFilter</</span>filter-name>
9. <</span>url-pattern>/*</</span>url-pattern>
10. filter-mapping>
11.
controller层
[java]
view plain
copy
1. @Controller
2. public class BookContorller {
3. @Autowired
4. private BookService bookService;
5.
6. @ModelAttribute
7. public Book loadBook(@RequestParam(name="bookId",required=false) Integer bookId,ModelMap model){
8. if(bookId!=null){
9. Book b=bookService.loadById(bookId);
10. "loadUpdate1",b);
11. return b;
12. else{
13. return new Book();
14. }
15. }
16. @RequestMapping("/loadAll")
17. public String loadAll(ModelMap model){
18. List books=bookService.loadAll();
19. "books",books);
20. return "index";
21. }
22.
23. @RequestMapping("/save.html")
24. public String save(){
25. return "save";
26. }
27.
28. @RequestMapping(value={"/saveHander"},method=RequestMethod.POST)
29. public String saveHander(Book book){
30. boolean bool=bookService.save(book);
31. return bool?"redirect:/loadAll":"error";
32. }
33.
34. @RequestMapping(value={"/deleteHander/{bookId}"},method=RequestMethod.DELETE)
35. public String deleteHander(@PathVariable("bookId") int bookId){
36. boolean bool=bookService.delete(bookId);
37. return bool?"redirect:/loadAll":"error";
38. }
39. @RequestMapping(value={"/loadUpdate/{bookId}"},method=RequestMethod.GET)
40. public String loadBookById(@PathVariable("bookId") int bookId,ModelMap model){
41. Book book=bookService.loadById(bookId);
42. "loadUpdate", book);
43. return "update";
44. }
45.
46. @RequestMapping(value={"/update"},method=RequestMethod.PUT)
47. public String updateHander(@ModelAttribute("loadUpdate1") Book book){
48. bookService.update(book);
49. return "redirect:/loadAll";
50. }