在我整合facebook登录的应用程序中,facebook登录工作正常,但要求登录时间。
我通过Facebook登录正常工作,在我的应用程序中使用应用程序请求,而应用程序请求也要求登录facebook。
我想避免告诉我这样做的一些想法,
我的登录代码:
Session.openActiveSession(Notication_Webview.this, true, new Session.StatusCallback() {
@Override
public void call(final Session session, SessionState state, Exception exception) {
// TODO Auto-generated method stub
if(session.isOpened()){
Request.executeMeRequestAsync(session, new Request.GraphUserCallback() {
@Override
public void onCompleted(GraphUser user, Response response) {
// TODO Auto-generated method stub
if(user!=null){
try{
userName=user.getFirstName();//obj.getString("first_name");
facebookId=user.getId();//obj.getString("id");
}catch (Exception e) {
Log.e(tag, "getUserIdMethod--->"+e);
}
}
}
});
}
}
});
在此应用程序请求代码中,
Session session = Session.getActiveSession();
Facebook mFb = new Facebook("app id");
Bundle params = new Bundle();
params.putString("to", userIDString);
params.putString("message", Message);
mFb.dialog(this.getParent(), "apprequests",
params, new DialogListener() {
public void onComplete(Bundle values) {
// TODO Auto-generated method stub
}
public void onFacebookError(FacebookError e) {
// TODO Auto-generated method stub
}
public void onError(DialogError e) {
// TODO Auto-generated method stub
}
public void onCancel() {
// TODO Auto-generated method stub
}
});
mFb.dialod方法:
@Deprecated
public void dialog(Context context, String action, Bundle parameters, final DialogListener listener) {
parameters.putString("display", "touch");
parameters.putString("redirect_uri", REDIRECT_URI);
if (action.equals(LOGIN)) {
parameters.putString("type", "user_agent");
parameters.putString("client_id", mAppId);
} else {
parameters.putString("app_id", mAppId);
// We do not want to add an access token when displaying the auth dialog.
if (isSessionValid()) {
parameters.putString(TOKEN, getAccessToken());
}
}
if (context.checkCallingOrSelfPermission(Manifest.permission.INTERNET) != PackageManager.PERMISSION_GRANTED) {
Util.showAlert(context, "Error", "Application requires permission to access the Internet");
} else {
new FbDialog(context, action, parameters, listener).show();
}
}
告诉我如何避免第二次登录。
答案 0 :(得分:4)
用户登录后,获取访问权限并使用SharedPreferences将其保存在您的设备中。
下次用户打开您的应用时,请打开您的SharedPreference文件并从那里检索访问令牌的值。
从存储中检索值后,使用 isSessionValid()
检查会话是否仍然有效。
如果会话仍然有效,则直接登录用户(不再询问详细信息),并确保在登录时在SharedPreferences中更新访问令牌的值。每次用户登录时,访问令牌的到期时间都会延长。
此外,当用户退出时,请不要忘记 clear()
SharedPreference文件。
答案 1 :(得分:0)
当您登录会话时将打开,此时取一个静态标志并更新。检查标志后,请转到isSession()。 再次注销时重置静态标志。
答案 2 :(得分:-3)
当用户登录时,然后在某处存储用户名和密码。你可以使用SQLite。如果hw退出,就破坏它。当用户再次打开应用程序时,检查数据库中是否有数据。如果是,则直接将其传递给Facebook,否则请用户再次登录。