相信大家都知道,每一个App都需要登录,登录信息都保存在本地文件中,然后我们就写一堆的 *** 作SharedPreferences的代码了。
现在,你可以完全抛弃这种方法,一句代码搞定登录信息,用户信息管理。实现全局 *** 作。为你的程序解耦。
public voID sessionDemo() { // 获取登录信息 TokenInfo token = SessionManager.getDefault().getUserToken(); // 获取用户信息 UserInfo userInfo = SessionManager.getDefault().getUser(); // 是否登录 boolean isLogin = SessionManager.getDefault().isLogin(); // @R_403_6169@ SessionManager.getDefault().clear(); // 登录成功后,设置用户信息 SessionManager.getDefault().setUser(new UserInfo()); // 登录成功后,设置登录信息 SessionManager.getDefault().setUserToken(new TokenInfo()); // 这句请在Application onCreate 的时候调用初始化配置信息 SessionManager.initWithConfig( new SessionManager.ConfigBuilder() .context(this) .tokenClass(TokenInfo.class) .userClass(UserInfo.class) .build()); Log.i("rae","登录信息:" + token); Log.i("rae","用户信息:" + userInfo); Log.i("rae","是否登录:" + isLogin); }
一、设计
抽象工厂模式,整体UML如下图,整体思路为:
抽象出SessionManager类,实际还是PreferencesSessionManager实现了这个抽象类,进行本地SharePreferences保存。
Config:负责维护实体类的class,用来做JsON序列化保存到本地的。这个类起到泛型解析的作用,getUser()返回的对象就由这个类去维护了。从而达到了解耦的作用。
ConfigBuild:构建者模式,提供方便的会话配置。
SessionManager.getDefault(); 默认返回的是PreferencesSessionManager的实例。
二、自定义Sessionmanger
如果不想用SharePreferences来保存用户信息,也可以继承Sessionmanger类实现抽象方法实现自定义的Session管理。
如果你的自定义也想全局访问,那么可以新增一个AppSessionmanger的类,来实现一个单例方法,返回你自定义的实现。
参考Sessionmanger.getDefault()的实现就可以了。
三、 Sessionmanger 代码实现
/** * 会话管理 * Created by ChenRui on 2017/4/28 0028 17:27. */public abstract class SessionManager { public static class Config { Class<?> userTokenClass; Class<?> userClass; Context context; } public static class ConfigBuilder { private final Config mConfig; public ConfigBuilder() { mConfig = new Config(); } public ConfigBuilder tokenClass(Class<?> cls) { mConfig.userTokenClass = cls; return this; } public ConfigBuilder userClass(Class<?> cls) { mConfig.userClass = cls; return this; } public ConfigBuilder context(Context applicationContext) { mConfig.context = applicationContext; return this; } public Config build() { return mConfig; } } private static Config sConfig; private static WeakReference<SessionManager> managerWeakReference; /** * 获取默认的会话管理器,默认的为cookie 管理器。 * 使用之前请使用{@link #initWithConfig(Config)} 来进行初始化配置。 */ public static SessionManager getDefault() { if (sConfig == null) { Log.w("SessionManager","session config from default"); sConfig = new ConfigBuilder().tokenClass(SessionToken.class).userClass(SessionUserInfo.class).build(); } if (managerWeakReference == null || managerWeakReference.get() == null) { synchronized (SessionManager.class) { if (managerWeakReference == null || managerWeakReference.get() == null) { managerWeakReference = new WeakReference<SessionManager>(new PreferencesSessionManager(sConfig)); } } } return managerWeakReference.get(); } /** * 初始化会话管理器 */ public static voID initWithConfig(Config config) { if (sConfig != null) { sConfig = null; System.gc(); } sConfig = config; } SessionManager() { } /** * 是否登录 */ public abstract boolean isLogin(); /** * 清除会话信息,即@R_403_6169@。 */ public abstract voID clear(); /** * 获取当前登录的用户信息,在调用该方法之前请先调用{@link #isLogin()}来判断是否登录 */ public abstract <T> T getUser(); /** * 设置当前用户信息 */ public abstract <T> voID setUser(T user); /** * 设置用户授权信息 * * @param token 授权信息 */ public abstract <T> voID setUserToken(T token); /** * 获取用户授权信息 */ public abstract <T> T getUserToken();}
本文结束,非常简单的实现,但是却非常实用!
GitHub开源:https://github.com/raee/retrofit-ext.git
总结
以上所述是小编给大家介绍的AndroID 用户Session管理的设计方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!
总结以上是内存溢出为你收集整理的Android 用户Session管理的设计方案全部内容,希望文章能够帮你解决Android 用户Session管理的设计方案所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)