作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我一直在尝试从我的 Android 应用程序中集成 Login LInkedIn。到目前为止,我已经进行了搜索,但关于如何进行搜索的示例有限。但这个问题的一个很好的答案 Posting LinkedIn message from Android application给了我一个先机。
但是当我运行它时。它会将我带到登录屏幕,然后当我输入我的凭据并按“登录并允许”时,它会在浏览器中执行某些操作但没有任何反应。它既不登录也不返回我的应用程序。
这是我的代码:
final SharedPreferences pref = getSharedPreferences(OAUTH_PREF,
MODE_PRIVATE);
final String token = pref.getString(PREF_TOKEN, null);
final String tokenSecret = pref.getString(PREF_TOKENSECRET, null);
if (token == null || tokenSecret == null) {
new AsyncTask<Void, Void, LinkedInRequestToken>() {
@Override
protected LinkedInRequestToken doInBackground(Void... params) {
return oAuthService.getOAuthRequestToken(OAUTH_CALLBACK_URL);
}
@Override
protected void onPostExecute(LinkedInRequestToken liToken) {
final String uri = liToken.getAuthorizationUrl();
getSharedPreferences(OAUTH_PREF, MODE_PRIVATE)
.edit()
.putString(PREF_REQTOKENSECRET,
liToken.getTokenSecret()).commit();
Intent i = new Intent(Intent.ACTION_VIEW, Uri.parse(uri));
startActivity(i);
}
}.execute();
} else {
showCurrentUser(new LinkedInAccessToken(token, tokenSecret));
}final LinkedInOAuthService oAuthService = LinkedInOAuthServiceFactory
.getInstance().createLinkedInOAuthService(CONSUMER_KEY,
CONSUMER_SECRET);
//////////////////////////剩余代码//////////////////
void finishAuthenticate(final Uri uri) {
if (uri != null && uri.getScheme().equals(OAUTH_CALLBACK_SCHEME)) {
final String problem = uri.getQueryParameter(OAUTH_QUERY_PROBLEM);
if (problem == null) {
new AsyncTask<Void, Void, LinkedInAccessToken>() {
@Override
protected LinkedInAccessToken doInBackground(Void... params) {
final SharedPreferences pref = getSharedPreferences(
OAUTH_PREF, MODE_PRIVATE);
final LinkedInAccessToken accessToken = oAuthService
.getOAuthAccessToken(
new LinkedInRequestToken(
uri.getQueryParameter(OAUTH_QUERY_TOKEN),
pref.getString(
PREF_REQTOKENSECRET,
null)),
uri.getQueryParameter(OAUTH_QUERY_VERIFIER));
pref.edit()
.putString(PREF_TOKEN, accessToken.getToken())
.putString(PREF_TOKENSECRET,
accessToken.getTokenSecret())
.remove(PREF_REQTOKENSECRET).commit();
return accessToken;
}
@Override
protected void onPostExecute(LinkedInAccessToken accessToken) {
showCurrentUser(accessToken);
}
}.execute();
} else {
Toast.makeText(this,
"Appliaction down due OAuth problem: " + problem,
Toast.LENGTH_LONG).show();
finish();
}
}
}
void clearTokens() {
getSharedPreferences(OAUTH_PREF, MODE_PRIVATE).edit()
.remove(PREF_TOKEN).remove(PREF_TOKENSECRET)
.remove(PREF_REQTOKENSECRET).commit();
}
void showCurrentUser(final LinkedInAccessToken accessToken) {
final LinkedInApiClient client = factory
.createLinkedInApiClient(accessToken);
new AsyncTask<Void, Void, Object>() {
@Override
protected Object doInBackground(Void... params) {
try {
final Person p = client.getProfileForCurrentUser();
// /////////////////////////////////////////////////////////
// here you can do client API calls ...
// client.postComment(arg0, arg1);
// client.updateCurrentStatus(arg0);
// or any other API call
// (this sample only check for current user
// and pass it to onPostExecute)
// /////////////////////////////////////////////////////////
return p;
} catch (LinkedInApiClientException ex) {
return ex;
}
}
@Override
protected void onPostExecute(Object result) {
if (result instanceof Exception) {
//result is an Exception :)
final Exception ex = (Exception) result;
clearTokens();
Toast.makeText(
getApplicationContext(),
"Appliaction down due LinkedInApiClientException: "
+ ex.getMessage()
+ " Authokens cleared - try run application again.",
Toast.LENGTH_LONG).show();
finish();
} else if (result instanceof Person) {
final Person p = (Person) result;
Toast.makeText(
getApplicationContext(),p.getLastName() + ", " + p.getFirstName(),
Toast.LENGTH_LONG).show();
}
}
}.execute();
}
////我的应用程序的结束日志是///////////
08-23 12:31:34.010 32724-32728/com.example.montovaapp D/-heap﹕ GC_CONCURRENT freed 251K, 5% free 8598K/9031K, paused 12ms+154ms, total 221ms
08-23 12:31:35.790 32724-32728/com.example.montovaapp D/-heap﹕ GC_CONCURRENT freed 857K, 12% free 8231K/9287K, paused 12ms+156ms, total 215ms
08-23 12:31:37.290 32724-32728/com.example.montovaapp D/-heap﹕ GC_CONCURRENT freed 261K, 10% free 8383K/9287K, paused 12ms+33ms, total 69ms
08-23 12:31:39.410 32724-32728/com.example.montovaapp D/-heap﹕ GC_CONCURRENT freed 255K, 9% free 8526K/9287K, paused 12ms+14ms, total 50ms
08-23 12:31:43.160 32724-32724/com.example.montovaapp W/IInputConnectionWrapper﹕ showStatusIcon on inactive InputConnection
请注意使用 Android Studio 进行 em 编程
问候
最佳答案
对不起,但也许使用 ASNE library和 asne-linkedin让你的生活更轻松?只需向您的项目添加依赖项:
dependencies {
...
compile 'com.github.asne:asne-linkedin:0.2.0'
...
}
像这样设置和请求登录
socialNetwork.requestLogin();
并且您可以轻松添加另一个社交网络或其他请求...
关于android - 无法通过登录屏幕 LinkedIn。在将我的应用程序链接到 LinkedIn 时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25459589/
我是一名优秀的程序员,十分优秀!