什麼是認證?
身份認證,校驗使用者是否有相應的身份(登入驗證)
Shiro實現認證的具體流程:
大致上來說是:
graph LR
Subject-->SecurityManager
SecurityManager-->Authenticator
Authenticator-->Realm
Realm-->Cryptography加密
複製程式碼
data:image/s3,"s3://crabby-images/b07d6/b07d613749150489729e9286accef21abec960f2" alt="image"
首先,使用者填寫登入資訊傳送請求到action中,action中呼叫subject中的login方法.
data:image/s3,"s3://crabby-images/87b68/87b68eabcbb57783828d91d6d1ec870d10eb5da9" alt="image"
然後由於Subject物件是一個介面,因此我們查詢它的實現類
data:image/s3,"s3://crabby-images/cb4cf/cb4cff29ff3aa2fdd09bc17813f0c63e488b6def" alt="image"
DelegattingSubject是Subject的實現類
data:image/s3,"s3://crabby-images/09da5/09da5d7e294585e170c8a39e56594557ada829a5" alt="image"
然而它又由securityManager 來呼叫
data:image/s3,"s3://crabby-images/92500/92500a4cefaf38e47dd9c4cd9a793e22c15128fb" alt="image"
SecurityManager是一個介面,繼續找它的實現類
data:image/s3,"s3://crabby-images/d9653/d9653eda2be09b985816bf2521b4badf56b803a6" alt="image"
認證安全管理
data:image/s3,"s3://crabby-images/0ce03/0ce0334f10b384b0ffb9fd184e493d1f2707fda0" alt="image"
類中的這個方法繼續將我們頁面中封裝好的token傳遞
data:image/s3,"s3://crabby-images/39c13/39c135149c0815b2c639124be0a221f492c96d33" alt="image"
data:image/s3,"s3://crabby-images/fd62e/fd62eda452bdf2b2d2659d06afa091d7c0ea7c0e" alt="image"
data:image/s3,"s3://crabby-images/fb187/fb18720159e25c8352565e0accc059415cf9ba66" alt="image"
最後這個token傳到了ModularRealmAuthenticator這裡來了.這裡面的doSingleRealmAuthentication呼叫了我們自定義的Realm.並把我們在Action中封裝的Token傳遞進Realm中進行認證校驗.
data:image/s3,"s3://crabby-images/ee122/ee12239ff58945eb004cfbb8f47f75a47f74f06c" alt="image"