<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
        主站蜘蛛池模板: 亚洲色偷偷av男人的天堂| 色久悠悠婷婷综合在线亚洲| 亚洲视频在线一区二区三区| 永久免费AV无码网站国产| 久久影视国产亚洲| 最近免费中文字幕MV在线视频3| 亚洲区小说区激情区图片区| 一级做a爱片特黄在线观看免费看 一级做a爱过程免费视 | 亚洲gay片在线gv网站| 日韩成人免费视频播放| 国产成人亚洲综合a∨| 亚洲精品视频免费| 国产一级a毛一级a看免费人娇| 亚洲人成网站在线播放vr| 嫩草在线视频www免费观看| 久久精品国产亚洲av日韩| 日本精品人妻无码免费大全| 亚洲欧美自偷自拍另类视| 亚洲成AV人在线观看网址| 光棍天堂免费手机观看在线观看| 亚洲av中文无码乱人伦在线播放 | 狠狠亚洲狠狠欧洲2019| 国产成年无码久久久免费| 亚洲精品白色在线发布| 在线精品免费视频| 日韩a毛片免费观看| 黑人精品videos亚洲人| 无码人妻精品中文字幕免费东京热| 伊人久久亚洲综合影院首页| 四虎永久免费影院在线| 二个人看的www免费视频| 亚洲毛片基地日韩毛片基地| 免费特级黄毛片在线成人观看| 一级毛片免费在线播放| 亚洲成人黄色在线| 亚洲A丁香五香天堂网| 青青草无码免费一二三区| 亚洲国产精品18久久久久久| 国产亚洲高清不卡在线观看| 在线看片无码永久免费视频| 一级特黄录像免费播放中文版|