最近在开发一个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打交道多年的老司机~)

更多相关文章

  1. android 学习七 一些xml layout组件的说明(自己总结不断更新)
  2. 源码的完全解析:Android的消息机制
  3. android线程 Handler Message Queue AsyncTask
  4. Android登录注册功能封装
  5. Android(安卓)NDK——必知必会之JNI和NDK基础全面详解(二)
  6. android 设置Alpha值实现图片渐变效果
  7. Android(安卓)开发 voip/sip 程序
  8. Android(安卓)强指针和弱指针
  9. Android踩坑日记:Android动态权限分析和解决方案

随机推荐

  1. Android(安卓)IPC 通讯机制源码分析 二
  2. linux下搭建android NDK开发环境
  3. 在 Android(安卓)上使用 XML
  4. 【30篇突击 android】源码统计八
  5. android 注册页面实现
  6. Android(安卓)横竖屏切换
  7. 如何进行Android单元测试
  8. android获取屏幕分辨率大小(DisplayMetri
  9. WARNING: APP_PLATFORM android-14 is la
  10. Android(安卓)文件实现断点上传