RESTful支持

一、介绍

RESTful架构,就是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。

RESTful(即Representational State Transfer的缩写)其实是一个开发理念,是对http的很好的诠释。戳我详请

1. 对url进行规范,写RESTful格式的url

非REST的url:http://...../queryItems.action?id=001&type=T01
REST的url风格:http://..../items/001

2. http的方法规范

  • 不管是删除、添加、更新,等等。使用url是一致的,如果进行删除,需要设置http的方法为delete,其他同理。
  • 后台controller方法:判断http方法,如果是delete执行删除,如果是post执行添加。

3. 对http的contentType规范
请求时指定contentType,要json数据,设置成json格式的type,要key/value 数据设置成key/value的格式type。

二、案例

2.1 需求

查询商品信息,返回json数据。

2.2 controller

定义方法,进行url映射使用REST风格的url,将查询商品信息的id传入controller。
输出json使用@ResponseBody将java对象输出json。

//查询商品信息,输出json
    ///itemsView/{id}里边的{id}表示占位符,通过@PathVariable获取占位符中的参数,
    //如果占位符中的名称和形参名一致,在@PathVariable可以不指定名称
    @RequestMapping("/itemsView/{id}")
    public @ResponseBody
    ItemsCustom itemsView(@PathVariable("id") Integer id) throws Exception {

        //调用service查询商品信息
        ItemsCustom itemsCustom = itemsService.findItemsById(id);
        return itemsCustom;
    }

@RequestMapping(value="/ itemsView/{id}"):{×××}占位符,请求的URL可以是/viewItems/1/viewItems/2,通过在方法中使用@PathVariable获取{×××}中的×××变量。

@PathVariable用于将请求URL中的模板变量映射到功能处理方法的参数上。如果RequestMapping中表示为/ itemsView /{id},id和形参名称一致,@PathVariable不用指定名称。

REST方法的前端控制器配置,url-pattern跟前面的配置不同。


    
        springmvc_rest
        org.springframework.web.servlet.DispatcherServlet
        
        
            contextConfigLocation
            classpath:spring/springmvc.xml
        
    

    
        springmvc_rest
        /
    

测试:

结果

三、对静态资源的解析

配置前端控制器的url-parttern中指定/,对静态资源的解析出现问题:

RESTful支持_第1张图片
1.png

在springmvc.xml中添加静态资源解析方法。

    
    
    
    

上篇:JSON数据交互
下篇:拦截器
源代码:https://github.com/yvettee36/SpringMVC_mybatis

你可能感兴趣的:(RESTful支持)