从android中的url获取json的问题

时间:2013-09-25 06:30:31

标签: android json

我开发了一个应用程序,通过facebook url从json获取数据: https://www.facebook.com/feeds/page.php?id=105310924507&format=json

问题在于,有时它会成功获取数据而没有任何问题,有时它会显示我们的错误消息:不幸的是,应用程序已停止!

我不知道问题是什么,我尝试了很多

这是我的代码:

Json Config

package com.engahmedphp.facebookcollector;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.ParseException;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpUriRequest;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import org.json.JSONException;
import org.json.JSONObject;

import android.util.Log;

public class JSONParser {

    static InputStream is = null;
    static JSONObject jObj = null;
    static String json = "";

    // constructor
    public JSONParser() {

    }

 // ==============================================================================
    public JSONObject getJSONFromUrl(String url) {

        // Making HTTP request
//        try {
            // defaultHttpClient
//            DefaultHttpClient httpClient = new DefaultHttpClient();
////            HttpFeed httpFeed = new HttpFeed(url);
//            
//            HttpGet httpGet = new HttpGet(url);
// 
//            HttpResponse httpResponse = httpClient.execute(httpGet);
//            HttpEntity httpEntity = httpResponse.getEntity();
//            is = httpEntity.getContent();           


             HttpClient httpClient = new DefaultHttpClient();
            // HttpFeed httpFeed = new HttpFeed(url);

             HttpUriRequest httpGet = new HttpGet(url);
             HttpResponse httpResponse = null;
             try {
             httpResponse = httpClient.execute(httpGet);


        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (ClientProtocolException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }


        try {
             HttpEntity httpEntity = httpResponse.getEntity();
//            BufferedReader reader = new BufferedReader(new InputStreamReader(
//                    is, "UTF-8"), 8);
//            StringBuilder sb = new StringBuilder();
//            String line = null;
//            while ((line = reader.readLine()) != null) {
//                sb.append(line + "\n");
//            }
//            is.close();
            json = EntityUtils.toString(httpEntity);
        } catch (ParseException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        // try parse the string to a JSON object
        try {
            jObj = new JSONObject(json);
        } catch (JSONException e) {
            Log.e("JSON Parser", "Error parsing data " + e.toString());
        }

        // return JSON String
        return jObj;

    }
}

获取数据的方法

public void getNewFeeds() {

        String url = "https://www.facebook.com/feeds/page.php?id=" + fpageid
                + "&format=json";
        try {
        // Creating JSON Parser instance
        JSONParser jParser = new JSONParser();
    // getting JSON string from URL
    JSONObject json = jParser.getJSONFromUrl(url);


        // Getting Array of Contacts
        entries = json.getJSONArray("entries");

        // looping through All Contacts
        for (int i = entries.length() - 1; i >= 0; i--) {

            JSONObject e = entries.getJSONObject(i);

            if (!dbPages.checkFeed(e.getString("id"))) {
                // Storing each json item in variable
                String fid = e.getString("id");

                String title = Html.fromHtml(e.getString("title"))
                        .toString();
                String content = e
                        .getString("content")
                        .replaceAll(
                                "<img[^>]*?src\\s*=\\s*['\"]([^'\"]*?)['\"][^>]*?/?>",
                                "").toString();
                // String content = e.getString("content").toString();
                //
                // Document doc = Jsoup.parse(content);
                // Element imgs = doc.select("img").first();
                // imgs.outerHtml();
                //
                // String src = img.attr("src");
                Pattern p = Pattern
                        .compile("<img[^>]*?src\\s*=\\s*['\"]([^'\"]*?)['\"][^>]*?/?>");
                Matcher m = p.matcher(e.getString("content"));

                String img = "";
                if (m.find()) {                     
                    img = m.group(0);
                }

                dbPages.addFeed(fid, fpageid, title, content, img);
            }

        }
        feedsCount = entries.length();

    } catch (JSONException e) {
        e.printStackTrace();
    }

}

logcat黄色

09-25 08:19:08.859: W/System.err(19351): org.apache.http.conn.HttpHostConnectException: Connection to https://www.facebook.com refused
09-25 08:19:08.874: W/System.err(19351):    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:183)
09-25 08:19:08.874: W/System.err(19351):    at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
09-25 08:19:08.874: W/System.err(19351):    at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
09-25 08:19:08.874: W/System.err(19351):    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
09-25 08:19:08.882: W/System.err(19351):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
09-25 08:19:08.882: W/System.err(19351):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
09-25 08:19:08.882: W/System.err(19351):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
09-25 08:19:08.882: W/System.err(19351):    at com.engahmedphp.facebookcollector.JSONParser.getJSONFromUrl(JSONParser.java:57)
09-25 08:19:08.890: W/System.err(19351):    at com.engahmedphp.facebookcollector.GetFeedsService.getNewFeeds(GetFeedsService.java:217)
09-25 08:19:08.890: W/System.err(19351):    at com.engahmedphp.facebookcollector.GetFeedsService.onHandleIntent(GetFeedsService.java:96)
09-25 08:19:08.890: W/System.err(19351):    at android.app.IntentService$ServiceHandler.handleMessage(IntentService.java:65)
09-25 08:19:08.890: W/System.err(19351):    at android.os.Handler.dispatchMessage(Handler.java:99)
09-25 08:19:08.890: W/System.err(19351):    at android.os.Looper.loop(Looper.java:137)
09-25 08:19:08.898: W/System.err(19351):    at android.os.HandlerThread.run(HandlerThread.java:60)
09-25 08:19:08.898: W/System.err(19351): Caused by: java.net.ConnectException: failed to connect to /31.13.86.16 (port 443): connect failed: ETIMEDOUT (Connection timed out)
09-25 08:19:08.906: W/System.err(19351):    at libcore.io.IoBridge.connect(IoBridge.java:114)
09-25 08:19:08.906: W/System.err(19351):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
09-25 08:19:08.906: W/System.err(19351):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
09-25 08:19:08.906: W/System.err(19351):    at java.net.Socket.connect(Socket.java:842)

红色的logcat

09-25 08:19:08.937: E/SQLiteDatabase(19351): close() was never explicitly called on database '/data/data/com.engahmedphp.facebook/databases/facebook' 
09-25 08:19:08.937: E/SQLiteDatabase(19351): android.database.sqlite.DatabaseObjectNotClosedException: Application did not close the cursor or database object that was opened here
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.database.sqlite.SQLiteDatabase.<init>(SQLiteDatabase.java:2063)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:1117)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:1074)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.database.sqlite.SQLiteDatabase.openOrCreateDatabase(SQLiteDatabase.java:1161)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:826)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:228)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:157)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at com.engahmedphp.facebook.DAOPages.open(DAOPages.java:57)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at com.engahmedphp.facebook.GetFeedsService.onStartCommand(GetFeedsService.java:200)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2373)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.app.ActivityThread.access$1900(ActivityThread.java:128)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1224)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.os.Handler.dispatchMessage(Handler.java:99)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.os.Looper.loop(Looper.java:137)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at android.app.ActivityThread.main(ActivityThread.java:4514)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at java.lang.reflect.Method.invokeNative(Native Method)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at java.lang.reflect.Method.invoke(Method.java:511)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
09-25 08:19:08.937: E/SQLiteDatabase(19351):    at dalvik.system.NativeStart.main(Native Method)
09-25 08:19:08.937: E/AndroidRuntime(19351): FATAL EXCEPTION: IntentService[getFeedsService]
09-25 08:19:08.937: E/AndroidRuntime(19351): java.lang.NullPointerException
09-25 08:19:08.937: E/AndroidRuntime(19351):    at com.engahmedphp.facebook.JSONParser.getJSONFromUrl(JSONParser.java:70)
09-25 08:19:08.937: E/AndroidRuntime(19351):    at com.engahmedphp.facebook.GetFeedsService.getNewFeeds(GetFeedsService.java:217)
09-25 08:19:08.937: E/AndroidRuntime(19351):    at com.engahmedphp.facebook.GetFeedsService.onHandleIntent(GetFeedsService.java:96)
09-25 08:19:08.937: E/AndroidRuntime(19351):    at android.app.IntentService$ServiceHandler.handleMessage(IntentService.java:65)
09-25 08:19:08.937: E/AndroidRuntime(19351):    at android.os.Handler.dispatchMessage(Handler.java:99)
09-25 08:19:08.937: E/AndroidRuntime(19351):    at android.os.Looper.loop(Looper.java:137)
09-25 08:19:08.937: E/AndroidRuntime(19351):    at android.os.HandlerThread.run(HandlerThread.java:60)

提前致谢

1 个答案:

答案 0 :(得分:0)

更改主机,如使用http作为主机

http://www.facebook.com 

而不是

 https://www.facebook.com 

在第二个中你没有关闭光标。首先正确关闭光标。

请确保您的服务器(/31.13.86.16(端口443))处于在线状态。