我们在一个app中经常看到这样一个功能,当我们第一次进入一个app时,会要求先登录,然后下次再进入时,就不需要登录了,直接进入主页,这个功能就是android 项目开发中经常会涉及到自动登录的功能,涉及到的知识点是SharePrefences。
SharePrefences是用来保存android中的少量数据用的,保存的数据是简单的key-value键值对。SharePrefences负责根据key读取数据,SharePrefences.editor主要用于写入数据。在项目中,我们一般使用SharePrefences实现自动登录的功能,在登录成功后,将数据(用户名,密码)保存在SharePrefences中,然后再次进入app时,判断SharePrefences中有无数据,有的话就跳到主页面,没有的话就跳到登录页。
下面就简单的实现在项目中的自动登录功能,
首先,在项目中有个SplashActivity,作为项目启动的Activity,然后在这个Activity中判断是否SharePrefences有数据,根据判断跳转到不同的页面。界面
/**
* 启动页,app刚打开时的activity
* create by linbin
*/
public class SplashActivity extends Activity {
private static final int GO_HOME = 0;//去主页
private static final int GO_LOGIN = 1;//去登录页
/**
* 跳转判断
*/
private Handler mHandler = new Handler() {
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case GO_HOME://去主页
Intent intent = new Intent(SplashActivity.this, HomeActivity.class);
startActivity(intent);
finish();
break;
case GO_LOGIN://去登录页
Intent intent2 = new Intent(SplashActivity.this, LoginActivity.class);
startActivity(intent2);
finish();
break;
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_splash);
if (UserManage.getInstance().hasUserInfo(this))//自动登录判断,SharePrefences中有数据,则跳转到主页,没数据则跳转到登录页
{
mHandler.sendEmptyMessageDelayed(GO_HOME, 2000);
} else {
mHandler.sendEmptyMessageAtTime(GO_LOGIN, 2000);
}
}
}
activity_splash.xml 启动页的布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<TextView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:text="这是启动页"/>
</RelativeLayout>
登录页面,在登录完成后,将用户名,密码保存在SharePrefences中,界面
/**
* 登录页面
* create by linbin
*/
public class LoginActivity extends Activity {
/**
* 用户名
*/
private EditText edt_username;
/**
* 密码
*/
private EditText edt_password;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
initViews();
}
private void initViews() {
edt_username = (EditText) findViewById(R.id.edt_username);
edt_password = (EditText) findViewById(R.id.edt_password);
findViewById(R.id.btn_login).setOnClickListener(mOnClickListener);
}
private View.OnClickListener mOnClickListener = new View.OnClickListener() {
@Override
public void onClick(View view) {
switch (view.getId()) {
case R.id.btn_login://登录
String userName = edt_username.getText().toString();
String userPwd = edt_password.getText().toString();
UserManage.getInstance().saveUserInfo(LoginActivity.this, userName, userPwd);
Toast.makeText(LoginActivity.this, "登录成功", Toast.LENGTH_SHORT).show();
Intent intent = new Intent(LoginActivity.this, HomeActivity.class);//跳转到主页
startActivity(intent);
finish();
break;
}
}
};
}
activity_login.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
>
<EditText
android:id="@+id/edt_username"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="15dp"
android:layout_marginRight="15dp"
android:layout_marginTop="15dp"
android:hint="用户名"/>
<EditText
android:id="@+id/edt_password"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="15dp"
android:layout_marginRight="15dp"
android:layout_marginTop="15dp"
android:hint="密码"/>
<Button
android:id="@+id/btn_login"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:text="登录"/>
</LinearLayout>
/**
* 保存用户信息的管理类
* Created by libin
*/
public class UserManage {
private static UserManage instance;
private UserManage() {
}
public static UserManage getInstance() {
if (instance == null) {
instance = new UserManage();
}
return instance;
}
/**
* 保存自动登录的用户信息
*/
public void saveUserInfo(Context context, String username, String password) {
SharedPreferences sp = context.getSharedPreferences("userInfo", Context.MODE_PRIVATE);//Context.MODE_PRIVATE表示SharePrefences的数据只有自己应用程序能访问。
SharedPreferences.Editor editor = sp.edit();
editor.putString("USER_NAME", username);
editor.putString("PASSWORD", password);
editor.commit();
}
/**
* 获取用户信息model
*
* @param context
* @param
* @param
*/
public UserInfo getUserInfo(Context context) {
SharedPreferences sp = context.getSharedPreferences("userInfo", Context.MODE_PRIVATE);
UserInfo userInfo = new UserInfo();
userInfo.setUserName(sp.getString("USER_NAME", ""));
userInfo.setPassword(sp.getString("PASSWORD", ""));
return userInfo;
}
/**
* userInfo中是否有数据
*/
public boolean hasUserInfo(Context context) {
UserInfo userInfo = getUserInfo(context);
if (userInfo != null) {
if ((!TextUtils.isEmpty(userInfo.getUserName())) && (!TextUtils.isEmpty(userInfo.getPassword()))) {//有数据
return true;
} else {
return false;
}
}
return false;
}
}
/**
* 用户信息model
* craeate by libin
*/
public class UserInfo {
/**
* 用户名
*/
private String userName;
/**
* 密码
*/
private String password;
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
}
主页界面
/**
* 主页界面
*/
public class HomeActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
}
}
activity_home.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<TextView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:text="这是主页"/>
</RelativeLayout>
最后奉上项目源码:点击源码