SSM整合之RESTful支持

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/fjnmbb12/article/details/73928791

什么是RESTful?

RESTful架构,就是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用。
RESTful(即 Representational State Transfer的缩写)是一种开发理念,是对于http的很好的诠释。


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

非REST的url: http://.../queryItems.action?id=001&type=T01
REST的url风格: http://..../items/001
特点:url简洁,将参数通过url传入服务端进行处理

对http的方法进行规范
不管是删除、添加、更新,使用的url是一致的,若要进行删除,需要设置http的方法为delete,put,post等

后台Controller方法:判断http方法,若为delete则执行删除,post执行添加等操作


对http的contentType进行规范
请求时指定contentType,要json数据,设置成json格式的type等

使用RESTful的例子

需求

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

controller

定义一个方法:使用url模板映射,进行url映射, 使用REST风格的url,能将查询商品信息的id传入controller
输出json,使用@ResponseBody将java对象输出为json至前端页面
    //查询商品信息 ,输出json
    //RequestMapping里的id标识将这个位置的参数传到@PathVariable指定的名称之中
    @RequestMapping("/itemsView/{id}")
    public @ResponseBody ItemsCustom itemsView(@PathVariable("id") Integer id) throws Exception{
        //调用service查询商品信息
        ItemsCustom itemsCustom = itemsService.findItemsById(id);
        //返回对象
        return itemsCustom;
    }

前端控制器

    <!-- SrpingMVC前端控制器 -->
    <servlet>
        <servlet-name>springmvc_restful</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--
        contextConfigLocation配置springmvc加载的配置文件(需要配置处理器映射器、适配器等)
        如果不配置contextConfigLocation , 摸人家在的是/WEB-INFO/servlet名称-servlet。xml(springmvc-servlet.xml)
         -->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:spring/springmvc.xml</param-value>
        </init-param>
    </servlet>
    <servlet-mapping>
        <servlet-name>springmvc_restful</servlet-name>
        <!--
        第一种配置方式: *.action 访问以 .action结尾的 由DispatcherServlet进行解析
        第二种配置方式:/ , 所有访问的地址 都由DispatcherServlet进行解析,若有图片或者其他的静态文件的解析,需要配置不让DispatcherServlet进行解析
        使用这种方式可以实现RESTful风格的url
        第三种配置模式: /* , 这样配置不对,使用该配置,最终要转发到一个JSP页面时,仍然会由dispaerServlet解析JSP,不能根据jsp页面找到handler,会报错的
        -->
        <url-pattern>/</url-pattern>
    </servlet-mapping>


注意,在测试时,我遇到了一个问题,报错 java.lang.IllegalArgumentException: No converter found for return value of type 这是因为springmvc默认没有配置java对象转换成json格式数据的转换器
需要我们手动在springmvc.xml配置文件中添加( 由于此处没有用到maven搭建项目,jackson依赖无法构建,故该问题无法解决

最终效果






对静态资源的解析

配置前端控制器的url-pattern中,指定为 / ,需要在springmvc.xml中添加静态资源解析方法

    <!--
    静态资源的解析
    包括js,css,img等
    -->
    <mvc:resources location="/js/"  mapping="/js/**" />

添加完成后,即可访问所定义的静态资源:




猜你喜欢

转载自blog.csdn.net/fjnmbb12/article/details/73928791
今日推荐