亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:128日期:2022-06-11 10:27:54

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 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緩存跳轉到登陸前的鏈接,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

標簽: Ajax
相關文章:
主站蜘蛛池模板: 中文字幕无线码中文字幕网站 | 牛牛影院成人免费网页 | 亚洲午夜精品在线 | 美国毛片毛片全部免费 | 美国一级做a一级视频 | 国产免费一级片 | 亚洲乱码中文字幕综合 | 香蕉视频在线观看黄 | 污黄在线观看 | 嫩草影院麻豆久久视频 | 国产私拍写真福利视频 | 美美女高清毛片视频黄的一免费 | 国产免费一区二区三区免费视频 | 国产xxxx做受欧美88xx00tube | 粉嫩jk制服美女啪啪 | 日韩欧美一二三区 | 欧美日韩免费在线视频 | 欧美精品在线视频观看 | 国产美女精品久久久久中文 | 日本高清色图 | 色射影院 | 精品久久久久不卡无毒 | 国产欧美在线播放 | 91视频国产免费 | 中文字幕曰韩一区二区不卡 | 特一级黄 | 欧美视频第二页 | 日韩字幕一中文在线综合 | 久久视频在线免费观看 | 一级特黄 | 九九在线偷拍视频在线播放 | 国产在线观看91精品2022 | 福利片成人午夜在线 | 中文字幕日韩在线观看 | 日比视频在线观看 | 国产剧情视频在线观看 | 高清视频一区二区三区 | 中国免费一级毛片 | 亚洲欧美久久婷婷爱综合一区天堂 | 国自产精品手机在线视频香蕉 | 91麻豆影视 |