我正在尝试@POST用户创建的对象,并获得一个响应,其中使用不同的用户创建的有效负载作为实体。虽然返回的对象存在并且已填充,但在客户端上它是空的。
客户端发送/服务器收到的对象:
@XmlRootElement
public class TweetQuery {
String query;
List<TweetQueryTweet> tweets = new ArrayList<>();
// setters and getters
}
public class TweetQueryTweet {
private String id;
private String text;
// setters and getters
}
服务器收到/客户端发送对象:
@XmlRootElement
public class TweetClusters {
List<TweetCluster> tweetClusters = new ArrayList<>();
// setters and getters
}
public class TweetCluster {
List<String> labels = new ArrayList<>();
List<String> docs = new ArrayList<>();
// setters and getters
}
客户(Arquillian)测试:
@Test
@RunAsClient
public void test01SeeSomething(@ArquillianResource URL deploymentUrl) throws ... {
final URI targetURI = ...;
System.out.println(" test target:" + targetURI.toASCIIString());
Entity<TweetQuery> tweetQuery = Entity.entity(getTestTweetQuery(), MediaType.APPLICATION_JSON);
Client client = ClientBuilder.newBuilder().build();
WebTarget target = client.target(targetURI.toASCIIString());
Response response = target.request(MediaType.APPLICATION_JSON).post(tweetQuery);
TweetClusters x = response.readEntity(TweetClusters.class);
System.out.println("Entity:" + x);
System.out.println("Response: " + response.getStatus());
assertEquals(Status.OK.getStatusCode(), response.getStatus());
assertNotNull(x);
assertThat(x.getTweetClusters().size()).isGreaterThan(0);
}
泽西邮报方法:
@POST
@Consumes(MediaType.APPLICATION_JSON)
@Produces(MediaType.APPLICATION_JSON)
public Response clusterPost(TweetQuery tweetQuery) {
TweetClusters tweetClusters = clusterService.getTweetClusters(tweetQuery);
System.out.println("clusterPost - in - tweetQuery: " + tweetQuery);
System.out.println(" - out tweetClusters: " + tweetClusters);
return Response.status(Status.OK).type(MediaType.APPLICATION_JSON).entity(tweetClusters).build();
}
调试:
test target:http://localhost:18080/test//cluster
clusterPost - in - tweetQuery: [TweetQuery - query:TweetQuery query, tweets:[[TweetQueryTweet - id:1, text:text 1], [TweetQueryTweet - id:2, text:text 2], [TweetQueryTweet - id:3, text:text 3]]]
- out tweetClusters: [TweetClusters:[[TweetCluster - labels: [Other Topics], docs:[3, 2, 1]]]]
Entity:[TweetClusters:[]]
Response: 200
第2行 - clusterPost - in - 显示TweetQuery正在正确编组。 第3行 - clusterPost - out - 显示当响应实体存在时要发送的tweetClusters 第4行 - tweetClusters未出现在请求中
修改
我更改了REST方法,以返回它作为输入接收的tweetQuery并正确返回。关于TweetClusters的一些东西。也许我需要一个MessageBodyReader&amp;作家。或者Moxy @XmlJavaTypeAdapter。但是因为Lists显然可以像TweetQuery一样开箱即用。
https://stackoverflow.com/users/383861/blaise-doughan你在外面吗? :)
我错过了一些简单的东西吗?
答案 0 :(得分:6)
总而言之,你需要让(un)编组对象:
如果您有更复杂的类型,包括日期和日历,则需要在Jackson中使用适配器@XmlJavaTypeAdapter
(Moxy)或@JsonSerialize.using
(或在RESTeasy中使用???)。
有趣的是,我不需要@XmlRootElement
(Moxy),但保留它是好的措施。
完整的答案是:
(联盟)编组的对象类是:
@XmlRootElement 公共课TweetClusters { 列出tweetClusters = new ArrayList&lt;&gt;();
public void addCluster(Cluster c) {
TweetCluster tweetCluster = new TweetCluster(c);
tweetClusters.add(tweetCluster);
}
public List<TweetCluster> getTweetClusters() {
return tweetClusters;
}
public void setTweetClusters(List<TweetCluster> tweetClusters) {
this.tweetClusters = tweetClusters;
}
@Override
public String toString() {
return String.format("[TweetClusters:%s]", tweetClusters);
}
}
public class TweetCluster { List labels = new ArrayList&lt;&gt;(); 列出docs = new ArrayList&lt;&gt;();
public TweetCluster() {
}
public TweetCluster(Cluster c) {
labels.add(c.getLabel());
for (Document doc : c.getDocuments()) {
docs.add(doc.getTitle());
}
}
public List<String> getLabels() {
return labels;
}
public void setLabels(List<String> labels) {
this.labels = labels;
}
public List<String> getDocs() {
return docs;
}
public void setDocs(List<String> docs) {
this.docs = docs;
}
@Override
public String toString() {
return String.format("[TweetCluster - labels: %s, docs:%s]", labels, docs);
}
}
public class TweetQuery { 字符串查询;
List<TweetQueryTweet> tweets = new ArrayList<>();
public String getQuery() {
return query;
}
public void setQuery(String query) {
this.query = query;
}
public List<TweetQueryTweet> getTweets() {
return tweets;
}
public void setTweets(List<TweetQueryTweet> tweets) {
this.tweets = tweets;
}
public void addTweets(TweetQueryTweet... queryTweets) {
for (TweetQueryTweet tweet : queryTweets) {
this.tweets.add(tweet);
}
}
@Override
public String toString() {
return String.format("[TweetQuery - query:%s, tweets:%s]",query, tweets);
}
}
(Arghhh,抱歉格式化;我无法在SO中修复它)
出于调试目的,通常可以获取从响应返回的字符串表示形式(即XML或JSON),并且只需将实体类型指定为String.class
:
String x = response.readEntity(String.class);
答案 1 :(得分:1)
尝试返回这样的响应:Response.ok(tweetClusters).build();
答案 2 :(得分:0)
我不确定为什么你有使用@XmlRootElements注释的模型。所以我认为你可以删除它,并确保你使用Jackson序列化和反序列化你的请求和响应正文。我认为你是或者是gson。