Jersey Web服务返回null JSON

时间:2013-11-08 03:21:09

标签: java json rest jersey

我想将数据库表的数据提供给客户端。我是通过JSON发送数据的。当我在客户端打印输出结果时,它会得到以下结果。

{"pricing":null}

当我在服务器端打印return语句时,它会输出以下内容

[Connection.Pricing@3d5bae2]

没有错误。我做错了什么?

这是我的客户端代码

public String loadTable(String tablename) throws ClientProtocolException, IOException {
    pathParams.add("tablename", tablename);
    ClientResponse response = service.path("access").path("loadtable").queryParams(pathParams).type(MediaType.APPLICATION_JSON).get(ClientResponse.class);
    String responseString = response.getEntity(String.class);
    return responseString;

这是我的服务器端

@Path("/loadtable")
@GET
@Produces(MediaType.APPLICATION_JSON) 
public List<Pricing> loadTable(@QueryParam("tablename") String tablename) throws Exception {
    List<Pricing> pricing = new ArrayList<Pricing>();
    try {
        query = c.prepareStatement("select * from " + tablename);
        ResultSet ets_rs = query.executeQuery();

        while (ets_rs.next()) {
        pricing.add(new Pricing(ets_rs.getString(1), ets_rs.getString(2),  ets_rs.getString(3), ets_rs.getString(4), ets_rs.getString(5), ets_rs.getString(6)));
        }
        query.close();
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        if (c != null) {
            c.close();
        }
    }
    return pricing;

这是我在服务器端的POJO类

@XmlRootElement
class Pricing {

String category;
String lower_limit;
String class_no;
String value;
String employee;
String upper_limit;

public Pricing() {
}



Pricing(String a, String b, String c, String d, String e, String f) {
    category = a;
    lower_limit = b;
    upper_limit = c;
    class_no = d;
    value = e;
    employee = f;
}
//getters
}

1 个答案:

答案 0 :(得分:1)

您需要覆盖toString类中的Pricing方法,才能以漂亮的方式打印对象。默认的toString()方法显示了由@字符分隔的对象类及其哈希代码,因此您看到了这个

Pricing@3d5bae2

以下是toString类的Pricing方法的一个实现:

@Override
public String toString() {
    return "Pricing [category=" + category + ", lower_limit=" + lower_limit
            + ", class_no=" + class_no + ", value=" + value + ", employee="
            + employee + ", upper_limit=" + upper_limit + "]";
}