shiro——從MySQL得到當(dāng)前執(zhí)行的用戶

圖片.png

jdbc_realm.ini:

[main]
jdbcRealm=org.apache.shiro.realm.jdbc.JdbcRealm
dataSource=com.mchange.v2.c3p0.ComboPooledDataSource
dataSource.driverClass=com.mysql.jdbc.Driver
dataSource.jdbcUrl=jdbc:mysql://localhost:3306/shiro_db
dataSource.user=root
dataSource.password=root
jdbcRealm.dataSource=$dataSource
securityManager.realms=$jdbcRealm

// 讀取配置文件,初始化SecurityManager工廠
        Factory<org.apache.shiro.mgt.SecurityManager> factory = new IniSecurityManagerFactory(
                "classpath:jdbc_realm.ini");

        // 獲取securityManager實例
        org.apache.shiro.mgt.SecurityManager securityManager = factory.getInstance();

        // 把securityManager實例綁定到SecurityUtils
        SecurityUtils.setSecurityManager(securityManager);

        // 得到當(dāng)前執(zhí)行的用戶
        Subject currentUser = SecurityUtils.getSubject();

        // 創(chuàng)建token令牌,用戶名/密碼
        UsernamePasswordToken token = new UsernamePasswordToken("zb", "1");

        try {
            // 身份認(rèn)證
            currentUser.login(token);
            System.out.println("身份認(rèn)證成功!" + token.getUsername());
        } catch (IncorrectCredentialsException e) {
            System.out.println("登錄密碼錯誤");
        } catch (ExcessiveAttemptsException e) {
            System.out.println("登錄失敗次數(shù)過多");
        } catch (LockedAccountException e) {
            System.out.println("帳號已被鎖定");
        } catch (DisabledAccountException e) {
            System.out.println("帳號已被禁用");
        } catch (ExpiredCredentialsException e) {
            System.out.println("帳號已過期");
        } catch (UnknownAccountException e) {
            System.out.println("帳號不存在");
        }
        // 退出
        currentUser.logout();

數(shù)據(jù)庫的表必須是user
字段為:
userName和passWord

user表

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容