精品熟女碰碰人人a久久,多姿,欧美欧美a v日韩中文字幕,日本福利片秋霞国产午夜,欧美成人禁片在线观看

Ajax登陸使用Spring Security緩存跳轉到登陸前的鏈接

spring security緩存的應用之登陸后跳轉到登錄前源地址

什么意思?

  • 用戶訪問網站,打開了一個鏈接:(origin url)起源鏈接
  • 請求發送給服務器,服務器判斷用戶請求了受保護的資源。
  • 由于用戶沒有登錄,服務器重定向到登錄頁面:/login
  • 填寫表單,點擊登錄
  • 瀏覽器將用戶名密碼以表單形式發送給服務器
  • 服務器驗證用戶名密碼。成功,進入到下一步。否則要求用戶重新認證(第三步)
  • 服務器對用戶擁有的權限(角色)判定。有權限,重定向到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 hashmap<string, 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 hashmap<string, 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緩存跳轉到登陸前的鏈接,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對碩編程網站的支持!
    如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

    相關文章