一:REST简单介绍

REST 2000 年由 Roy Fielding 在博士论文中提出,他是 HTTP 规范 1.0 和 1.1 版的首席作者之中的一个。

REST 中最重要的概念是资源(resources) ,使用全球 ID(通常使用 URI)标识。client应用程序使用 HTTP 方法(GET/ POST/ PUT/ DELETE )操作资源或资源集。

RESTful Web 服务是使用 HTTP 和 REST 原理实现的 Web 服务。通常。RESTful Web 服务应该定义下面方面:

Web 服务的基/根 URI。比方 http://host/<appcontext>/resources。

支持 MIME 类型的响应数据,包含 JSON/XML/ATOM 等等。

服务支持的操作集合(比如 POST、GET、PUT 或  DELETE)

例如以下表所看到的:

方法/资源 资源集合。 URI 如:

http://host/<appctx>/resources   成员资源,URI 如:

http://host/<appctx>/resources/1234 

GET 列出资源集合的全部成员检索标识为 1234 的资源的表示形式。

PUT 使用一个集合更新(替换)还有一个集合。

更新标记为 1234 的数字资源。

POST 在集合中创建数字资源在以下创建一个子资源。

DELETE 删除整个资源集合。删除标记为 1234 的数字资源。

二:REST 与 JSR(jersey)

JSR-311  Java API for RESTful Web Services (JAX-RS) 1.0 and 1.1

JAX-RS是将在JavaEE 6引起的一种新技术。 JAX-RS即Java API for RESTful Web Services。是一个Java 编程语言的应用程序接口 ,支持依照表述性状态转移(REST)架构风格创建Web服务。

JAX-RS使用了Java SE5引入的Java标注来简化Web服务的client和服务端 的开发和部署。包含:

 

@Path。标注资源类或者方法的相对路径   

@GET。@PUT。@POST。@DELETE,标注方法是HTTP请求的类型。

  

@Produces,标注返回的MIME媒体类型   

@Consumes。标注可接受请求的MIME媒体类型

@PathParam。@QueryParam。@HeaderParam。@CookieParam,@MatrixParam。@FormParam,分别标注方法的參数来自于HTTP请求的不同位置。比如@PathParam来自于URL的路径,@QueryParam来自于URL的查询參数,@HeaderParam来自于HTTP请求的头信息,@CookieParam来自于HTTP请求的Cookie,@FormParam来自于HTTP请求的post的form格式。



 

三:Jersey jar包简单介绍

 

Jersey 是 JAX-RS 的參考实现,它包括三个主要部分。

核心server(Core Server):通过提供 JSR 311 中标准化的凝视和 API 标准化,您能够用直观的方式开发 RESTful Web 服务。

核心client(Core Client):Jersey client API 帮助您与 REST 服务轻松通信。

集成(Integration):Jersey 还提供能够轻松集成 Spring、Guice、Apache Abdera 的库。

注意:jar包下载 jersey jar包下载(须要积分的哦,辛苦整理的)

四:自己创建一个rest资源

用微账户的查询接口作一个样例

 

Java代码  

@Path("/accinfo")// prgramname/rest/下的路径 

public class AccountInfoResource {  

    @Context  

    UriInfo uriInfo;  

    @Context  

    Request request;  

      

    /* 

     * Get all accounts info 

     */  

    @GET  

    @Path("all")// accinfo的子路径,也是外界调用的路径  

    @Produces(MediaType.APPLICATION_XML)  

    public List<AccountInfo> getAllaccounts() throws UnsupportedEncodingException{  

        List<AccountInfo> retList = new ArrayList<AccountInfo>();  

        EntityManager em = EntityManagerHelper.getEntityManager();  

        MaaccdtapManager mm = new MaaccdtapManager(em);  

        List<Maaccdtap> mList = mm.getAllAccounts();  

        AccountInfo ai = null;  

        AccountAdapter ad = new AccountAdapter();  

          

        for(Maaccdtap m : mList){             

            ai = ad.getAccountInfo(m);  

            retList.add(ai);  

        }  

          

        EntityManagerHelper.closeEntityManager();  

          

        return retList;  

    }     

      

    /* 

     * Get account info by mbrseq id   @GET方式

     */  

    @GET  

    @Path("{accountid}")// accinfo的子路径,也是外界调用的路径,既作为accountid又作为參数

    @Produces(MediaType.APPLICATION_JSON)  

    public AccountInfo getAccountBySid(@PathParam("accountid") String accountid)   

            throws UnsupportedEncodingException{  

          

        EntityManager em = EntityManagerHelper.getEntityManager();  

        MaaccdtapManager mm = new MaaccdtapManager(em);  

        Maaccdtap mp = mm.getAccountBySid(accountid);  

        AccountInfo ai = null;  

          

        if(null != mp){  

            AccountAdapter ad = new AccountAdapter();  

            ai = ad.getAccountInfo(mp);  

        }  

          

        EntityManagerHelper.closeEntityManager();  

          

        return ai;  

    }  

/* 

     * Get account info by mbrseq id and name   @POST方式

     */

    @POST  

    @Path("change")  

    @Consumes(MediaType.APPLICATION_FORM_URLENCODED)  

    public void responseAccountChange(  

            @FormParam(value = "id") String id,  

            @FormParam(value = "name") String name,  

            @Context HttpServletResponse servletResponse) throws IOException{  

          

      

    System.out.println("Reveiced change parameters from UI:");  

    System.out.println("ID is " + id);  

    System.out.println("Name is " + name);  

      

    URI newUrl = uriInfo.getAbsolutePathBuilder().path(id).build();  

    System.out.println(newUrl.toString());  

      

    Response.created(newUrl).build();  

    //ServletOutputStream os = servletResponse.getOutputStream();  

    PrintWriter pw = servletResponse.getWriter();  

    pw.write("The change request has been sent to backend and id is " + id);  

    pw.flush();  

    }

}

測试:

用以下的URL就可以訪问对应的账户信息(即Resource)

 http://ip:port/MicroAcc/rest/accinfo/{mbrseq}      

   http://ip:port/MicroAcc/rest/accinfo/al l

@Produces(MediaType.APPLICATION_JSON)则能够产生Json的输出。

@POST凝视会接收http post request, 将Web表单里的action指向POST的地址。比如:

http://ip:port/MicroAcc/rest/accinfo/change 被凝视的方法就可以收到表单的内容。

五:配置信息 Jersey配置:

Jersey 1.2 以后的版本号和一些Update的维护版本号仅仅支持Java SE 6, 在选择版本号和对应server时须要注意。、

从 Jersey 开发包中下面的库为必须:

核心服务器:jersey-core.jar。jersey-server.jar。jsr311-api.jar。asm.jar

核心客户端:(用于測试)jersey-client.jar

JAXB 支持:(在高级例子中使用)jaxb-impl.jar,jaxb-api.jar。activation.jar,stax-api.jar,wstx-asl.jar

JSON 支持:(在高级例子中使用)jersey-json.jar

(JSON是类似于xml的一种通用。在不同project/语言/平台间传递数据的格式,其比xml更精炼更优良,差点儿全部的语言和框架已经支持了,传递过来的数据再用JSON解码就可以,就像c++struct结构体一样,直接json.xxx就可以訪问。多层的话就json.xxx.xxx)

您须要将全部的 REST 请求发送到 Jersey 容器 —— 在应用程序的 web.xml 文件里定义 servlet 调度程序(參见清单 1)。

除了声明 Jersey servlet 外,它还定义一个初始化參数,指示包括资源的 Java 包。

Web.xml: Xml代码

<servlet>  

    <servlet-name>Jersey REST Service</servlet-name>  

    <servlet-class>  

      com.sun.jersey.spi.container.servlet.ServletContainer  

    </servlet-class>  

    <init-param>  

      <param-name>com.sun.jersey.config.property.packages</param-name>  

      <param-value>sh.cmbchina.pension.resources</param-value>  

    </init-param>  

    <load-on-startup>1</load-on-startup>  

</servlet>  

<servlet-mapping>  

    <servlet-name>Jersey REST Service</servlet-name>  

    <url-pattern>/rest/*</url-pattern>

</servlet-mapping>

 这样,全部在包sh.cmbchina.pension.resources以下的resource类都会被注冊为Restful url的响应处理类。



Restful 和 Jersey介绍(Web Service )的更多相关文章

  1. Restful 架构方式的 web service

    现在公司项目用的apache wink 搭建的web service ,感觉挺好用的.顺便学习一个这种架构方式 . 个人理解apache 实现Restful 架构方式技术有两种,如果有其他新的知识或不 ...

  2. day01(RESTful Web Service、SVN)

    今日大纲 搭建SSM环境 基于SSM环境实现用户管理系统 学习RESTful Web Service 学习SVN 统一开发环境 JDK1.7 32? 64? -- 64 Eclipse 使用4.4.1 ...

  3. Web Service概念梳理

    计算机技术难理解的很多,Web Service 对我来说就是一个很难理解的概念:为了弄清它到底是什么,我花费了两周的时间,总算有了一些收获,参考了不少网上的资料,但有些概念说法不一.我以w3c和 一些 ...

  4. WCF分布式开发必备知识(3):Web Service 使用

    参考地址:http://www.cnblogs.com/zhili/p/WebService.html 一.WebService概述 SOAP.WSDL.UDDISOAP(Simple Object ...

  5. 微软BI 之SSIS 系列 - 在 SSIS 中使用 Web Service 以及 XML 解析

    开篇介绍 Web Service 的用途非常广几乎无处不在,像各大门户网站上的天气预报使用到的第三方 Web Service API,像手机客户端和服务器端的交互等都可以通过事先设计好的 Web Se ...

  6. 用Jersey为Android客户端开发Restful Web Service

    平时在做Android客户端的时候经常要与服务器之间通信,客户端通过服务端提供的接口获取数据,然后再展示在客户端的界面上,作为Android开发者,我们平时更多的是关注客户端的开发,而对服务端开发的关 ...

  7. 【转】 Build a RESTful Web service using Jersey and Apache Tomcat 2009

    Build a RESTful Web service using Jersey and Apache Tomcat Yi Ming Huang with Dong Fei Wu, Qing GuoP ...

  8. Jersey(1.19.1) - Deploying a RESTful Web Service

    JAX-RS provides a deployment agnostic abstract class Application for declaring root resource and pro ...

  9. 使用Java创建RESTful Web Service

    REST是REpresentational State Transfer的缩写(一般中文翻译为表述性状态转移).2000年Roy Fielding博士在他的博士论文“Architectural Sty ...

随机推荐

  1. 基于visual Studio2013解决C语言竞赛题之0303最大数

     题目 解决代码及点评 这道题考察对条件分支和赋值的灵活应用 正常思维 如果 a>b and a>c 那么a最大 如果b>c and b>a 那么b最大 如果c>a ...

  2. extjs 优化小建议

    1 原文信息 原文标题: Sencha Con 2013: Ext JS Performance tips 原文地址: [http://edspencer.net/2013/07/19/sencha- ...

  3. Swap file ".Podfile.swp" already exists!

    解决Swap file ".ceshi.c.swp" already exists!问题 关于swp文件:使用vi,经常可以看到swp这个文件,那这个文件是怎么产生的呢,当你打开一 ...

  4. 浅谈独立使用NDK编译库文件(Android)

    阅读前准备 这是一篇相对入门的文章.文中会涉及到少许NDK的知识,但个人认为对初学者来说都相对比较实用,因为都是在平时项目中遇到的(目前自己也是初学者).一些其他高深的技术不再本文探讨范围之内(因为我 ...

  5. eclipse svn2.0.0插件 手动安装方法

    org.tigris.subversion.javahl.ClientException: Unsupported working copy formatsvn: This client is too ...

  6. X-UA-Compatible IE 浏览器默认文档模式设置

    制作网页的时候,IE8浏览器浏览页面的时候,有时候文档模式默认是IE7,导致IE8兼容性不是非常好.出现IE7应该出现的模式. 解决的方法例如以下: 在X-UA-Compatible中可用的方法有: ...

  7. HDU 3060 多边形面积并

    Area2 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  8. 在树莓派上设置无线静态IP

    修改文件: /etc/network/interfaces,命令如下 sudo nano /etc/network/interfaces 将最后一句iface default inet dhcp,替换 ...

  9. mvc中的几个数据传递

    1.ViewData对象 ViewBagData是一种字典集合数据同时属于视图基类和控制器基类的属性. 实例: //控制器 public class HomeController:Controller ...

  10. jquey的 ajax请求的几种方式

    在jquery中,提供了集中方法来进行ajax操作 一.$.get(url,[data],[callback]) 向服务器发起get操作. 说明:url为请求地址,data为请求数据的列表(json对 ...