Android 基于第三方登录(使用Bmob后端云存储数据)实现记忆用户登录、不必重复登录

最近在开发一个Android 社交app,其中引入了第三方登录的接口,数据存储使用Bmob后端云。有个问题曾困扰了我很久,就是记忆用户登录的问题。众所周知,如果是自己的服务器,进行用户登录,其实完全可以记忆用户名密码,实现自动登陆。但是第三方授权的情况下,这种条件也就不成立了。看了一些网上的博文,有说保存token的,更有甚者要开一个后台去监测用户对象。

动动脑子,假如你那边用的是QQ sdk,在登录完之后你需要做什么?

其实,绝大多数情况,在第三方登录之后,第三方授权对象基本就不会再用了(如QQ授权的Tencent对象)。之后的数据就都会存储到后端云里面了。

所以,我们只需要在登录后使用SharedPreferences将用户的openId存储到本地就可以了。这样,在Bmob建表的时候,每个用户则需要一一对应一个openId。这个openId在用户首次第三方登录的时候可以获取。(当然以后也是可以的,只要引入授权就可以)

那么,在用户把应用线程kill掉之后,再次打开应用,在Init界面就可以用SharedPreferences取出openId,去云数据库查询并获取用户对象了。

有人想必会问:那么授权对象怎么处理?(如QQ的Tencent对象)

当我们创建了User之后,如果不再使用授权对象,它就是一种可有可无的存在了。如果用户直接杀掉线程,则授权对象直接销毁。如果用户点击了退出登录的话,首先要清掉本地存储的openId,然后做一个判断,以QQ sdk为例:

 if (mTencent != null && mTencent.isSessionValid()) {
    //如果处于登录状态,就退出登录
    mTencent.logout(getApplicationContext());
 }

就可以了。意思是:你有授权对象,我就给你注销登录。没有,就不用管

希望可以帮到各位!

纯原创。作者:逍子 (一名跟Java打交道多年的老司机~)

你可能感兴趣的:(Android,第三方登录)