android - Tumblr API - 适用于 Android 的 Jumblr [OAuthConnectionException]

标签 android oauth tumblr

我意识到 Jumblr,一个适用于 Android 的 Tumblr APi 并没有很好地记录我们如何真正着手实现它。我已经在我的应用程序上成功授权了我的帐户。就这样。根据Jumblr's README , 你所要做的就是

JumblrClient client = new JumblrClient("consumer_key", "consumer_secret");
client.setToken("oauth_token", "oauth_token_secret");

在我的应用程序中已经设置了消费者 key 和 secret ,并且 oauth_token 和 token_secret 是在用户登录时由应用程序获取的。 但是,我收到类似

的错误
org.scribe.exceptions.OAuthConnectionException: There was a problem while creating a connection to the remote service.

完整的日志:

08-12 19:55:03.212: E/AndroidRuntime(27896): FATAL EXCEPTION: main
08-12 19:55:03.212: E/AndroidRuntime(27896): java.lang.RuntimeException: Unable to start activity ComponentInfo{dev.example.tumblr/dev.example.tumblr.MainActivity}: org.scribe.exceptions.OAuthConnectionException: There was a problem while creating a connection to the remote service.
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2308)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2358)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.app.ActivityThread.access$600(ActivityThread.java:153)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1247)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.os.Handler.dispatchMessage(Handler.java:99)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.os.Looper.loop(Looper.java:137)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.app.ActivityThread.main(ActivityThread.java:5227)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at java.lang.reflect.Method.invokeNative(Native Method)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at java.lang.reflect.Method.invoke(Method.java:511)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:795)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at dalvik.system.NativeStart.main(Native Method)
08-12 19:55:03.212: E/AndroidRuntime(27896): Caused by: org.scribe.exceptions.OAuthConnectionException: There was a problem while creating a connection to the remote service.
08-12 19:55:03.212: E/AndroidRuntime(27896):    at org.scribe.model.Request.send(Request.java:70)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at org.scribe.model.Request.send(Request.java:76)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at dev.example.tumblr.library.request.RequestBuilder.get(RequestBuilder.java:71)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at dev.example.tumblr.library.JumblrClient.user(JumblrClient.java:65)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at dev.example.tumblr.MainActivity.onCreate(MainActivity.java:59)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.app.Activity.performCreate(Activity.java:5104)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2262)
08-12 19:55:03.212: E/AndroidRuntime(27896):    ... 11 more
08-12 19:55:03.212: E/AndroidRuntime(27896): Caused by: android.os.NetworkOnMainThreadException
08-12 19:55:03.212: E/AndroidRuntime(27896):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at java.net.InetAddress.getAllByName(InetAddress.java:214)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpConnection.<init>(HttpConnection.java:70)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpConnection.<init>(HttpConnection.java:50)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpConnection$Address.connect(HttpConnection.java:340)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpConnectionPool.get(HttpConnectionPool.java:87)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpConnection.connect(HttpConnection.java:128)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpEngine.openSocketConnection(HttpEngine.java:316)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpEngine.connect(HttpEngine.java:311)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpEngine.sendSocketRequest(HttpEngine.java:290)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpEngine.sendRequest(HttpEngine.java:240)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at libcore.net.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:81)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at org.scribe.model.Response.<init>(Response.java:29)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at org.scribe.model.Request.doSend(Request.java:117)
08-12 19:55:03.212: E/AndroidRuntime(27896):    at org.scribe.model.Request.send(Request.java:66)

我知道我必须用 Oauth 做点什么。但它是什么?我之前对 Twitter 的 Oauth 经验不多。

提前致谢。

最佳答案

问题出在 NetworkOnMainThreadException 而不是 OAuth。从 Android 3.0 开始,所有网络操作都必须在后台线程上运行。将您对 Jumblr 的调用放在 AsyncTask 或类似的东西中。

关于android - Tumblr API - 适用于 Android 的 Jumblr [OAuthConnectionException],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18186478/

相关文章:

android - 复制android项目的最快方法?

android - 使用按钮在 Android 上从布局 1 更改为布局 2

android - Cordova - 启动后出现白屏,控制台中没有异常

c# - 推特,Oauth,关注用户

oauth2服务器用户注册

Tumblr - 缺少关注、仪表板和自定义控制按钮 - 未显示在右上角

安卓工作室 : Failed to find: 'com.android.support:support-v4:19.1.0'

android - 使用 SignPost 在 Android 中登录 Tumblr

python - Tumblr API v2 的 "Default callback URL:"是什么?

c# - C# 中是否有任何 JSON Web token (JWT) 示例?