Android应用搭配Spring Security实现登陆鉴权

在普通基于浏览器的web应用中,我们的验证鉴权一般使用sessionid实现,即验证通过时服务端返回一个sessionid,在cookies中。以后的每次请求都在请求头中设置cookies的值为返回的sessionid,即标志该请求是验证通过的。

在android应用中,我们可以通过用户名密码去请求登陆接口,得到服务端响应的sessionid,持久化存储起来,每次请求网络的时候都带上该sessionid,即可验证。

问题是,验证通过后的行为不合适。Web应用中验证通过后一般会重定向到之前请求页或首页,但是android不能接受redirect响应。所以应该需要为android应用开发一套接口,尽可能的重用验证鉴权逻辑。

我们要实现的这个功能属于验证成功后的行为,所以显然,应该在登陆过滤器中去修改,登陆过滤器中有一个authenticationSuccessHandler接口,项目之前采用的是org.springframework.security.web.authentication.SimpleUrlAuthenticationSuccessHandler实例。其中的onAuthenticationSuccess方法主要逻辑在handle()方法中。查看handle方法源码,最重要的一条是redirectStrategy.sendRedirect(request, response, targetUrl);很明显,这就是我们要修改的地方。redirectStrategy默认只有一个实现DefaultRedirectStrategy,其主要的方法如下:

public void sendRedirect(HttpServletRequest request,HttpServletResponse response,
        String url) throws IOException {
    String redirectUrl = calculateRedirectUrl(request.getContextPath(), url);
    redirectUrl = response.encodeRedirectURL(redirectUrl);
    if (logger.isDebugEnabled()) {
        logger.debug("Redirecting to '" + redirectUrl + "'");
    }
    response.sendRedirect(redirectUrl);
}

该方法通过response来sendredirect到目的地址。

我们要实现的是,android设备验证成功后不用redirect,而是返回一个标 记,在此就很好实现了。只需要在安卓设备发送登陆请求时添加一个字段,表明是安卓设备,我们在重新实现以下这个sendRedirect方法,redirect之前首先判断以下request是否含有android设备标记即可,然后分情况来决定是否redirect。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,405评论 25 708
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,767评论 18 399
  • 布果怎么也不能想明白,那个人会是谁,只是在随意的某个时间,发过来的好友请求, 布果手贱的同意一下,也再无理会...
    笛尘阅读 239评论 4 2
  • 周末 天气晴好 骑上免费小黄车 拿上手机,留下春天美好记忆。 ① 摄影器材 不喜欢单反相机的笨重和复杂,手机摄影随...
    闲看庭前花开阅读 419评论 1 4
  • 文/风吟草木声 如果我是兀立于原野之上 那棵白杨树。那么,你就是 云一样缠绕在生命的枝头 水一样纠结于生活的每一道...
    风吟草木声阅读 143评论 0 1