`
747017186
  • 浏览: 331409 次
社区版块
存档分类
最新评论

restful架构详解

 
阅读更多

最近做项目使用到了restful架构来实现一些对外开放的接口,其实这个restful架构也是webservice的一种,只不过这个更加轻量级,它是基于http协议的。下面来看例子:

1.所需资源包

一下4个包是最简单版本的,你如果需要和其他框架进行结合必须再引入包,这里我就不再引进了。

javaee-api-7.0.jar

jersey-bundle-1.19.jar

jersey-core-1.19.jar

jersey-server-1.19.jar

2.编写接口实现

/** 
* RESTful WebService入门 
* @author leizhimin 2009-11-18 16:42:43 
*/ 
package restful; 

import javax.ws.rs.GET; 
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;

//指定URI 
@Path("/helloworld") 
public class HelloWorld { 
        //处理HTTP的GET请求 
        @GET 
        // 处理请求反馈的内容格式为"text/plain" 
        @Produces(MediaType.TEXT_PLAIN) 
        public String getClichedMessage() { 
                return "Hello World!"; 
        } 
        
        @GET
        @Path("/{param}")//指定url后面直接添加参数值,例如:http://localhost:8088/TestRestFul/helloworld/参数值
        @Produces("text/plain;charset=UTF-8") 
        public String getClichedMessage(@PathParam("param") String username) {//@PathParam("param")直接获取参数值username
        	return "Hello " + username;
        }
}

 3.restful服务发布方式

 restful服务发布方式有两种:

3.1主方法发布

package restful;

import java.io.IOException;
import com.sun.jersey.api.container.httpserver.HttpServerFactory;
import com.sun.net.httpserver.HttpServer;

public class TestMain {
	public static void main(String[] args) throws IOException {
    	System.out.println("44444444");
        //创建RESTful WebService服务 
        HttpServer server = HttpServerFactory.create("http://localhost:9999/"); 
        //启动服务,这会导致新开一个线程 
        server.start(); 
        //输出服务的一些提示信息到控制台 
        System.out.println("RESTful WebService服务已经启动"); 
        System.out.println("服务访问地址: http://localhost:9999/helloworld"); 
    } 
}

 3.2服务器启动发布

这里讲解的是跟随tomcat启动的时候发布

配置web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
  <display-name>TestRestFul</display-name>
  
  <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>restful</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>
  
  <welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
</web-app>

 

这里之讲解一点要特殊注意:

<init-param>  	  
 <param-name>com.sun.jersey.config.property.packages</param-name>  
	   <param-value>restful</param-value><!-- 处理类的包名,不是包名.类名,切记 -->  
	</init-param> 

如果配置错误了,服务器就会报异常:The ResourceConfig instance does not contain any root resource classes.  

 

4.测试

4.1主方法启动测试

直接在浏览器输入:

http://localhost:8088/helloworld    //无参数测试

http://localhost:8088/helloworld/您好    //有参数测试

 

4.2服务器启动测试

直接在浏览器输入:

http://localhost:8088/rest/helloworld    //无参数测试


 ---------------------------------------------------------------------------------------------

http://localhost:8088/rest/helloworld/您好    //有参数测试

 

 本来转自:http://www.open-open.com/lib/view/open1431569985232.html

在Eclipse中使用Jersey和Tomcat构建RESTful WebService及其调用

在Eclipse中使用Jersey和Tomcat构建RESTful WebService及其调用

RESTful Web 服务简介

REST 在 2000 年由 Roy Fielding 在博士论文中提出,他是 HTTP 规范 1.0 和 1.1 版

的首席作者之一。

REST 中最重要的概念是资源(resources),使用全球 ID(通常使用 URI)标识。

客户端应用程序使用 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)。

表 1 演示了典型 RESTful Web 服务中使用的资源 URI 和 HTTP 方法。

 1. RESTful Web 服务示例

方法/资源

资源集合, URI 如:
http://host/<appctx>/resources

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

/resources/1234

GET

列出资源集合的所有成员。

检索标识为 1234 的

资源的表示形式。

PUT

使用一个集合更新(替换)另一个集合。

更新标记为 1234 的

数字资源。

POST

在集合中创建数字资源,其 ID 是自动分配的。

在下面创建一个子

资源。

DELETE

删除整个资源集合。

删除标记为 1234 的

数字资源。


JSR 311 (JAX-RS)和 Jersey

JSR 311 或 JAX-RS(用于 RESTful Web Services 的 Java API)的提议开始于 2007 年,1.0 版本到 2008 年 10 月定稿。目前,JSR 311 版本 1.1 还处于草案阶段。该 JSR 的目的是提供一组 API 以简化 REST 样式的 Web 服务的开发。

在 JAX-RS 规范之前,已经有 Restlet 和 RestEasy 之类的框架,可以帮助您实现

RESTful Web 服务,但是它们不够直观。Jersey 是 JAX-RS 的参考实现,它包含三个主要部分。

  • 核心服务器(Core Server):通过提供 JSR 311 中标准化的注释和 API 标准化,您可以用直观的方式开发 RESTful Web 服务。

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

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

 

构建 RESTful Web 服

我将从可以集成到 Tomcat 的 “hello world”用程序开始。该应用程序将带领您完成境的程,并涉及 Jersey 和 JAX-RS 的基

然后,我将介更加复用程序,深入探 JAX-RS 的本和特性,比如多个 MIME 型表示形式支持、JAXB 支持等。

 

Hello World:第一个 Jersey Web 项目

要设置开发环境:

  • IDE:Eclipse IDE for JEE (v3.4+) 或 IBM Rational Application Developer 7.5

  • Java SE5 或更高版本

  • Web 容器:Apache Tomcat 6.0(Jetty 和其他也可以)

  • Jersey 库:Jersey 1.0.3 归档,包含所有必需的库

 

置 Jersey 的环境

首先,为 Eclipse 上的 Tomcat 6.0 创建服务器运行时。这是用于 RESTful Web 应用程序的 Web 容器。然后创建一个名为 “Jersey” 应用程序,并将目标运行时指定为 Tomcat 6.0。

最后,从 Jersey 开发包中将以下库复制到 WEB-INF 下的库目录:

  • 核心服务器:jersey-core.jar,jersey-server.jar,jsr311-api.jar,asm.jar, jersey-bundle.jar

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

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

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

Jersey库文件的下载地址:http://jersey.java.net/nonav/documentation/latest/chapter_deps.html

需要下载的库文件如下:

activation-1.1.1.jar

asm-3.3.1.jar

jackson-core-asl-1.9.2.jar

jackson-jaxrs-1.9.2.jar

jackson-mapper-asl-1.9.2.jar

jaxb-api-2.2.4.jar

jaxb-impl-2.2.4-1.jar

jersey-bundle-1.12.jar

jersey-client-1.12.jar

jersey-core-1.12.jar

jersey-json-1.12.jar

jersey-server-1.12.jar

jettison-1.1.jar

stax-api-1.0-2.jar

 

发 REST 服务

现在,您已经设置好了开发第一个 REST 服务的环境,该服务对客户端发出 “Hello”。

要做到这一点,您需要将所有的 REST 请求发送到 Jersey 容器 —— 在应用程序的 web.xml 文件中定义 servlet 调度程序(参见清单 1)。除了声明 Jersey servlet 外,它还定义一个初始化参数,指示包含资源的 Java 包。

 

单 1. 在 web.xml 文件中定义 Jersey servlet 调度程度

<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>sample.hello.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>

现在您将编写一个名为 HelloResource 的资源,它接受 HTTP GET 并响应 “Hello Jersey”。


单 2. sample.hello.resources 包中的 HelloResource

@Path("/hello")  
public class HelloResource {  
    @GET  
    @Produces(MediaType.TEXT_PLAIN)  
    public String sayHello() {  
        return "Hello Jersey";  
    }  
}

该代码中有几个地方需要强调:

  • 资源类(Resource Class):注意,资源类是一个简单的 Java 对象 (POJO),可以实现任何接口。这增加了许多好处,比如可重用性和简单。

  • 注释(Annotation):在 javax.ws.rs.* 中定义,是 JAX-RS (JSR 311) 规范的一部分。

  • @Path:定义资源基 URI。由上下文根和主机名组成,资源标识符类似于 http://localhost:8080/Jersey/rest/hello。

  • @GET:这意味着以下方法可以响应 HTTP GET 方法。

  • @Produces:以纯文本方式定义响应内容 MIME 类型。

部署到Tomcat容器

在Jersey项目上点击右键,Export---WAR file,生成Jersey.war文件,复制该文件到Tomcat安装目录下的webapps目录下,重新启动tomcat,Jersey.war文件将被自动解压。

 

 

测试 Hello 应用程序

要测试应用程序,可以打开您的浏览器并输入 URL http://<host>:<port>/<appctx>/rest/hello。您将看到响应 “Hello Jersey”。这非常简单,使用注释处理请求、响应和方法。

以下部分将涉及 JAX-RS 规范的必要部分,使用 Contacts 示例应用程序中的代码片段进行介绍。您可以在源代码包中找到这个高级样例的所有代码。

 

源是成 RESTful Web 服的关部分。您可以使用 HTTP 方法(如GET、POST、PUT 和DELETE)操作源。用程序中的所有内容都是源:工、系人、组织等。在 JAX-RX 中,源通 POJO实现,使用@Path  注释组成其标识符源可以有子源。在种情况下,父源是源集合,子源是成员资源。

例 Contacts用程序中,您将操作个人系人和系人集合。ContactsResource 是 /contacts URI 成的集合源,ContactResource 是 /contacts/{contactId} URI成的成员资源。下划线 JavaBean 是一个简单的 Contact,使用 id、名称和地址作字段。参 3 和清 4 了解情。

单 3. ContactsResource

@Path("/contacts")  
public class ContactsResource {  
    @Context  
    UriInfo uriInfo;  
    @Context  
    Request request;  
  
    @GET  
    @Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})  
    public List<Contact> getContacts() {  
        List<Contact> contacts = >new ArrayList<Contact>();  
        contacts.addAll( ContactStore.getStore().values() );  
        return contacts;  
    }  
  
@Path("{contact}")  
    public ContactResource getContact(  
            @PathParam("contact") String contact) {  
        return new ContactResource(uriInfo, request, contact);  
    }  
}

有几个有趣的地方需要注意。

  • @Context: 使用该注释注入上下文对象,比如 Request、Response、UriInfo、ServletContext 等。

  • @Path("{contact}"):这是 @Path 注释,与根路径 “/contacts” 结合形成子资源的 URI。

  • @PathParam("contact"):该注释将参数注入方法参数的路径,在本例中就是联系人 id。其他可用的注释有 @FormParam、@QueryParam 等。

  • @Produces:响应支持多个 MIME 类型。在本例和上一个示例中,APPLICATION/XML 将是默认的 MIME 类型。

您也许还注意到了,GET 方法返回定制 Java 对象而不是 String(纯文本),正如上一个 Hello World 示例所示。 JAX-RS 规范要求实现支持多个表示形式类型,比如 InputStream、byte[]、JAXB 元素、JAXB 元素集合等等,以及将其序列化为 XML、JSON 或纯文本作为响应的能力。下文我将提供更多有关表示形式技术的信息,尤其是 JAXB 元素表示形式。


单 4. ContactResource

public class ContactResource {  
    @Context  
    UriInfo uriInfo;  
    @Context  
    Request request;  
    String contact;  
      
    public ContactResource(UriInfo uriInfo, Request request,   
            String contact) {  
        this.uriInfo = uriInfo;  
        this.request = request;  
        this.contact = contact;  
    }  
      
    @GET  
    @Produces({MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON})  
    public Contact getContact() {  
        Contact cont = ContactStore.getStore().get(contact);  
        if(cont==null)  
            throw new NotFoundException("No such Contact.");  
        return cont;  
    }  
}

ContactResource 的代码简单明了。注意以下内容:

  • Representation Type Contact:Contact 是一个简单的 JavaBean,由 @XmlRootElement 注释,这使它可以表示为 XML 或 JSON。

  • ContactStore:这是基于 HashMap 的内存数据存储库,其实现对于本文不重要。

 

方法

HTTP 方法映射到资源的 CRUD(创建、读取、更新和删除) 操作。尽管您可以做一些小修改,比如让 PUT 方法变成创建或更新,但基本的模式如下:

  • HTTP GET:获取/列出/检索单个资源或资源集合。

  • HTTP POST:新建资源。

  • HTTP PUT:更新现有资源或资源集合。

  • HTTP DELETE:删除资源或资源集合。

因为我已经介绍过 GET 方法,我将从 POST 开始说明。就像其他方法一样,我仍然使用 Contact 示例进行说明。

 

POST

通常通过填写表单创建新联系人。也就是说,HTML 表单将 POST 到服务器,服务器创建并维护新创建的联系人。清单 5 演示了该操作的服务器端逻辑。


单 5. 接受表单提交(POST)并新建一个联系人

@POST  
@Produces(MediaType.TEXT_HTML)  
@Consumes(MediaType.APPLICATION_FORM_URLENCODED)  
public void newContact(  
        @FormParam("id") String id,  
        @FormParam("name") String name,  
        @Context HttpServletResponse servletResponse  
) throws IOException {  
    Contact c = new Contact(id,name,new ArrayList<Address>());  
    ContactStore.getStore().put(id, c);  
          
    URI uri = uriInfo.getAbsolutePathBuilder().path(id).build();  
    Response.created(uri).build();  
          
    servletResponse.sendRedirect("../pages/new_contact.html");  
}

注意该示例的以下部分:

  • @Consumes:声明该方法使用 HTML FORM。

  • @FormParam:注入该方法的 HTML 属性确定的表单输入。

  • @Response.created(uri).build(): 构建新的 URI 用于新创建的联系人(/contacts/{id})并设置响应代码(201/created)。您可以使用 http://localhost:8080/Jersey/rest/contacts/<id> 访问新联系人。

 

PUT

我使用 PUT 方法更新现有资源。但是,也可以通过更新实现,或者像清单 6 中的代码片段展示的那样创建一个资源。


单 6. 接受 PUT 请求并创建或更新联系人

@PUT  
@Consumes(MediaType.APPLICATION_XML)  
public Response putContact(JAXBElement<Contact> jaxbContact) {  
    Contact c = jaxbContact.getValue();  
    return putAndGetResponse(c);  
}  
  
private Response putAndGetResponse(Contact c) {  
    Response res;  
    if(ContactStore.getStore().containsKey(c.getId())) {  
        res = Response.noContent().build();  
    } else {  
        res = Response.created(uriInfo.getAbsolutePath()).build();  
    }  
    ContactStore.getStore().put(c.getId(), c);  
    return res;  
}

我还在本示例中包含了许多不同的概念,重点强调以下概念:

  • Consume XML:putContact() 方法接受 APPLICATION/XML 请求类型,而这种输入 XML 将使用 JAXB 绑定到 Contact 对象。您将在下一节中找到客户端代码。

  • 空响应带有不同的状态码:PUT 请求的响应没有任何内容,但是有不同的状态码。如果数据存储库中存在联系人,我将更新该联系人并返回 204/no content。如果没有新联系人,我将创建一个并返回 201/created。

 

DELETE

实现 DELETE 方法非常简单。示例请查看清单 7。

单 7. 删除其 ID 确定的联系人

@DELETE  
public void deleteContact() {  
    Contact c = ContactStore.getStore().remove(contact);  
    if(c==null)  
        throw new NotFoundException("No such Contact.");  
}

表示形式

在上一节中,我介绍了几个表示形式类型。现在我将简要浏览一遍并深入探讨 JAXB 表示形式。其他受支持的表示形式有 byte[]、InputStream、File 等。

  • String:纯文本。

  • Response:一般 HTTP 响应,包含带有不同响应代码的定制内容。

  • Void:带有 204/no content 状态码的空响应。

  • Resource Class:将流程委托给该资源类。

  • POJO:使用 @XmlRootElement 注释的 JavaBean,这让它成为一个 JAXB bean,可以绑定到 XML。

  • POJO 集合:JAXB bean 集合。

JAX-RS 支持使用 JAXB (Java API for XML Binding) 将 JavaBean 绑定到 XML 或 JSON,反之亦然。JavaBean 必须使用 @XmlRootElement 注释。清单 8 使用 Contact bean 作为示例。没有明确 @XmlElement 注释的字段将包含一个名称与之相同的 XML 元素。清单 9 显示了用于一个 Contact bean 的序列化 XML 和 JSON 表示形式。联系人集合的表示形式与此相同,默认使用 <Contacts> 作为包装器元素。


单 8. Contact bean

@XmlRootElement  
public class Contact {  
    private String id;  
    private String name;  
    private List<Address> addresses;  
      
    public Contact() {}  
      
    public Contact(String id, String name, List<Address> addresses) {  
        this.id = id;  
        this.name = name;  
        this.addresses = addresses;  
    }  
  
    @XmlElement(name="address")  
    public List<Address> getAddresses() {  
        return addresses;  
    }  
  
    public void setAddresses(List<Address> addresses) {  
        this.addresses = addresses;  
    }  
    // Omit other getters and setters  
}

单 9. 一个 Contact 的表示形式

XML representation:

<contact>  
  <address>  
    <city>Shanghai</city>  
    <street>Long Hua Street</street>  
  </address>  
  <address>  
    <city>Shanghai</city>  
    <street>Dong Quan Street</street>  
  </address>  
  <id>huangyim</id>  
    <name>Huang Yi Ming</name>  
</contact>

JSON representation:

{"contact":[{"address":[{"city":"Shanghai","street":"Long  
            Hua Street"},{"city":"Shanghai","street":"Dong Quan  
            Street"}],"id":"huangyim","name":"Huang Yi Ming"}]}

 

 REST 服务通讯的客户端

在目前为止的示例中,我开发了一个支持 CRUD 的 RESTful Web 服务。现在我开始解释如何使用 curl,RestClient 和 Jersey 客户端 API 与该 REST 服务通讯。这样一来,我可以测试服务器端代码,并介绍更多有关客户端技术的信息。

 

使用 curl 与 REST 服务通讯

Curl 是一个流行的命令行工具,可以向使用 HTTP 和 HTTPS 协议的服务器发送请求。这是一个与 RESTful Web 服务通讯的好工具,因为它可以通过任何 HTTP 方法发送内容。Curl 已经在 Linux 和 Mac 中自带了,并且有一个实用工具,可以在 Windows® 平台上进行安装。

现在,我们初始化获取所有联系人的第一个 curl 命令。您可以参考 清单 3 获取服务器端代码。

curl http://localhost:8080/Jersey/rest/contacts

响应将使用 XML 并包含所有联系人。

注意,getContacts() 方法还生成一个 application/json MIME 类型响应。您还可以请求该类型的内容。

curl –HAccept:application/json http://localhost:8080/Jersey/rest/contacts

响应将是一个包含所有联系人的 JSON 字符串。

现在,我将 PUT 一个新的联系人。注意,清单 6 中的 putContact() 方法接受 XML 并使用 JAXB 将 XML 绑定到 Contact 对象。

[html] view plaincopy

  1. curl -X PUT -HContent-type:application/xml --data "<contact><id>foo</id>  

  2.                 <name>bar</name></contact>" http://localhost:8080/Jersey/rest/contacts/foo  

一个通过 “foo” 识别的新联系人将添加到联系人存储库。您可以使用 URI /contacts 或 /contacts/foo 验证联系人集合或单个联系人。

 

使用 RestClient 与 REST 服务通讯

RESTClient是一个用于测试RESTful Web services的Java客户端,该工具的安装请参考文章http://blog.csdn.net/zztfj/article/details/7588330

获取所有联系人列表,并返回XML格式(默认格式)。

在Eclipse中使用Jersey和Tomcat构建RESTful WebService及其调用

获取所有联系人列表,并返回JSON格式。

在Eclipse中使用Jersey和Tomcat构建RESTful WebService及其调用

 

 

使用 Jersey Client 与 REST 服务通讯

Jersey 还提供了一个客户端库,帮助您与服务器通讯并对 RESTful 服务进行单元测试。该库是一个一般实现,可以整合任何 HTTP/HTTPS-based Web 服务。

客户端的核心类是 WebResource 类。您可以使用该类根据根 URI 构建一个请求 URL,然后发送请求并获取响应。清单 10 展示了如何创建 WebResource 实例。注意 WebResource 是一个大对象,因此只创建一次。


单 10. 创建 WebResource 实例

[java] view plaincopy

  1.                   

  2. Client c = Client.create();  

  3. WebResource r=c.resource("http://localhost:8080/Jersey/rest/contacts");  

第一个 Jersey 客户端示例将发送 GET 请求获取所有联系人并打印响应状态码和响应内容,参见清单 11。

单 11. GET 所有联系人并打印响应

[java] view plaincopy

  1. ClientResponse response = r.get(ClientResponse.class);  

  2. System.out.println( response.getStatus() );  

  3. System.out.println( response.getHeaders().get("Content-Type") );  

  4. String entity = response.getEntity(String.class);  

  5. System.out.println(entity);  


 

清单 12 展示了另一个创建通过 “foo” 识别的新联系人的示例。


单 12. 创建一个联系人

[java] view plaincopy

  1. Address[] addrs = {  

  2.     new Address("Shanghai""Ke Yuan Street")  

  3. };  

  4. Contact c = new Contact("foo""Foo Bar", Arrays.asList(addrs));  

  5.   

  6. ClientResponse response = r  

  7.     .path(c.getId())  

  8.     .accept(MediaType.APPLICATION_XML)  

  9.     .put(ClientResponse.class, c);  

  10. System.out.println(response.getStatus());           

注意 WebResource 实例的 API。它构建 URI,设置请求头,并在一行代码中调用请求。内容(Contact 对象)将自动绑定到 XML。

清单 13 展示了检索通过 “foo” 识别的联系人(已上一个示例中创建)的最后一个示例然后删除该联系人。


单 13. 检索 “foo” 联系人并删除

[java] view plaincopy

  1. GenericType<JAXBElement<Contact>> generic = new GenericType<JAXBElement<Contact>>() {};  

  2. JAXBElement<Contact> jaxbContact = r  

  3.     .path("foo")  

  4.     .type(MediaType.APPLICATION_XML)  

  5.     .get(generic);  

  6. Contact contact = jaxbContact.getValue();  

  7. System.out.println(contact.getId() + ": " + contact.getName());  

  8.   

  9. ClientResponse response = r.path("foo").delete(ClientResponse.class);  

  10. System.out.println(response.getStatus());    


 

注意,当您想获取 JAXB bean 响应时,您需要使用 Java 2 Platform, Standard Edition (J2SE) 中引入的范型特性。

 

Jersey jar库文件的下载地址:http://download.csdn.net/detail/zztfj/4334371

本文的源代码下载:http://download.csdn.net/detail/zztfj/4334425

  • 大小: 10.2 KB
  • 大小: 10.2 KB
分享到:
评论

相关推荐

    RESTful 架构详解 _ 菜鸟教程2

    综上所述,RESTful架构提供了一种清晰、模块化的方法来设计Web服务,使得开发者能够构建高效、可维护的分布式系统。通过理解并遵循RESTful原则,可以创建出易于理解和使用的API,从而促进系统的互操作性和可扩展性。

    OpenStack的架构详解

    OpenStack 架构详解 OpenStack 是一个社区、项目和开源软件,提供了一个部署云的操作平台或工具集。其宗旨在于,帮助组织运行为虚拟计算或存储服务的云,为公有云、私有云,也为大云、小云提供可扩展的、灵活的...

    java restFull及示例和Maven.rar

    7. **RESTful架构详解**: - 无状态:每次请求都包含所有必要的信息,服务器不保存客户端状态。 - 缓存机制:允许客户端缓存响应,提高性能。 - 层次化系统:中间层可以增加安全性和可扩展性。 - 统一接口:简化...

    对Django的restful用法详解(自带的增删改查)

    在当今的网络编程中,RESTful(Representational State Transfer,表现层状态转换)架构设计原则已被广泛采用,成为构建Web API的标准方式之一。RESTful要求所有的Web应用都应当遵循一套既定的架构指导原则,从而...

    springboot学习笔记

    2. [RESTful架构详解](http://www.ruanyifeng.com/blog/2011/09/restful.html) ##### 常用注解 在Spring Boot中,实现RESTful API需要用到以下几种注解: 1. **@Controller**:表示这是一个控制器类,用于处理Web...

    微服务架构详解.docx

    微服务架构详解 微服务架构是一种架构模式,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。每个服务运行在其独立的进程中,服务与服务间采用轻量级的通信机制互相协作...

    Openstack架构详解[归纳].pdf

    "OpenStack 架构详解" OpenStack 是一个社区,也是一个项目和一个开源软件,它提供了一个部署云的操作平台或工具集。其宗旨在于,帮助组织运行为虚拟计算或存储服务的云,为公有云、私有云,也为大云、小云提供可...

    微服务技术架构详解.docx

    这种架构模式鼓励使用轻量级通信机制,如HTTP RESTful API,以实现服务间的交互。此外,微服务强调每个服务应具有清晰的边界,遵循SOLID原则,确保服务的职责单一。 二、出现和发展 微服务概念的诞生是为了应对快速...

    RESTful API设计规范

    1. **资源(Resource)**:在RESTful架构中,所有网络上的实体都可以被抽象成资源。例如,一个用户、一篇文章或者一条评论都可以被视为资源。 2. **资源标识**:每个资源都拥有唯一的标识符,通常通过URL来表示。这种...

    Kubernetes架构详解.docx

    1. **API 服务器(API Server)**:作为集群的接口,API 服务器暴露了一个 RESTful API,允许用户和系统组件与集群进行交互。它处理来自客户端的请求,验证并更新存储在 etcd 中的集群状态。 2. **集群数据存储...

    cxf实现restful资料

    RESTful服务常用于构建分布式系统,如移动应用后端、微服务架构中的服务间通信等。CXF的灵活性和与Spring的深度整合使其成为实现RESTful服务的优秀选择。通过学习和实践本资料中的案例,开发者能够掌握如何利用CXF和...

    nginx实战-基于lua语言

    **Nginx实战:基于Lua语言的配置、开发与架构详解** 在现代Web服务领域,Nginx以其高性能、轻量级以及强大的反向代理和负载均衡能力而备受青睐。结合Lua语言,Nginx可以进一步提升其灵活性和功能扩展性,实现更复杂...

    Apress - Pro ADO.NET Data Services Working with RESTful Data

    《专业ADO.NET数据服务:与RESTful数据协作》是一本由John Shaw和Simon Evans撰写的深入探讨ADO.NET数据服务在RESTful架构下应用的专业书籍。本书聚焦于如何使用ADO.NET Data Services来处理RESTful数据,为读者提供...

Global site tag (gtag.js) - Google Analytics