2013-07-25 35 views
3

Im新的phonegap,android和facebook,我想添加一個登錄使用Facebook。致命的例外 - cordova.facebook.ConnectPlugin

我做了所有的步驟按照Facebook的入門指南適用於Android,

得到這個錯誤:

07-25 09:52:24.470: E/AndroidRuntime(1284): FATAL EXCEPTION: main 
07-25 09:52:24.470: E/AndroidRuntime(1284): java.lang.NullPointerException 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at org.apache.cordova.facebook.ConnectPlugin$AuthorizeListener.onComplete(ConnectPlugin.java:277) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at com.facebook.android.Facebook.onSessionCallback(Facebook.java:345) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at com.facebook.android.Facebook.access$11(Facebook.java:326) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at com.facebook.android.Facebook$1.call(Facebook.java:304) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at com.facebook.Session$3$1.run(Session.java:1190) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at android.os.Handler.handleCallback(Handler.java:725) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at android.os.Handler.dispatchMessage(Handler.java:92) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at android.os.Looper.loop(Looper.java:137) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at android.app.ActivityThread.main(ActivityThread.java:5041) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at java.lang.reflect.Method.invokeNative(Native Method) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at java.lang.reflect.Method.invoke(Method.java:511) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 
07-25 09:52:24.470: E/AndroidRuntime(1284):  at dalvik.system.NativeStart.main(Native Method) 

什麼想法?感謝..

回答

0

ConnectPlugin.java,替換:

try { 
    JSONObject o = new JSONObject(this.fba.facebook.request("/me")); 
    this.fba.userId = o.getString("id"); 
    this.fba.success(getResponse(), this.fba.callbackId); 
} catch (MalformedURLException e) { 
    // TODO Auto-generated catch block 
    e.printStackTrace(); 
} catch (IOException e) { 
    // TODO Auto-generated catch block 
    e.printStackTrace(); 
} catch (JSONException e) { 
    // TODO Auto-generated catch block 
    e.printStackTrace(); 
} 

用下面的代碼:

Thread t = new Thread(new Runnable() { 
    public void run() { 
     try { 
      JSONObject o = new JSONObject(fba.facebook.request("/me")); 
      fba.userId = o.getString("id"); 
      fba.success(getResponse(), fba.callbackId); 
     } catch (MalformedURLException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } catch (IOException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } catch (JSONException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
    } 
}); 
t.start(); 

價:NetworkOnMainThreadException on Facebook Login with Phonegap 1.6.0

+2

感謝您的答覆。我看着ConnectPlugin.java,但代碼已經在那裏:public void onComplete(Bundle values) – user2618162

+0

這裏同樣的問題。我認爲問題是手機插件是使用這麼多不贊成的Facebook的API。 –

0

註釋掉線277的org.apache.cordova.facebook.ConnectPlugin.java

//Log.d(TAG, values.toString()); 

它只是一個日誌到控制檯