使用Java创建RESTful Web Service详解架构师

使用Java创建RESTful Web Service详解架构师

REST是REpresentational State Transfer的缩写(一般中文翻译为表述性状态转移)。2000年Roy Fielding博士在他的博士论文“Architectural Styles and the Design of Network-based Software Architectures”《体系结构与基于网络的软件架构设计》中提出了REST。

REST是一种体系结构。而HTTP是一种包含了REST架构属性的协议。

REST基础概念

1.在REST中所有东西都被看作资源。每一个资源都有一个URI和它对应。

2.在REST中使用统一接口处理资源。与数据库CRUD操作(Create、Read、Update 和 Delete)一样,可以用POST、GET、PUT和DELETE处理REST资源。

3.每个REST请求都是孤立的,请求中包含了所需的全部信息。REST服务端不存储状态。

4.REST支持不同的通信数据格式,比如XML、JSON。

RESTful Web Services

RESTful Web Services因其简单性被广泛使用,它比SOAP要更简单。本文将重点介绍如何使用Jersey框架创建RESTful Web Services。Jersey框架实现了JAX-RS接口。本文示例代码使用Eclipse和Java SE 6编写。

创建RESTful Web Service服务端

在Eclipse中创建一个“dynamic web project”(动态web工程) ,项目名设为 “RESTfulWS”。

从这里下载Jersey。示例代码使用的是Jersey 1.17.1。首先解压Jersey到“jersey-archive-1.17.1”文件夹。接着将里面lib文件夹下的jar文件拷贝到工程目录的WEB-INF -> lib。然后将它们添加到build path。

1.asm-3.1.jar

2.jersey-client-1.17.1.jar

3.jersey-core-1.17.1.jar

4.jersey-server-1.17.1.jar

5.jersey-servlet-1.17.1.jar

6.jsr311-api-1.1.1.jar

在工程Java Resources -> src中创建“com.eviac.blog.restws”包,并在其中创建“UserInfo”类。最后把web.xml拷贝到WEB-INF目录下。

UserInfo.java

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;

// [email protected]

// 指定了资源类提供服务的URI路径。

@Path(“UserInfoService”)

    public class UserInfo {

    // @GET表示方法会处理HTTP GET请求

    @GET

    // [email protected]服务的URI路径。

    @Path(“/name/{i}”)

    // @Produces定义了资源类方法会生成的媒体类型。

    @Produces(MediaType.TEXT_XML)

    // @[email protected]

    public String userName(@PathParam(“i”) String i) {

        String name = i;

        return “<User>” + “<Name>” + name + “</Name>” + “</User>”;

    }

 

    @GET

    @Path(“/age/{j}”)

    @Produces(MediaType.TEXT_XML)

    public String userAge(@PathParam(“j”) int j) {

        int age = j;

        return “<User>” + “<Age>” + age + “</Age>” + “</User>”;

    }

}

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” xmlns:web=”http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd” xsi:schemaLocation=”http://java.sun.com/xml/ns/javaee <a href=”http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd”>http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd”</a> id=”WebApp_ID” version=”2.5″>

<display-name>RESTfulWS</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>com.eviac.blog.restws</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>

</web-app>

将此URL拷贝到浏览器地址栏中运行:

http://localhost:8080/RESTfulWS/rest/UserInfoService/name/Pavithra

输出结果如下:

创建客户端

创建一个“com.eviac.blog.restclient”包,然后新建“UserInfoClient”类。

UserInfoClient.java

import javax.ws.rs.core.MediaType;

import com.sun.jersey.api.client.Client;

import com.sun.jersey.api.client.ClientResponse;

import com.sun.jersey.api.client.WebResource;

import com.sun.jersey.api.client.config.ClientConfig;

import com.sun.jersey.api.client.config.DefaultClientConfig;

    public class UserInfoClient {

        public static final String BASE_URI = “http://localhost:8080/RESTfulWS”;

        public static final String PATH_NAME = “/UserInfoService/name/”;

        public static final String PATH_AGE = “/UserInfoService/age/”;

        public static void main(String[] args) {

        String name = “Pavithra”;

        int age = 25;

        ClientConfig config = new DefaultClientConfig();

        Client client = Client.create(config);

        WebResource resource = client.resource(BASE_URI);

        WebResource nameResource = resource.path(“rest”).path(PATH_NAME + name);

        System.out.println(“Client Response /n”

        + getClientResponse(nameResource));

        System.out.println(“Response /n” + getResponse(nameResource) + “/n/n”);

        WebResource ageResource = resource.path(“rest”).path(PATH_AGE + age);

        System.out.println(“Client Response /n”

        + getClientResponse(ageResource));

        System.out.println(“Response /n” + getResponse(ageResource));

    }

    /**

    * 返回客户端请求。

    * 例如:

    * GET http://localhost:8080/RESTfulWS/rest/UserInfoService/name/Pavithra

    * 返回请求结果状态“200 OK”。

    *

    * @param service

    * @return

    */

    private static String getClientResponse(WebResource resource) {

        return resource.accept(MediaType.TEXT_XML).get(ClientResponse.class)

        .toString();

    }

 

    /**

    * 返回请求结果XML

    * 例如:<User><Name>Pavithra</Name></User>

    *

    * @param service

    * @return

    */

    private static String getResponse(WebResource resource) {

        return resource.accept(MediaType.TEXT_XML).get(String.class);

    }

}

运行客户端程序后,可以看到以下输出:

Client Response

GET http://localhost:8080/RESTfulWS/rest/UserInfoService/name/Pavithra returned a response status of 200 OK

Response

<User><Name>Pavithra</Name></User>

Client Response

GET http://localhost:8080/RESTfulWS/rest/UserInfoService/age/25 returned a response status of 200 OK

Response

<User><Age>25</Age></User>

原文链接: eviac 翻译: ImportNew.com – 陈洁
译文链接: http://www.importnew.com/7336.html
[ 转载请保留原文出处、译者和译文链接。]

使用Java创建RESTful Web Service详解架构师

转载请注明来源网站:blog.ytso.com谢谢!

原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/tech/architecture/7024.html

(0)
上一篇 2021年7月17日 01:51
下一篇 2021年7月17日 01:51

相关推荐

发表回复

登录后才能评论