成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SSO單點(diǎn)登錄重定向解決方案

開發(fā) 前端
當(dāng)我們寫好SSO單點(diǎn)登錄服務(wù)的代碼后,通過調(diào)用接口方式驗(yàn)證,流程看似正常,但開始與前端聯(lián)調(diào)就出現(xiàn)問題了。

[[376527]]

當(dāng)我們寫好SSO單點(diǎn)登錄服務(wù)的代碼后,通過調(diào)用接口方式驗(yàn)證,流程看似正常,但開始與前端聯(lián)調(diào)就出現(xiàn)問題了。

流程是這樣的:前端在首頁使用ajax訪問后端獲取菜單或者用戶信息的接口,以觸發(fā)登錄校驗(yàn),如果未登錄則重定向到SSO登錄頁面。

但這一步就出問題了,原因是ajax無法攔截302處理。當(dāng)ajax接收到302響應(yīng)時,看起來就像是ajax直接向重定向鏈接發(fā)起請求,而不是讓瀏覽器重定向,結(jié)果啥事也沒干。

關(guān)于ajax無法攔截302處理的原因,筆者從網(wǎng)上找到的解釋如下。

服務(wù)器將302響應(yīng)發(fā)給瀏覽器時,瀏覽器并不是直接進(jìn)行ajax回調(diào)處理,而是先執(zhí)行302重定向,從響應(yīng)頭中讀取Location信息,然后向Location中的Url發(fā)出請求,在收到這個請求的響應(yīng)后才會進(jìn)行ajax回調(diào)處理。

大致流程:ajax -> browser -> server -> 302 -> browser(redirect) -> server -> browser -> ajax callback。

原本是為了讓前端以最少的改動接入SSO,但因?yàn)楣P者對前端的了解較淺,才犯了這樣的錯誤。

既然ajax無法處理302,那也只能修改流程,讓前端主動發(fā)起重定向了。

流程修改后,當(dāng)后端驗(yàn)證用戶未登錄或登錄過期時響應(yīng)401狀態(tài)碼,同時body給出重定向鏈接,而前端需要全局?jǐn)r截401錯誤,從響應(yīng)body獲取鏈接并讓瀏覽器重定向到指定鏈接,該鏈接就是由后端拼接好的跳轉(zhuǎn)到SSO登錄的鏈接。

最后還有一個cookie問題。由于本地測試,前端將請求轉(zhuǎn)發(fā)給部署到測試環(huán)境的后端,前端的域名為127.0.0.1,后端測試環(huán)境域名為xxx. com,導(dǎo)致本地測試跳轉(zhuǎn)到SSO登錄成功并返回后,前端向后端發(fā)起請求依然響應(yīng)401。

原因在上篇已經(jīng)描述過了,就是因?yàn)橛蛎煌岸耸褂胊jax發(fā)起請求,瀏覽器并不會將xxx.com域名下的cookie帶上,只會帶上127.0.0.1域名下的cookie。

解決該問題只需要修改傳給SSO登錄成功后重定向的checkToken接口的域名為前端本地測試的域名,由前端將請求轉(zhuǎn)發(fā)給后端,或者在nginx配置將此接口的請求轉(zhuǎn)發(fā)給后端處理,只有這樣session才能保持一致。

除此之外,跨協(xié)議無法重訂向。也就是說,sso部署在測試環(huán)境域名為https://sso.xx.com,而接入sso的服務(wù)在本地測試域名為http://127.0.0.1,想要從https://sso.xx.com登錄成功后重定向回http://127.0.0.1是不支持的,原因是跨協(xié)議重定向了,由https協(xié)議變成了http協(xié)議。

從這些事情可以看出,實(shí)戰(zhàn)很重要!即便理解了流程、實(shí)現(xiàn)原理,但不動手實(shí)戰(zhàn)就學(xué)不到細(xì)節(jié),無法從各種踩坑過程中成長。

 本文轉(zhuǎn)載自微信公眾號「Java藝術(shù)」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系Java藝術(shù)公眾號。

 

責(zé)任編輯:武曉燕 來源: Java藝術(shù)
相關(guān)推薦

2021-10-29 13:26:54

單點(diǎn)登錄SSO

2020-12-28 05:52:27

SSO登錄單點(diǎn)

2024-06-21 09:28:43

2025-03-28 09:22:33

2019-07-24 15:12:08

單點(diǎn)登錄SSO密碼

2022-11-28 09:19:33

2024-08-12 08:12:38

2023-11-08 14:57:41

2024-03-01 11:33:31

2021-09-28 10:48:07

開源雙因素認(rèn)證單點(diǎn)登錄

2014-04-11 09:22:17

MySQL雙主架構(gòu)單點(diǎn)故障

2010-12-14 15:07:15

ICMP路由重定向

2024-09-27 12:13:26

GoGTokenSSO

2022-05-12 07:37:51

單點(diǎn)登錄微服務(wù)開源

2024-06-20 08:20:27

2021-06-01 06:01:35

SSO單點(diǎn)登錄

2012-07-11 13:45:33

伊頓

2020-02-28 08:00:35

單點(diǎn)登錄系統(tǒng)

2018-12-03 12:17:27

Semptian解決方案

2012-05-27 16:21:31

IDC華為
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 在线欧美日韩 | 欧洲亚洲一区二区三区 | 亚洲444eee在线观看 | 成人av播放 | a在线观看 | 亚洲国产伊人 | 国产一区不卡在线观看 | 国产欧美一区二区精品忘忧草 | 久久一区二区三区免费 | 在线视频亚洲 | 亚洲精品一区中文字幕乱码 | 成人区精品一区二区婷婷 | 激情福利视频 | 一级特黄在线 | 久久久久99 | 久久久观看 | 欧美日韩专区 | 天天干天天草 | 中文无码日韩欧 | 日韩在线观看中文字幕 | 国产欧美日韩精品一区 | 全免一级毛片 | 99精品在线观看 | 在线婷婷 | 中文字幕一区二区三区四区五区 | 国产亚洲精品久久19p | 精品不卡| 粉嫩高清一区二区三区 | 午夜国产 | 亚洲精品久久 | 国产精品视频久久久 | 日本高清视频在线播放 | 国内精品视频一区二区三区 | 欧美激情 亚洲 | 国产一区中文字幕 | 一二三在线视频 | 荷兰欧美一级毛片 | 国产一区二区影院 | 国产激情一区二区三区 | 久久免费视频在线 | 一区二区三区四区免费在线观看 |