`
liugang594
  • 浏览: 990694 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JAX-RS入门 六: 数据处理(1)

 
阅读更多

接下来要花两小节来介绍一下JAX-RS中的数据处理(Data Handlers)部分。

 

一、SteamingOutput

在第一节中(http://liugang594.iteye.com/blog/1491434),看getCustomer()方法:

    public StreamingOutput getCustomer(int id) {   
        final Customer customer = customerDB.get(id);   
        if (customer == null) {   
            throw new WebApplicationException(Response.Status.NOT_FOUND);   
        }   
        return new StreamingOutput() {   
            public void write(OutputStream outputStream) throws IOException,   
                    WebApplicationException {   
                outputCustomer(outputStream, customer);   
            }   
        };   
    }  

其中使用了SteamingOutput来写一个原始流的字符流。

 

这是JAX-RS提供的数据处理的其中一种方式,通过回调SteamingOutput的write()方法来写回response。

相对于直接返回一个OutputSteam对象,使用回调对象有以下好处:

  1. JAX-RS可以自由的,按照它的设想处理输出
  2. 当追求性能时,甚至可以使用另一个线程而不是当前调用线程回写
  3. 可以很方便的注入拦截器,而使用一个直接的OutputSteam则通常会跳过这些步骤
  4. 最后,可以实现异步响应,类AJAX。在Servlet3.0中已经介绍了异常响应的想法。

二、InputSteam/Reader

 

可以使用InputSteam或Reader去处理请求内容,JAX-RS会自动将请求数据转成一个InputSteam/Reader对象,例如:

@PUT
@Path("/stuff")
public void putStuff(InputStream is) {
	byte[] bytes = readFromStream(is);
	String input = new String(bytes);
	System.out.println(input);
}

 

 

@PUT
@Path("/morestuff")
public void putMore(Reader reader) {
	LineNumberReader lineReader = new LineNumberReader(reader);
	do {
		String line = lineReader.readLine();
		if (line != null) System.out.println(line);
	} while (line != null);
}

 

除了处理请求,InputSteam/Reader也可以作为响应:

	@GET
	@Path("file/{fileName}")
	@Produces("text/plain")
	public Reader getFileContent(@PathParam("fileName") String fileName);

注:当作为响应时,需要指定@Produces,这样JAX-RS才知道怎么去设置响应的Content-Type头信息

 

三、File

 

File对象也可以用在处理请求或响应中。例如用于请求:

@POST
@Path("/morestuff")
public void post(File file) {
	Reader reader = new Reader(new FileInputStream(file));
	LineNumberReader lineReader = new LineNumberReader(reader);
	do {
		String line = lineReader.readLine();
		if (line != null) System.out.println(line);
	} while (line != null);
}

这里File作为请求参数使用。

 

注:当使用File作为请求参数时,JAX-RS会在后台生成一个临时文件,以请求的信息体作为这个文件的内容,然后将这个临时文件作为参数传入。

 

用于响应:

private static final String basePath = "...";
@GET
@Path("{filepath: .*}")
@Produces("text/plain")
public File getFile(@PathParam("filepath") String path) {
	return new File(basePath + path);
}    

注:同样的,当File用作响应时,需要指定@Produces,用于告诉JAX-RS怎么转换File内容,即Content-Type。

 

四、byte[]

 

byte[]也可以用在请求或响应,例如:

@GET
@Produces("text/plain")
public byte[] get() {
	return "hello world".getBytes();
}
@POST
@Consumes("text/plain")
public void post(byte[] bytes) {
	System.out.println(new String(bytes));
}

注:当用作响应时,需要指定@Produces,用于告诉JAX-RS怎么设置响应的Content-Type值。 

 

五、String/Char[]

 

大多数网络数据是基于文件格式的。JAX-RS可以进行任何文件格式的内容与String/Char[]之间的转换。例如:

@GET
@Produces("application/xml")
public String get() {
	return "<customer><name>Bill Burke</name></customer>";
}
@POST
@Consumes("text/plain")
public void post(String str) {
	System.out.println(str);
}

注:当用作响应时,需要指定@Produces,用于告诉JAX-RS怎么设置响应的Content-Type值。

 

注:JAX-RS规范要求实现者必须处理在Content-Type中指定的charset值,当注入String时,例如:

 

POST /data
Content-Type: application/xml;charset=UTF-8
<customer>...</customer>

这里charset为UTF-8,实现者必须保证生成的Java String必须是UTF-8编码的。

 

六、MultivaluedMap<String, String> 和Form

 

在节4(http://liugang594.iteye.com/blog/1496651)中,已经介绍了使用@FormParam去获取提交的Form值。除了使用@FormParam,也可以直接注入MultivaluedMap<String,String>对象来表示所有请求的Form数据,其中Form数据格式是 "application/x-www-form-urlencoded",例如:

 

@POST
@Consumes("application/x-www-form-urlencoded")
@Produces("application/x-www-form-urlencoded")
public MultivaluedMap<String,String> post(
	MultivaluedMap<String, String> form) {
	return form;
}

注:JAX-RS规范并未指明注入的MultivaluedMap是否已经编码;大多数实现者都会自动解码其中的key/value值。如果你想保持编码的格式,则可以使用@javax.ws.rs.Encoded注释。

 

七、javax.xml.transform.Source

 

Source接口代表了一个XML的输入或输出,它通常是用来进行XSLT转换的,例如:

 

@Consumes("application/xml")
@Produces("application/xml")
public String post(Source source) {
	javax.xml.transform.TransformerFactory tFactory =
		javax.xml.transform.TransformerFactory.newInstance();
	javax.xml.transform.Transformer transformer =
		tFactory.newTransformer(
			new javax.xml.transform.stream.StreamSource("foo.xsl"));
	StringWriter writer = new StringWriter();
	transformer.transform(source,
		new javax.xml.transform.stream.StreamResult(writer));
	return writer.toString();
}

除了JAXB(下节讲)外,javax.xml.transform.Source对象是规范中唯一支持的基于XML结构的对象。(甚至不能注入org.w3c.dom.Document对象)

 

 

分享到:
评论

相关推荐

    JAX-RS入门jar包集合

    本资源“JAX-RS入门jar包集合”包含了开始学习和使用JAX-RS所需的基本库文件,这些jar包将帮助开发者快速搭建REST服务环境。下面我们将详细讲解JAX-RS的核心概念和关键组件,以及如何利用这些jar包进行实际开发。 1...

    CursoWebServices:Curso Java Web服务JAX-WS JAX-RS

    2. JAX-WS入门:介绍如何使用JAX-WS创建SOAP服务,包括服务端点接口、消息处理和部署描述符的配置。 3. JAX-WS高级特性:探讨服务端点实现、异常处理、消息传递模式和WS-Security等进阶话题。 4. JAX-RS基础:学习...

    quick-start-jax-rs

    【快速入门JAX-RS】 JAX-RS是Java API for RESTful Web Services的缩写,它是Java平台上的一个标准,用于构建RESTful Web服务。REST(Representational State Transfer)是一种网络应用程序的设计风格和开发方式,...

    WebService视频教程大全

    2. **JAX-RS**: JAX-RS是处理RESTful服务的Java标准。CXF提供了对JAX-RS的强大支持,允许开发者使用注解来快速创建资源类,定义HTTP方法和URL映射,从而构建RESTful服务。 【WebService视频教程内容预览】 在...

    apache-cxf-3.1.6

    此外,它还支持JAX-RS(Java API for RESTful Web Services)和JAX-WS(Java API for XML Web Services),使得开发RESTful服务和SOAP服务变得简单。 8. **安全性**: CXF提供了多种安全机制,如基本认证、OAuth、...

    webService DEMO

    Web服务(WebService)是一种基于网络的、松散耦合的软件模块,允许不同系统之间进行交互和数据交换。在Java中实现Web服务,通常使用SOAP(Simple Object Access Protocol)或REST(Representational State Transfer...

    cxf入门文档资料

    5. **数据绑定**:CXF支持JAXB(Java Architecture for XML Binding)进行XML到Java对象的自动转换,简化了XML数据的处理。 6. **安全与认证**:文档可能涵盖了如何在CXF中集成安全机制,如WS-Security、OAuth2或...

    JAXRS-HelloWorld

    本示例“JAXRS-HelloWorld”是学习JAX-RS基础知识的一个经典入门项目。 首先,我们来看一下这个项目的目录结构。根据提供的压缩包文件名“JAXRS-HelloWorld-master”,我们可以推测这是一个Git仓库的克隆,通常包含...

    WebService CXF学习-入门篇.pdf

    4. **JAX-RS**:Java API for RESTful Web Services,用于创建RESTful服务。 5. **SOAP**:支持1.1和1.2版本,以及WS-I Basic Profile、WS-Security、WS-Addressing等规范。 6. **WSDL**:Web服务描述语言,用于定义...

    初级Webservice教程代码资料(java)

    4. JAX-RS教程:JAX-RS利用HTTP方法(如GET、POST、PUT和DELETE)和资源URI来处理请求。学习如何使用@Path、@GET、@POST等注解创建REST服务,并理解JSON和XML之间的转换。 5. 客户端调用:无论是SOAP还是REST服务,...

    hello-world-apis:API API de grafos的世界您好

    1. **Servlet和JAX-RS**:Java中的API通常通过HTTP服务器进行通信,这可能需要使用Servlet或JAX-RS(Java API for RESTful Web Services)来创建RESTful API。Servlet处理HTTP请求,而JAX-RS则简化了创建REST服务的...

    Java的webservice入门(视频+代码)

    SOAP允许开发者传递复杂的数据结构,并提供了错误处理机制。 2. **WSDL**:WSDL文档定义了Web Service的接口,包括服务提供的操作、消息格式、输入/输出参数、地址等信息。服务消费者通过读取WSDL可以知道如何与...

    java restFull及示例和Maven.rar

    - Jersey是JAX-RS(Java API for RESTful Web Services)的参考实现,用于创建RESTful服务。 - 注解驱动:使用@Path、@GET、@POST等注解来标记资源类和方法。 - 使用Response和Entity:返回HTTP响应,包括状态码...

    jaxws的小demo

    JAX-WS支持多种协议,包括SOAP、WSDL和UDDI,能够处理XML数据并进行网络通信。 2. **Web服务生命周期** - **创建服务端**:首先,我们需要定义一个Java接口,该接口将作为Web服务的API。然后,使用JAX-WS的注解...

    Web Service 入门

    Java中,JAX-RS(Java API for RESTful Web Services)是用于构建RESTful服务的标准API。 - 定义资源类:创建Java类表示资源,并使用`@Path`注解指定资源路径。 - 方法注解:在类的方法上使用`@GET`, `@POST`, `@...

    webservice入门教程

    1. 使用Apache CXF或Jersey创建JAX-RS服务,实现RESTful API。 2. 使用Spring Boot创建基于JAX-WS的SOAP服务,利用注解简化配置。 六、学习资源 1. "web+service入门教程ppt":这份PPT资料将深入浅出地介绍Web服务...

    cfx web service

    - **数据绑定**:CXF支持多种数据绑定机制,如JAXB、Aegis等,方便处理XML和Java对象之间的转换。 - **MTOM/XOP**:支持Message Transmission Optimization Mechanism,可以提高大文件传输的效率。 - **国际化与本地...

    CXF入门教程及源码

    CXF是基于Apache基金会的项目,它提供了SOAP、RESTful、JAX-RS、JAX-WS等接口的支持,可以方便地创建Web服务。CXF的核心功能包括服务建模、绑定生成、服务实现和部署,以及客户端代理和服务代理的生成。它的设计...

    camel-manual-2.10.4.pdf

    - Apache CXF:一个智能的Web服务套件(包括JAX-WS和JAX-RS)。 - Apache Karaf:一个小型的基于OSGi的运行时环境,其中可以部署容器代理的应用程序。 - Apache MINA:一个高性能的NIO驱动的网络框架。 Camel的核心...

    Jersey User Guild

    1. **Getting Started(入门指南)** - **Creating a New Project from Maven Archetype(从 Maven Archetype 创建新项目)**:介绍如何使用 Maven archetype 快速搭建 Jersey 项目。 - **Exploring the Newly ...

Global site tag (gtag.js) - Google Analytics