Jersey客户端调用RESTful服务

时间:2013-08-20 07:10:23

标签: java rest authentication jersey client

我是使用Jersey的新手,我正在努力让我的客户端对抗现有的RESTful服务。我有一个有效的SOAPUI调用,这是来自该请求的原始数据。

POST http://localhost/QWJB/WENXrest//getHistory HTTP/1.1
Accept-Encoding: gzip,deflate
Content-Type: application/json
User-Agent: Jakarta Commons-HttpClient/3.1
Content-Length: 189
Authorization: Basic VUNRRzE02fr45tDE0d1RQdw==
Host: localhost

{getHistory:       
{
wENXHeader:
{
languageCode: "en"
},

Account: "111111111",

    services: 
    [
        {Service: "CE000001"},
        {Service: "CE000002"}
    ]
    }

}

此时我愿意硬编码所有值,只是为了看它是否有效。但这是我的客户代码。

import javax.ws.rs.Consumes;
import javax.ws.rs.POST;
import javax.ws.rs.core.MediaType;
import com.sun.jersey.api.client.Client;
import com.sun.jersey.api.client.WebResource;

public void MakeRestCall() {
  try {
GetHistory requestData = new GetHistory();
requestData.setAccount("111111111");

Client client = Client.create();
WebResource webResource = client
.resource("http://localhost/QWJB/WNEXrest//getHistory");

webResource.accept("application/json");
webResource.entity(requestData);

GetHistoryResponse response =       
webResource.type(MediaType.APPLICATION_XML).post(GetHistoryResponse.class);

} catch (Exception e) {
logger.error(message);
    e.printStackTrace();
}

当我使用SOAPUI时,我必须设置用户ID和密码,原始请求的授权部分是什么?我应该用它来加密它?

1 个答案:

答案 0 :(得分:3)

框架身份验证标头

由于您的REST服务使用的是基本身份验证,因此您可以使用以下命令设置泽西休息客户端身份验证:

client.addFilter(new HTTPBasicAuthFilter(username, password));