twitter没有重定向到android应用程序中的回调url
我的目标是允许使用twitter4j登录Twitter 问题是在第64行,它调用了twitter没有重定向到android应用程序中的回调url,android,twitter,callback,twitter4j,Android,Twitter,Callback,Twitter4j,我的目标是允许使用twitter4j登录Twitter 问题是在第64行,它调用了getAuthenticationURl()。当我执行时,它会将我带到登录页面,而不是允许/禁止我的应用访问ppl帐户的页面。 但是,如果我将其更改为getAuthorizationUrl(),则会转到正确的页面 1) 那么这两者的区别是什么呢 2) 这是一个重要的问题。我提供下面的代码 package com.example.twitter; import twitter4j.Twitter; import
getAuthenticationURl()
。当我执行时,它会将我带到登录页面,而不是允许/禁止我的应用访问ppl帐户的页面。但是,如果我将其更改为
getAuthorizationUrl()
,则会转到正确的页面
1) 那么这两者的区别是什么呢
2) 这是一个重要的问题。我提供下面的代码
package com.example.twitter;
import twitter4j.Twitter;
import twitter4j.TwitterException;
import twitter4j.TwitterFactory;
import twitter4j.http.AccessToken;
import twitter4j.http.RequestToken;
import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
public class WriteTweet extends Activity{
public final static String consumerKey = "xxxxxxxxxxxxxxxxxx";
public final static String consumerSecret = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
private final String CALLBACKURL = "T4J_OAuth://callback";
Twitter twitter;
RequestToken requestToken;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
loginUser();
}
private void loginUser() {
// TODO Auto-generated method stub
try {
twitter = new TwitterFactory().getInstance();
twitter.setOAuthConsumer(consumerKey, consumerSecret);
requestToken = twitter.getOAuthRequestToken(CALLBACKURL);
String authUrl = requestToken.getAuthorizationURL();
this.startActivity(new Intent(Intent.ACTION_VIEW, Uri
.parse(authUrl)));
} catch (TwitterException ex) {
Toast.makeText(this, ex.getMessage(), Toast.LENGTH_LONG).show();
Log.e("in Main.OAuthLogin", ex.getMessage());
}
}
@Override
protected void onNewIntent(Intent intent) {
Log.e("hi","hi");
super.onNewIntent(intent);
Uri uri = intent.getData();
try {
String verifier = uri.getQueryParameter("oauth_verifier");
AccessToken accessToken = twitter.getOAuthAccessToken(requestToken,
verifier);
String token = accessToken.getToken(), secret = accessToken
.getTokenSecret();
displayTimeLine(token, secret); //after everything, display the first tweet
} catch (TwitterException ex) {
Log.e("Main.onNewIntent", "" + ex.getMessage());
}
}
@SuppressWarnings("deprecation")
void displayTimeLine(String token, String secret) {
Log.e("display","timeline");
}
}
舱单是
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.twitter"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="15" />
<uses-permission android:name="android.permission.INTERNET"/>
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/title_activity_main" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".ListTweets" >
</activity>
<activity android:name=".WriteTweet">
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="T4J_OAuth" android:host="callback" />
</intent-filter>
</activity>
<activity android:name=".ViewFollowers">
</activity>
</application>
</manifest>
我不知道我做错了什么。无论是使用getAuthenticationUrl()
还是getAuthorizationUrl()
,问题都存在。我在Twitter的callback\uURL
字段中提供了一个虚拟url。
如果我没有在代码和twitter页面中提供callbackurl
,它会给我一个pin码。但这不是我想要的。我需要我的twitter重定向到我的应用程序。如何实现这一点?使用下面的URL作为回调URL
public static final String CALLBACK_URL = "x-oauthflow-twitter://callback";
有关android应用程序中twitter集成的更多信息,请参见下面的链接
这就是我解决问题的方法
创建web视图并从应用程序中加载twitter的确认页面
vw = (WebView)findViewById(R.id.loginView);
vw.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
return super.shouldOverrideUrlLoading(view, url);
}
}); vw.loadUrl(authUrl);
收到回调url后,获取“oauth\u验证程序”
Uri uri = Uri.parse(url);
String verifier = uri.getQueryParameter("oauth_verifier");
使用此验证器获取访问权限并执行所需操作。在我的例子中,我销毁webview并加载我需要的活动
不,它没有按预期工作。现在我在一个回调循环中。它一直重定向到不同的授权页面。@emiljho请查看上面的链接以了解更多信息,它在我的应用程序中工作。这是根据您的博客编写的代码。它不起作用了。我不认为回调url有问题。@emiljho您在哪个API版本上测试这个应用程序?