我試圖將twitter與我的應用在Android中集成。我試着在這裏給出的androidHive指南http://goo.gl/VF4PkTwitter與Android的集成
我每次點擊登錄按鈕時都會收到下面的錯誤消息。
06-24 08:58:09.659: E/AndroidRuntime(30667): FATAL EXCEPTION: main
06-24 08:58:09.659: E/AndroidRuntime(30667): Process: com.example.testoauthtweets, PID: 30667
06-24 08:58:09.659: E/AndroidRuntime(30667): android.os.NetworkOnMainThreadException
06-24 08:58:09.659: E/AndroidRuntime(30667): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1145)
06-24 08:58:09.659: E/AndroidRuntime(30667): at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
06-24 08:58:09.659: E/AndroidRuntime(30667): at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
06-24 08:58:09.659: E/AndroidRuntime(30667): at java.net.InetAddress.getAllByName(InetAddress.java:214)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.Dns$1.getAllByName(Dns.java:28)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:216)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.http.RouteSelector.next(RouteSelector.java:122)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:292)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.http.HttpEngine.sendSocketRequest(HttpEngine.java:255)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:206)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:345)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:89)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.okhttp.internal.http.HttpURLConnectionImpl.getOutputStream(HttpURLConnectionImpl.java:197)
06-24 08:58:09.659: E/AndroidRuntime(30667): at twitter4j.internal.http.HttpClientImpl.request(HttpClientImpl.java:150)
06-24 08:58:09.659: E/AndroidRuntime(30667): at twitter4j.internal.http.HttpClientWrapper.request(HttpClientWrapper.java:61)
06-24 08:58:09.659: E/AndroidRuntime(30667): at twitter4j.internal.http.HttpClientWrapper.post(HttpClientWrapper.java:98)
06-24 08:58:09.659: E/AndroidRuntime(30667): at twitter4j.auth.OAuthAuthorization.getOAuthRequestToken(OAuthAuthorization.java:122)
06-24 08:58:09.659: E/AndroidRuntime(30667): at twitter4j.auth.OAuthAuthorization.getOAuthRequestToken(OAuthAuthorization.java:104)
06-24 08:58:09.659: E/AndroidRuntime(30667): at twitter4j.TwitterBaseImpl.getOAuthRequestToken(TwitterBaseImpl.java:281)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.example.testoauthtweets.MainActivity.loginToTwitter(MainActivity.java:189)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.example.testoauthtweets.MainActivity.access$1(MainActivity.java:175)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.example.testoauthtweets.MainActivity$1.onClick(MainActivity.java:123)
06-24 08:58:09.659: E/AndroidRuntime(30667): at android.view.View.performClick(View.java:4438)
06-24 08:58:09.659: E/AndroidRuntime(30667): at android.view.View$PerformClick.run(View.java:18422)
06-24 08:58:09.659: E/AndroidRuntime(30667): at android.os.Handler.handleCallback(Handler.java:733)
06-24 08:58:09.659: E/AndroidRuntime(30667): at android.os.Handler.dispatchMessage(Handler.java:95)
06-24 08:58:09.659: E/AndroidRuntime(30667): at android.os.Looper.loop(Looper.java:136)
06-24 08:58:09.659: E/AndroidRuntime(30667): at android.app.ActivityThread.main(ActivityThread.java:5001)
06-24 08:58:09.659: E/AndroidRuntime(30667): at java.lang.reflect.Method.invoke(Native Method)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
06-24 08:58:09.659: E/AndroidRuntime(30667): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
在這裏,我得到的錯誤:
private void loginToTwitter() {
// Check if already logged in
if (!isTwitterLoggedInAlready())
{
ConfigurationBuilder builder = new ConfigurationBuilder();
builder.setOAuthConsumerKey(TWITTER_CONSUMER_KEY);
builder.setOAuthConsumerSecret(TWITTER_CONSUMER_SECRET);
Configuration configuration = builder.build();
TwitterFactory factory = new TwitterFactory(configuration);
twitter = factory.getInstance();
try {
requestToken = twitter
.getOAuthRequestToken(TWITTER_CALLBACK_URL);
this.startActivity(new Intent(Intent.ACTION_VIEW, Uri
.parse(requestToken.getAuthenticationURL())));
} catch (TwitterException e) {
e.printStackTrace();
}
}
else
{
// user already logged into twitter
Toast.makeText(getApplicationContext(),
"Already Logged into twitter", Toast.LENGTH_LONG).show();
}
}
更新1:
我的庫文件更新到最新版本。現在,我可以在登錄後獲取登錄屏幕,並接受它返回到我的應用程序的訪問權限,但它始終顯示登錄錯誤 - NULL。看起來訪問令牌沒有得到更新或接受。
有人可以幫我嗎?
謝謝!
這是第189行?請告訴我? – Kishan
TwitterFactory factory = new TwitterFactory(configuration); \t \t \t twitter = factory.getInstance(); – TheDevMan