0

我使用 FQL 和Spring Social Facebook阅读了所有喜欢的内容

这是方法:

public List<LikeObject>  startF(String token){
    Facebook facebook = new FacebookTemplate(token);
    FacebookProfile profile = facebook.userOperations().getUserProfile();
    //System.out.println(facebook.isAuthorized());
    System.out.println("Authenticcated user: "+profile.getFirstName()+" "+profile.getLastName());
    PagedList<String> friendListIds =  facebook.friendOperations().getFriendIds();

    List<LikeObject> resultsLikes = facebook.fqlOperations().query("SELECT object_id, object_id_cursor,object_type, post_id, post_id_cursor, user_id "+
            "FROM like "+
            "WHERE user_id =me() ",  new FqlResultMapper<LikeObject>(){
        public LikeObject mapObject(FqlResult result) {
            LikeObject like = new LikeObject();
            like.object_id = result.getString("object_id");
            like.object_id_cursor =  result.getString("object_id_cursor");
            like.object_type = result.getString("object_type");
            like.post_id = result.getString("post_id"); 
            like.post_id_cursor = result.getString("post_id_cursor");
            like.user_id = result.getString("user_id");
            return like;
        }
    });
    return resultsLikes;
}       

这里的结果:

LikeObject [object_id=578416.., object_id_cursor=null, object_type=status, post_id=, post_id_cursor=null, user_id=10217..]

然后我想解析 like.object_id 并将其转换为 java 对象。但我不知道如何使用 spring social facebook 来做到这一点。

我试过了facebook.fetchObject(like.object_id, PostType.STATUS)。但这似乎是一种错误的方式。

是否有任何可能的方法来解析春季社交中的“object_id”而不解析来自 GET 查询的原始 JSON 响应?

我试过这个:

LinkPost post = facebook.fetchObject(obj_id, LinkPost.class);

我相信 obj_id 有类型link,我已经检查过了

并导致以下异常:

Exception in thread "main" org.springframework.http.converter.HttpMessageNotReadableException: Could not read JSON: Unexpected token (END_OBJECT), expected FIELD_NAME: missing property 'postType' that is to contain type id  (for class org.springframework.social.facebook.api.LinkPost)
 at [Source: java.io.ByteArrayInputStream@6ca79a6a; line: 1, column: 11114]; nested exception is com.fasterxml.jackson.databind.JsonMappingException: Unexpected token (END_OBJECT), expected FIELD_NAME: missing property 'postType' that is to contain type id  (for class org.springframework.social.facebook.api.LinkPost)
 at [Source: java.io.ByteArrayInputStream@6ca79a6a; line: 1, column: 11114]
    at org.springframework.http.converter.json.MappingJackson2HttpMessageConverter.readJavaType(MappingJackson2HttpMessageConverter.java:171)
    at org.springframework.http.converter.json.MappingJackson2HttpMessageConverter.read(MappingJackson2HttpMessageConverter.java:163)
    at org.springframework.web.client.HttpMessageConverterExtractor.extractData(HttpMessageConverterExtractor.java:94)
    at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:491)
    at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:460)
    at org.springframework.web.client.RestTemplate.getForObject(RestTemplate.java:228)
    at org.springframework.social.facebook.api.impl.FacebookTemplate.fetchObject(FacebookTemplate.java:202)
    at com.repost.facebook.FbConnection.getLikedPosts(FbConnection.java:58)
    at com.repost.facebook.MainClass.main(MainClass.java:15)
4

1 回答 1

2

我仍然不清楚您所说的“解析”是什么意思。但无论如何,让我尝试回答这个问题......

我认为您只是希望能够将对象作为 Post(或 LinkPost)对象获取……对吗?如果是这样,那么不幸的是,我不得不将一些特殊的魔法融入到 API 中,以便能够获取帖子类型并将多态反序列化为特定类型的帖子(例如,LinkPost、StatusPost 等)。

您可以在https://github.com/SpringSource/spring-social-facebook/blob/master/spring-social-facebook/src/main/java/org/springframework/social/facebook/api/中看到设置impl/FeedTemplate.java。在 deserializePost() 方法中,您会看到我读取了“type”属性并将其复制到新的“postType”字段中。其中一个字段用于填充 Post 的 type 属性,另一个用于确定应创建 Post 的哪个特定子类。解决我在 Jackson 1.9.x 中遇到的问题是一种 hack……我认为 Jackson 2 将使这种 hack 变得不必要,但我还没有尝试过。

因此,我只看到了一种实用的方法:不要自己做所有的工作。而是使用 facebook.feedOperations().getPost(objectId)。它知道如何在幕后施展魔法来给你一个 Post 对象。从那里,如果您知道特定类型的 Post,您可以将其转换为(如果)需要 LinkPost、StatusPost 等。

我看到的唯一其他选择是更低级别并通过 facebook.restOperations() 发出请求并自己处理绑定。显然,您需要做更多的工作。

于 2013-06-06T16:20:11.293 回答