SSM框架下Shiro免密登錄

在做微信授權(quán)登陸的時候,由于使用shiro框架進行認證登陸,沒有認證授權(quán)無法建立會話。
數(shù)據(jù)庫中的密碼經(jīng)過md5加密员魏,通過openid查詢出賬號密碼也無法進行授權(quán)登陸,所以需要實現(xiàn)Shiro免密授權(quán)登陸功能叠聋,以防后續(xù)踩坑逆趋。

1.整體思路

自定義token,加入免密標識符晒奕,在進行授權(quán)時判斷是密碼登陸或無密碼登陸闻书,自定義密碼認證方法,即寫一個方法繼承HashedCredentialsMatcher脑慧,重寫其中的doCredentialsMatch魄眉,將其中的token改寫為自定義的token,最后將自己寫的密碼認證方法注入shiro

2.源碼分析

在shiro的配置文件中有個配置credentialsMatcher闷袒,該方法為重寫方法坑律,自定義登陸模式,可設(shè)置密碼錯誤鎖定功能囊骤,我們需要的就是改寫這個方法

image.png
1)在ShiroDbRealm中晃择,認證使用的是UserPasswordToken
image.png
其默認使用username,password進行認證
image.png

image.png
網(wǎng)上有方法另寫token繼承UsernamePasswordToken重寫getCredentials方法修改getPassword() 為 return null。此方法過于簡單粗暴也物,順帶連密碼認證也給刪除了宫屠,不建議使用。
2)Shiro的密碼認證在org.apache.shiro.authc.credential包下HashedCredentialsMatcher.class方法內(nèi)
image.png
其中密碼認證:doCredentialsMatch方法
image.png

3.免密登陸方法

1)創(chuàng)建一個枚舉類(enum )LoginType
public enum LoginType {
    PASSWORD("password"), // 密碼登錄
    NOPASSWD("nopassword"); // 免密登錄

    private String code;// 狀態(tài)值

    private LoginType(String code) {
    this.code = code;
    }
    public String getCode () {
    return code;
    }
}
2)自定義token 繼承UsernamePasswordToken,通過構(gòu)造方法來區(qū)分 賬號密碼登陸(password) 和 免密登陸(nopassword)
package com.pasic.commons.shiro;

import org.apache.shiro.authc.UsernamePasswordToken;

public class EasyTypeToken extends UsernamePasswordToken {
    private static final long serialVersionUID = -2564928913725078138L;

    private LoginType type;


    public EasyTypeToken() {
    super();
    }


    public EasyTypeToken(String username, String password, LoginType type, boolean rememberMe,  String host) {
    super(username, password, rememberMe,  host);
    this.type = type;
    }
    /**免密登錄*/
    public EasyTypeToken(String username) {
    super(username, "", false, null);
    this.type = LoginType.NOPASSWD;
    }
    /**賬號密碼登錄*/
    public EasyTypeToken(String username, String password) {
    super(username, password, false, null);
    this.type = LoginType.PASSWORD;
    }

    public LoginType getType() {
    return type;
    }


    public void setType(LoginType type) {
    this.type = type;
    }
}
3)修改ShiroDbRealm:將UsernamePasswordToen修改為自定義token
image.png
4)找到RetryLimitCredentialsMatcher重寫doCredentialsMatch,將token強轉(zhuǎn)為自定義token滑蚯,如果是免密登陸則直接返回 true
@Override
    public boolean doCredentialsMatch(AuthenticationToken authcToken, AuthenticationInfo info) {
        EasyTypeToken tk = (EasyTypeToken) authcToken;
        if(tk.getType().equals(LoginType.NOPASSWD)){
                return true;
        }
         
        String username = (String) authcToken.getPrincipal();
        //retry count + 1
        AtomicInteger retryCount = passwordRetryCache.get(username);
        if(retryCount == null) {
            retryCount = new AtomicInteger(0);
            passwordRetryCache.put(username, retryCount);
        }
        if(retryCount.incrementAndGet() > 5) {
            //if retry count > 5 throw
            logger.warn("username: " + username + " tried to login more than 5 times in period");  
            throw new ExcessiveAttemptsException("用戶名: " + username + " 密碼連續(xù)輸入錯誤超過5次达址,鎖定半小時话原!"); 
        } else {
            passwordRetryCache.put(username, retryCount);
        }

        boolean matches = super.doCredentialsMatch(authcToken, info);
        if(matches) {
            //clear retry data
            passwordRetryCache.remove(username);
        }
        return matches;
    }

就此配置完成

Login調(diào)用

1)賬號密碼登陸
Subject user = SecurityUtils.getSubject();
EasyTypeToken token = new EasyTypeToken(username, password);
user.login(token);
2)免密登陸
Subject user = SecurityUtils.getSubject();
EasyTypeToken token = new EasyTypeToken(username);
user.login(token);

通過不同的構(gòu)造函數(shù)生成不同的LoginType光稼,從而實現(xiàn)賬號密碼登陸與免密登陸分離步鉴,完成。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末斥赋,一起剝皮案震驚了整個濱河市缰猴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌疤剑,老刑警劉巖滑绒,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件闷堡,死亡現(xiàn)場離奇詭異,居然都是意外死亡蹬挤,警方通過查閱死者的電腦和手機缚窿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來焰扳,“玉大人倦零,你說我怎么就攤上這事《趾罚” “怎么了扫茅?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長育瓜。 經(jīng)常有香客問我葫隙,道長,這世上最難降的妖魔是什么躏仇? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任恋脚,我火速辦了婚禮,結(jié)果婚禮上焰手,老公的妹妹穿的比我還像新娘糟描。我一直安慰自己,他們只是感情好书妻,可當我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布船响。 她就那樣靜靜地躺著,像睡著了一般躲履。 火紅的嫁衣襯著肌膚如雪见间。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天工猜,我揣著相機與錄音米诉,去河邊找鬼。 笑死域慷,一個胖子當著我的面吹牛荒辕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播犹褒,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼弛针!你這毒婦竟也來了叠骑?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤削茁,失蹤者是張志新(化名)和其女友劉穎宙枷,沒想到半個月后掉房,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡慰丛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年卓囚,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诅病。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡哪亿,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出贤笆,到底是詐尸還是另有隱情蝇棉,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布芥永,位于F島的核電站篡殷,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏埋涧。R本人自食惡果不足惜板辽,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望棘催。 院中可真熱鬧劲弦,春花似錦、人聲如沸巧鸭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽纲仍。三九已至呀袱,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間郑叠,已是汗流浹背夜赵。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留乡革,地道東北人寇僧。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像沸版,于是被迫代替她去往敵國和親嘁傀。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,627評論 2 350

推薦閱讀更多精彩內(nèi)容