前後端分離的架構中,未認證跳轉是怎麼做的呢?

來源:互聯網
上載者:User
在前後端分離的架構中,一般通過nginx的配置將後端的請求去後端對應的目錄,然後前端的請求去找前端對應的目錄。現在剛好碰到一個認證條狀的功能,要實現的就是每個請求發過來不管是前端請求還是後端請求,先判斷有沒有登入,沒有登入就跳轉到登入首頁。
1。一般認證判斷是後端做的事情,頁面跳轉是前端做的事情,這兩個步驟怎麼給他結合起來呢。

  1. 前後端不分離的時候一般是在架構初始化的時候置一個鉤子,判斷有沒有登入,沒有登入就跳轉。

  2. 我想分離後的方案應該是,後端依然對每個請求進行認證判斷,只返回不跳轉。 然後前端架構模組初始化都先請求下認證介面,如果認證未通過就跳轉到登入頁面。

麻煩有經驗的友友,給下分離情境下這個認證該怎麼做的意見哈。

回複內容:

在前後端分離的架構中,一般通過nginx的配置將後端的請求去後端對應的目錄,然後前端的請求去找前端對應的目錄。現在剛好碰到一個認證條狀的功能,要實現的就是每個請求發過來不管是前端請求還是後端請求,先判斷有沒有登入,沒有登入就跳轉到登入首頁。
1。一般認證判斷是後端做的事情,頁面跳轉是前端做的事情,這兩個步驟怎麼給他結合起來呢。

  1. 前後端不分離的時候一般是在架構初始化的時候置一個鉤子,判斷有沒有登入,沒有登入就跳轉。

  2. 我想分離後的方案應該是,後端依然對每個請求進行認證判斷,只返回不跳轉。 然後前端架構模組初始化都先請求下認證介面,如果認證未通過就跳轉到登入頁面。

麻煩有經驗的友友,給下分離情境下這個認證該怎麼做的意見哈。

前台端分離一般都是用json傳輸,假如是Json可以這樣做。
驗證成功時返回:{code:"成功",data:"要取的資料",info:null},
驗證失敗時返回:{code:"失敗",data:null,info:"沒有存取權限"}
前端用接收後自己判斷code值,至於跳不跳轉那就是前端自己的事咯。

我實現的方式是:

前端登入後,儲存後端產生的token(後端可以用JWTredismysql儲存,前端儲存在localstoragecookie)。

前端每次請求需授權(登入)介面,判斷token是否有效(包含是否到期),如果無效返回403,以及錯誤資訊。前端使用一個Service基類(例如AdminService catch 403的異常,如果捕獲到,路由到登入頁面),或者寫一個全域的過濾器,捕獲403

前後端分離就在前端緩衝一個登入狀態,然後每次請求的時候帶上這個狀態代碼,後台判斷是否到期,差不多就這樣了

很簡單吖,譬如說背景項目,後台我們都知道只能登陸成功之後才能進入系統把,那麼整個時候是怎麼做認證的呢?

  1. 後端對所有過來的請求都做過濾,驗證使用者有沒有登陸,如果又就繼續不管他,如果沒有登陸就讓他直接跳轉到登陸頁面

  2. 對於前台來說,每一個路由跳轉也要進行驗證,比如:開啟某一個頁面之前向後台發送一個ajax用來驗證,如果登陸顯示頁面如果沒有就跳轉到登陸頁面

  3. 怎麼驗證,使用者沒有登陸成功的情況下,瀏覽器不寫入cookie,登入成功之後就把使用者的cookie儲存到瀏覽器,使用者的session儲存到伺服器,瀏覽器的cookie就是session的key

我們公司最近做前後端完全分離。具體辦法很簡單,比如有需要登入驗證的頁面,前端會直接請求後端。後端判斷是否登入,如果登入了返回狀態statussuccess,外加資料啥的。如果沒有登入直接返回一個固定的狀態,就是statusfail_401

如果該頁面沒有什麼可以擷取的資料,我們直接給個通用介面,進入頁面就請求下介面,如果通過就留在當前頁面,如果未通過就直接跳轉。

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.