0

我有一个登录/注销系统,用户可以通过 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);

这似乎工作正常,即用户注销并被发送回登录页面,并且他们的所有数据都已从应用程序中清除。

然而,一些用户报告说,如果他们关闭应用程序并返回它,他们实际上仍然登录。我无法复制这一点,所以想知道是否有人对如何改进我的登录/退出系统有任何意见以改进它并防止这个。

4

2 回答 2

0

最好在注销时刷新您的共享首选项,并在登录时检查共享首选项是否存在然后登录,否则将用户重定向到登录页面。

于 2013-10-06T10:54:55.583 回答
0

你的代码看起来不错。但我想您可以将登录名转移到 sqlite 数据库。将它们保存到数据库并从数据库检索登录信息。这是一个快速的肮脏修复;)

于 2013-10-06T10:47:44.260 回答