• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Ajax登陆使用Spring Security缓存跳转到登陆前的链接

    Spring Security缓存的应用之登陆后跳转到登录前源地址

    什么意思?

    1. 用户访问网站,打开了一个链接:(origin url)起源链接
    2. 请求发送给服务器,服务器判断用户请求了受保护的资源。
    3. 由于用户没有登录,服务器重定向到登录页面:/login
    4. 填写表单,点击登录
    5. 浏览器将用户名密码以表单形式发送给服务器
    6. 服务器验证用户名密码。成功,进入到下一步。否则要求用户重新认证(第三步)
    7. 服务器对用户拥有的权限(角色)判定。有权限,重定向到origin url; 权限不足,返回状态码403( “禁止”)。

    从第3步,我们可以知道,用户的请求被中断了。

    用户登录成功后(第7步),会被重定向到origin url,spring security通过使用缓存的请求,使得被中断的请求能够继续执行。

    具体请看 探究Spring Security缓存请求

    我这里仅讲解如何在ajax登陆后跳转到登录前的链接。

    1. 首先,如果想跳转到登陆之前的链接,我们需要拿到缓存:

    SavedRequest savedRequest = requestCache.getRequest(request, response);

    注意!若用户是直接访问没有权限限制的登陆页面,是不会有缓存的,也就是说savedRequest = null ,所以在使用缓存之前,我们需要做一个非null判断,也就是:

    if (savedRequest != null) {
      // 逻辑代码
     }

    2. 取到登录前访问的url

    String url = savedRequest.getRedirectUrl();

    3. 使用hashMap建立一个对象,这是为了后续向浏览器返回json数据

    Map json = new HashMapString, Object>();
       json.put("code", 0);
       json.put("message", "操作成功");
       json.put("url", url);

    可以看到这个json 对象比较简单,其中url属性是为了让浏览器端的js跳转的

    4.设置响应体编码和格式

    response.setContentType(FebsConstant.JSON_UTF8);

    5.向浏览器进行响应数据,这里的数据是json格式,是使用jackson工具包完成的,Maven地址: JacksonMaven地址

    response.getWriter().write(mapper.writeValueAsString(ResponseBo.ok(messsage, url)));

    下面是完整的Java代码:

    @Override
     public void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication) throws IOException, ServletException {
      // 不管请求哪个页面,登陆成功后仅打开指定页面index
    //  redirectStrategy.sendRedirect(request, response, "/index");
      // 获取缓存
      SavedRequest savedRequest = requestCache.getRequest(request, response);
      // 设置响应格式和编码
      response.setContentType(FebsConstant.JSON_UTF8);
      
      // 缓存非空判断
      if (savedRequest != null) {
       // 跳转到之前引发跳转的url
       String url = savedRequest.getRedirectUrl();
       
       String messsage = "成功";
       // 准备json
       Map json = new HashMapString, Object>();
       json.put("code", 0);
       json.put("message", "操作成功");
       json.put("url", url);
    
       Object jsons = ResponseBo.ok(messsage, url);
       response.getWriter().write(mapper.writeValueAsString(ResponseBo.ok(messsage, url)));
      } else {
       // 这个是没有缓存,直接跳转到默认ajax默认的页面
       response.getWriter().write(mapper.writeValueAsString(ResponseBo.ok()));
      }
     }

    6. 前端页面Ajax代码:

    $.ajax(
      {
       type: "post",
       url: "/login",
       // 登陆表单数据序列化
       data: $form.serialize(),
       dataType: "json",
       error: function (data, type, err) {
        if (data.responseJSON != undefined) {
         console.log(data.responseJSON.error != undefined);
         console.log(JSON.stringify(data.responseJSON.error));
         $MB.n_danger("error:" + JSON.stringify(data.responseJSON.error));
        }
       },
       success: function (data) {
        console.log(JSON.stringify(data));
        alert(JSON.stringify(data));
    
        if (data.code == 0) {
         // 如果有url,则跳转该url
         if (data.url != undefined) {
          $form[0].reset();
          window.location.href = data.url;
         } else {
          // 重置表单的输入框内容
          $form[0].reset();
          window.location.href = '/index';
          // $form.attr("action", '/index');
         }
    
        } else {
         // if (r.msg !== '验证码不能为空!') reloadCode();
         console.log(data.message);
        }
       },
      }
     );

    7.不出意外的话,浏览器会收到下面的数据:

    {"code":0,"message":"操作成功"}

    如果你也收到了这条数据,说明已经成功了。

    总结

    以上所述是小编给大家介绍的Ajax登陆使用Spring Security缓存跳转到登陆前的链接,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
    如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

    您可能感兴趣的文章:
    • Spring security实现登陆和权限角色控制
    • 基于Spring Security的Oauth2授权实现方法
    • 浅谈Spring Security 对于静态资源的拦截与放行
    • SpringBoot2.0 整合 SpringSecurity 框架实现用户权限安全管理方法
    • 使用Spring Security OAuth2实现单点登录
    • SpringBoot+Spring Security+JWT实现RESTful Api权限控制的方法
    • spring security CSRF防护的示例代码
    • Spring Security实现禁止用户重复登陆的配置原理
    上一篇:Ajax验证用户名是否存在的实例代码
    下一篇:关于Ajax跨域问题及解决方案详析
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    Ajax登陆使用Spring Security缓存跳转到登陆前的链接 Ajax,登陆,使用,Spring,Security,