Android(安卓)基于第三方登录(使用Bmob后端云存储数据)实现记忆用户登录、不必重复登录
16lz
2021-01-26
最近在开发一个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 学习七 一些xml layout组件的说明(自己总结不断更新)
- 源码的完全解析:Android的消息机制
- android线程 Handler Message Queue AsyncTask
- Android登录注册功能封装
- Android(安卓)NDK——必知必会之JNI和NDK基础全面详解(二)
- android 设置Alpha值实现图片渐变效果
- Android(安卓)开发 voip/sip 程序
- Android(安卓)强指针和弱指针
- Android踩坑日记:Android动态权限分析和解决方案