我有一个登录/注销系统,用户可以通过facebook或我们自己的mysql数据库登录。
当用户成功登录时,保存完毕:
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
SharedPreferences.Editor editor = settings.edit();
editor.putBoolean("loggedIn", true);
editor.putString("email", EMAIL);
editor.putString("password", PASSWORD);
editor.putInt("USERID", Integer.parseInt((String) product.get("ProfileID")));
editor.commit();
然后我有一个启动页面,检查用户是否已登录:
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
boolean loggedin = settings.getBoolean("loggedIn", false);
if (loggedin) {
Intent intent = new Intent(this, LoggedIn.class);
startActivity(intent);
} else {
Intent intent = new Intent(this, LogIn.class);
startActivity(intent);
}
然后当用户退出时:
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
SharedPreferences.Editor editor = settings.edit();
editor.putBoolean("loggedIn", false);
editor.putString("email", "");
editor.putString("password", "");
editor.commit();
db.clearLists();
db.clearProducts();
Intent intent = new Intent(v.getContext(), Splash.class);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP );
v.getContext().startActivity(intent);
这似乎工作正常,即用户注销并被发送回登录页面,并且所有数据都已从应用程序中清除。
然而,有些用户报告说,如果他们关闭应用程序并返回它,他们实际上仍然登录。 我不能复制这个,所以想知道是否有人有任何关于如何改进我的登录/退出系统以改进它并防止这种情况的意见。
答案 0 :(得分:0)
你的代码看起来不错。但我想你可以将你的登录名转移到sqlite db。将它们保存到db并从db检索登录信息。这是一个快速的脏修复;)
答案 1 :(得分:0)
最好在注销时刷新共享首选项,登录时检查是否存在共享首选项,然后以其他方式将用户重定向到登录页面。