SyntaxError:missing;在JSON中声明之前

时间:2014-03-08 09:50:45

标签: javascript jquery json rest

响应正确时,我收到一个非常奇怪的错误,我可以看到JSON内容:

这是请求:

$.ajax({
                    type: "GET",
                    url: urlTwitter,
                    contentType: "application/json",
                    dataType: "jsonp",
                    async: false,
                    success: function (resp, status, xhr) {
                       $("#message").html("STATUS: " + xhr.status + " " + xhr.statusText + "\n" + resp);
                       $("#message").hide();
                       $.each(resp, function() {
                            $.each(this, function(i, tweet) {
                                arrayTweets.push(tweet);
                            });

                        });

                        displayTweets();
                    },
                    error: function(resp, status, xhr){
                        $("#message").html("ERROR: " + xhr.status + " " + xhr.statusText + "\n" + resp.e);
                        $("#message").show();
                    }
                });

以下是回复中的内容:

{"tweet":[{"text":"RT @OSCARHAROTASEND: MUYYY CONTENTO Y MUYYY ORGULLOSO del trabajo d mi hermanito @pablonieto22 en la presentación d su TEAM @CalvoTeam anoc…","user":"Jemurillove"}]}

任何人都有一个线索,我这半天一直在争吵。

感谢任何帮助。

谢谢,

修改

这是我的资源,如果可以提供帮助的话。 Tweet对象使用@XmlRootElement注释:

@GET
    @XmlElement(name = "tweet")
    @Path("/retrieveTweets")
    @Produces(MediaType.APPLICATION_JSON)
    public List<Tweet> retrieve(@QueryParam("lat") Double Latitude, @QueryParam("lon") Double Longitude, @QueryParam("rad") Double Radius, @QueryParam("from") String From, @QueryParam("to") String To) {
        //List<Status> tweets = null;
        List<Tweet> lTweets = new ArrayList<Tweet>();
        boolean status = false;

        Twitter twitter = new TwitterFactory().getInstance();

        AccessToken accessToken = new AccessToken(TwitterInterface.ACCESS_TOKEN, TwitterInterface.ACCESS_TOKEN_SECRET);
        twitter.setOAuthConsumer(TwitterInterface.CONSUMER_KEY, TwitterInterface.CONSUMER_SECRET);
        twitter.setOAuthAccessToken(accessToken);

        try {
            Query query = new Query("");
            GeoLocation geo =  new GeoLocation(Latitude, Longitude);
            query.setGeoCode(geo, Radius/1000, Query.KILOMETERS);
            query.setCount(100);
            query.setSince(From);
            query.setUntil(To);
            QueryResult result;
            result = twitter.search(query);
            List<Status>tweets = result.getTweets();
            for (Status tweet : tweets) {
                System.out.println("@" + tweet.getUser().getScreenName() + " - " + tweet.getText() + " - " + tweet.getCreatedAt());
                Tweet t = new Tweet();
                t.setUser(tweet.getUser().getScreenName());
                t.setText(tweet.getText());
                lTweets.add(t);
            }
        }
        catch (TwitterException te) {
            te.printStackTrace();
            System.out.println("Failed to search tweets: " + te.getMessage());
            System.exit(-1);
        }

        return lTweets;

1 个答案:

答案 0 :(得分:3)

您正在请求jsonp响应,但响应是纯JSON。

您可以将请求类型更改为“JSON” - 如果请求不会违反跨域限制,或者更改生成响应的任何内容以将响应包装为JSONP。

有关JSONP的更多信息,请查看jQuery docs

总之,jQuery会自动将callback=?参数添加到它请求的url中。您的服务器端代码需要使用该参数的值作为您的响应应该使用作为参数传递的JSON调用的javascript函数的名称。

例如,如果callback=helloWorld,您的回复应为:

helloWorld({"tweet": ... });