<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

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

        來源:懂視網 責編:小采 時間:2020-11-27 22:51:25
        文檔

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

        Ajax登陸使用Spring Security緩存跳轉到登陸前的鏈接:Spring Security緩存的應用之登陸后跳轉到登錄前源地址 什么意思? 用戶訪問網站,打開了一個鏈接:(origin url)起源鏈接 請求發送給服務器,服務器判斷用戶請求了受保護的資源。 由于用戶沒有登錄,服務器重定向到登錄頁面:/login 填寫表單,點擊
        推薦度:
        導讀Ajax登陸使用Spring Security緩存跳轉到登陸前的鏈接:Spring Security緩存的應用之登陸后跳轉到登錄前源地址 什么意思? 用戶訪問網站,打開了一個鏈接:(origin url)起源鏈接 請求發送給服務器,服務器判斷用戶請求了受保護的資源。 由于用戶沒有登錄,服務器重定向到登錄頁面:/login 填寫表單,點擊

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

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

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

        Ajax登陸使用Spring Security緩存跳轉到登陸前的鏈接:Spring Security緩存的應用之登陸后跳轉到登錄前源地址 什么意思? 用戶訪問網站,打開了一個鏈接:(origin url)起源鏈接 請求發送給服務器,服務器判斷用戶請求了受保護的資源。 由于用戶沒有登錄,服務器重定向到登錄頁面:/login 填寫表單,點擊
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产91精品一区二区麻豆亚洲| 国产a不卡片精品免费观看| 国产三级在线免费| 久久国产乱子伦精品免费一| 成年女人喷潮毛片免费播放 | a级毛片在线视频免费观看| 日韩视频在线观看免费| 久久精品夜色噜噜亚洲A∨| 亚洲AV无码AV男人的天堂| 亚洲男女一区二区三区| 亚洲av永久中文无码精品综合 | 亚洲 无码 在线 专区| 九月丁香婷婷亚洲综合色| 亚洲免费视频网址| 中国一级毛片视频免费看| 无码日韩人妻av一区免费| 国产亚洲精品自在线观看| 精品免费久久久久国产一区| 成年女人毛片免费播放人| 亚洲AV性色在线观看| 最好看的中文字幕2019免费| 亚洲VA综合VA国产产VA中| 亚洲中字慕日产2020| 三级黄色在线免费观看| 亚洲AV无码乱码在线观看富二代 | 亚洲国产日韩在线人成下载 | 中文在线观看永久免费| 久久亚洲国产精品| 青青青国产在线观看免费网站| 精品亚洲综合在线第一区| 国产电影午夜成年免费视频| 亚洲色欲久久久综合网| 羞羞漫画在线成人漫画阅读免费| 久久精品免费一区二区| 久久香蕉国产线看观看亚洲片| xx视频在线永久免费观看| 亚洲欧洲精品成人久久曰| 18禁美女裸体免费网站| 亚洲成a人片在线观看中文动漫| 国产四虎免费精品视频| 免费国产草莓视频在线观看黄|