spring security緩存的應(yīng)用之登陸后跳轉(zhuǎn)到登錄前源地址
什么意思?
從第3步,我們可以知道,用戶的請(qǐng)求被中斷了。
用戶登錄成功后(第7步),會(huì)被重定向到origin url,spring security通過(guò)使用緩存的請(qǐng)求,使得被中斷的請(qǐng)求能夠繼續(xù)執(zhí)行。
具體請(qǐng)看 探究spring security緩存請(qǐng)求
我這里僅講解如何在ajax登陸后跳轉(zhuǎn)到登錄前的鏈接。
1. 首先,如果想跳轉(zhuǎn)到登陸之前的鏈接,我們需要拿到緩存:
savedrequest savedrequest = requestcache.getrequest(request, response);
注意!若用戶是直接訪問(wèn)沒(méi)有權(quán)限限制的登陸頁(yè)面,是不會(huì)有緩存的,也就是說(shuō)savedrequest = null ,所以在使用緩存之前,我們需要做一個(gè)非null判斷,也就是:
if (savedrequest != null) { // 邏輯代碼 }
2. 取到登錄前訪問(wèn)的url
string url = savedrequest.getredirecturl();
3. 使用hashmap建立一個(gè)對(duì)象,這是為了后續(xù)向?yàn)g覽器返回json數(shù)據(jù)
map json = new hashmap<string, object>(); json.put("code", 0); json.put("message", "操作成功"); json.put("url", url);
可以看到這個(gè)json 對(duì)象比較簡(jiǎn)單,其中url屬性是為了讓瀏覽器端的js跳轉(zhuǎn)的
4.設(shè)置響應(yīng)體編碼和格式
response.setcontenttype(febsconstant.json_utf8);
5.向?yàn)g覽器進(jìn)行響應(yīng)數(shù)據(jù),這里的數(shù)據(jù)是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 { // 不管請(qǐng)求哪個(gè)頁(yè)面,登陸成功后僅打開(kāi)指定頁(yè)面index // redirectstrategy.sendredirect(request, response, "/index"); // 獲取緩存 savedrequest savedrequest = requestcache.getrequest(request, response); // 設(shè)置響應(yīng)格式和編碼 response.setcontenttype(febsconstant.json_utf8); // 緩存非空判斷 if (savedrequest != null) { // 跳轉(zhuǎn)到之前引發(fā)跳轉(zhuǎn)的url string url = savedrequest.getredirecturl(); string messsage = "成功"; // 準(zhǔn)備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 { // 這個(gè)是沒(méi)有緩存,直接跳轉(zhuǎn)到默認(rèn)ajax默認(rèn)的頁(yè)面 response.getwriter().write(mapper.writevalueasstring(responsebo.ok())); } }
6. 前端頁(yè)面ajax代碼:
$.ajax( { type: "post", url: "/login", // 登陸表單數(shù)據(jù)序列化 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,則跳轉(zhuǎn)該url if (data.url != undefined) { $form[0].reset(); window.location.href = data.url; } else { // 重置表單的輸入框內(nèi)容 $form[0].reset(); window.location.href = '/index'; // $form.attr("action", '/index'); } } else { // if (r.msg !== '驗(yàn)證碼不能為空!') reloadcode(); console.log(data.message); } }, } );
7.不出意外的話,瀏覽器會(huì)收到下面的數(shù)據(jù):
{"code":0,"message":"操作成功"}
如果你也收到了這條數(shù)據(jù),說(shuō)明已經(jīng)成功了。
總結(jié)
以上所述是小編給大家介紹的ajax登陸使用spring security緩存跳轉(zhuǎn)到登陸前的鏈接,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)碩編程網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!