美文网首页
关于登录拦截的一种实现方式

关于登录拦截的一种实现方式

作者: 捡贝壳的小男孩_839c | 来源:发表于2018-10-16 16:58 被阅读50次

    之前 APP 一直都是通过桌面的 icon 点击进入应用,所以都会跳转到登录页进行验证,再跳转到首页,最近有新的需求,第三方直接打开应用的某个 activity ,如果没有 token 会报 500 或者 token 无效,所以给应用加个登录拦截,如果没有登录,就跳转到登录页登录之后再返回要跳转的 activity 。

    先是看了一遍网上的实现方式,觉得都挺麻烦的,就自己试试通过 ActivityLifecycleCallbacks 来做一个登录拦截。

    首先写个 MyApplicationLifecycleCallback 实现 ActivityLifecycleCallbacks 接口,该 class 如下:

    public class MyApplicationLifecycleCallback implements Application.ActivityLifecycleCallbacks {
    
        @Override
        public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
        }
    
        @Override
        public void onActivityStarted(final Activity activity) {
    
        }
    
        @Override
        public void onActivityResumed(Activity activity) {
    
        }
    
        @Override
        public void onActivityPaused(Activity activity) {
    
        }
    
        @Override
        public void onActivityStopped(Activity activity) {
    
        }
    
        @Override
        public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
    
        }
    
        @Override
        public void onActivityDestroyed(Activity activity) {
    
        }
    }
    

    然后在 onActivityStarted 里面写拦截的代码:

            // 当前activity的名字
            String className = activity.getLocalClassName();
            // 不需要拦截的activity名字
            String permissionClassName = "com.permission.PermissionActivity";
            // 是否是需要拦截的activity
            boolean isInterceptActivity = !loginClassName.equals(className) && !permissionClassName.equals(className);
            // 是否有token 这里取application的全局token
            boolean haveToken = !(GlobalValue.TOKEN== null || "".equals(GlobalValue.TOKEN));
            if (isInterceptActivity && !haveToken) {
                Intent loginIntent = new Intent();
                loginIntent.setClass(activity, LoginActivity.class);
                activity.startActivity(loginIntent);
            }
    
    

    这样子就可以拦截没有登录的时候,其他应用打开需要登录的界面打开的就是登录页了。

    紧接着发现一个问题。在 ActivityLifecycleCallbacks 拦截的话,被拦截的 activity 已经 onResumed() 显示到前台,再跳转到 LoginActivity ,所以所有操作已经做完了,包括网络请求,所以跳转登录之后,finish 掉 LoginActivity 后,打开的是一个空白页面,不是我们想要的效果。

    所以我就想到保存当前跳转的 intent ,结束掉当前被拦截的 activity ,等到登录结束后再跳回去。

            // 当前activity的名字
            String className = activity.getLocalClassName();
            // 不需要拦截的activity名字
            String permissionClassName = "com.permission.PermissionActivity";
            // 是否是需要拦截的activity
            boolean isInterceptActivity = !loginClassName.equals(className) && !permissionClassName.equals(className);
            // 是否有token 这里取application的全局token
            boolean haveToken = !(GlobalValue.TOKEN== null || "".equals(GlobalValue.TOKEN));
            if (isInterceptActivity && !haveToken) {
                Intent loginIntent = new Intent();
                loginIntent.setClass(activity, LoginActivity.class);
                activity.startActivity(loginIntent);
                // 被拦截的activity的intent 
                beforeIntent = activity.getIntent();
                new Handler().postDelayed(new Runnable() {
                    @Override
                    public void run() {
                        // 在这里finish掉,然后一会loginActivity结束了再打开
                        activity.finish();
                    }
                }, 500);
            }
    

    然后在 onActivityStopped 里面增加判断

            String className = activity.getLocalClassName();
            if (loginClassName.equals(className)) {
                // 当loginActivity结束的时候,判断beforeIntent为不为空,不为空就说明是第三方打开的,跳转回去
                if (beforeIntent != null) {
                    activity.startActivity(beforeIntent);
                    beforeIntent = null;
                }
            }
    

    所以这个 MyApplicationLifecycleCallback.java 文件的全部代码是:

    public class MyApplicationLifecycleCallback implements Application.ActivityLifecycleCallbacks {
        private Intent beforeIntent;
        String loginClassName = "com.LoginActivity";
    
        @Override
        public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
        }
    
        @Override
        public void onActivityStarted(final Activity activity) {
            // 登录拦截 登录过后再跳回去
            // 当前activity的名字
            String className = activity.getLocalClassName();
            // 不需要拦截的activity名字
            String permissionClassName = "com.permission.PermissionActivity";
            // 是否是需要拦截的activity
            boolean isInterceptActivity = !loginClassName.equals(className) && !permissionClassName.equals(className);
            // 是否有token 这里取application的全局token
            boolean haveToken = !(GlobalValue.TOKEN== null || "".equals(GlobalValue.TOKEN));
            if (isInterceptActivity && !haveToken) {
                Intent loginIntent = new Intent();
                loginIntent.setClass(activity, LoginActivity.class);
                activity.startActivity(loginIntent);
                // 被拦截的activity的intent 
                beforeIntent = activity.getIntent();
                new Handler().postDelayed(new Runnable() {
                    @Override
                    public void run() {
                        // 在这里finish掉,然后一会loginActivity结束了再打开
                        activity.finish();
                    }
                }, 500);
            }
        }
    
        @Override
        public void onActivityResumed(Activity activity) {
    
        }
    
        @Override
        public void onActivityPaused(Activity activity) {
    
        }
    
        @Override
        public void onActivityStopped(Activity activity) {
            String className = activity.getLocalClassName();
            if (loginClassName.equals(className)) {
                // 当loginActivity结束的时候,判断beforeIntent为不为空,不为空就说明是第三方打开的,跳转回去
                if (beforeIntent != null) {
                    activity.startActivity(beforeIntent);
                    beforeIntent = null;
                }
            } 
        }
    
        @Override
        public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
    
        }
    
        @Override
        public void onActivityDestroyed(Activity activity) {
    
        }
    }
    

    相关文章

      网友评论

          本文标题:关于登录拦截的一种实现方式

          本文链接:https://www.haomeiwen.com/subject/nzdhzftx.html