spring boot整合shiro安全框架過程解析
這篇文章主要介紹了spring boot整合shiro安全框架過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
題記:在學習了springboot和thymeleaf之后,想完成一個項目練練手,于是使用springboot+mybatis和thymeleaf完成一個博客系統(tǒng),在完成的過程中出現(xiàn)的一些問題,將這些問題記錄下來,作為自己的學習心得。在這先感謝群主TyCoding的Tumo項目,雖然本人實在太菜了,好些地方看不懂,但還是使我受益匪淺。
shiro作為一個小巧靈活的安全框架,在認證和授權(quán)方面簡約但又不簡單,十分容易上手使用。下面是整合shiro的具體流程。
1.添加依賴
<!--shiro和spring整合-->
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-spring</artifactId>
<version>1.3.2</version>
</dependency>
<!--shiro核心包-->
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-core</artifactId>
<version>1.3.2</version>
</dependency>
2.在springboot控制臺中添加基礎(chǔ)包的掃描和實體類的掃描注解
由于本人實在粗心,用try,catch將這個錯誤包起來了,所以找了一個下午的bug才發(fā)現(xiàn)。如果是用ssm整合shiro也大致一樣,只不過需要在web.xml中添加一些配置信息。
具體流程大同小異。
@SpringBootApplication(scanBasePackages = "cn.zhq")
@EntityScan("cn.zhq.system.entity")
public class MyBlogApplication {
public static void main(String[] args) {
SpringApplication.run(MyBlogApplication.class);
}
}
3.自定義realm域
個人覺得realm就相當于一個數(shù)據(jù)源 ,shiro從realm中去獲取一些數(shù)據(jù),驗證用戶的認證和授權(quán)。
3.1 usermapper接口
@Mapper
public interface UserMapper {
/**
* 根據(jù)Name查詢用戶數(shù)據(jù)
*/
SysUser findByName(String username);
}
3.2 配置文件usermapper.xml
<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="cn.zhq.system.mapper.UserMapper">
<select id="findByName" resultType="sysuser" parameterType="String">
select * from tb_user where username = #{username}
</select>
</mapper>
3.3 編寫自定義realm并繼承AuthorizingRealm
這里只貼出認證的方法。
@Autowired
private UserMapper userMapper;
@Override
protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {
//1.獲取登錄的用戶名密碼(token)
UsernamePasswordToken upToken = (UsernamePasswordToken) authenticationToken;
String username = upToken.getUsername();
String password = new String( upToken.getPassword());
//2.根據(jù)用戶名查詢數(shù)據(jù)庫
SysUser user = userMapper.findByName(username);
//3.判斷用戶是否存在或者密碼是否一致
if(user != null && user.getPassword().equals(password)) {
//4.如果一致返回安全數(shù)據(jù)
//構(gòu)造方法:安全數(shù)據(jù),密碼,realm域名
SimpleAuthenticationInfo info = new SimpleAuthenticationInfo(user,user.getPassword(),this.getName());
return info;
}
//5.不一致,返回null(拋出異常)
return null;
}
4.編寫shiro配置類
4.1 安全管理器
//配置自定義的Realm
@Bean
public AuthRealm getRealm() {
return new AuthRealm();
}
//配置安全管理器
@Bean
public SecurityManager securityManager(AuthRealm realm) {
//使用默認的安全管理器
DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager(realm);
//將自定義的realm交給安全管理器統(tǒng)一調(diào)度管理
securityManager.setRealm(realm);
return securityManager;
}
4.2 配置過濾器工廠
@Bean
public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
//1.創(chuàng)建過濾器工廠
ShiroFilterFactoryBean filterFactory = new ShiroFilterFactoryBean();
//2.設(shè)置安全管理器
filterFactory.setSecurityManager(securityManager);
//3.通用配置(跳轉(zhuǎn)登錄頁面,為授權(quán)跳轉(zhuǎn)的頁面)
filterFactory.setLoginUrl("#");//跳轉(zhuǎn)url地址
filterFactory.setUnauthorizedUrl("#");//未授權(quán)的url
return filterFactory;
}
5. 編寫controller方法
@RequestMapping(value="/login")
@ResponseBody
public String login(String username,String password) {
try{
Subject subject = SecurityUtils.getSubject();
UsernamePasswordToken uptoken = new UsernamePasswordToken(username,password);
subject.login(uptoken);
return "登錄成功";
}catch (Exception e) {
return "用戶名或密碼錯誤";
}
}
6.登陸
6.1 獲取md5加密的密碼
由于密碼是使用shiro提供的Md5加密方式。為了避免麻煩就直接打印加密之后的密碼。
Md5Hash的參數(shù)代表的含義分別是 加密的內(nèi)容 | 鹽(加密的混淆字符串) | 加密次數(shù)
System.out.println(new Md5Hash("123456","zhangbo",3).toString());


可以看到使用加密過的密碼是可以登陸成功的,但使用原始密碼是無法登陸成功的,可以在具體的業(yè)務(wù)邏輯層中添加用戶時將密碼進行加密處理。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring-boot oauth2使用RestTemplate進行后臺自動登錄的實現(xiàn)
這篇文章主要介紹了Spring-boot oauth2使用RestTemplate進行后臺自動登錄的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07
詳解 Java Maximum redirects (100) exceeded
這篇文章主要介紹了詳解 Java Maximum redirects (100) exceeded的相關(guān)資料,需要的朋友可以參考下2017-05-05
SpringCloud對服務(wù)內(nèi)某個client進行單獨配置的操作步驟
我們的微服務(wù)項目用的是springCloud,某個微服務(wù)接口因為數(shù)據(jù)處理量大,出現(xiàn)了接口超時的情況,我們需要單獨修改這一個feignClient的超時時間,所以本文介紹了SpringCloud對服務(wù)內(nèi)某個client進行單獨配置的操作步驟,需要的朋友可以參考下2023-10-10
Spring boot2X Consul如何使用Feign實現(xiàn)服務(wù)調(diào)用
這篇文章主要介紹了spring boot2X Consul如何使用Feign實現(xiàn)服務(wù)調(diào)用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-12-12
springboot 使用zookeeper實現(xiàn)分布式隊列的基本步驟
這篇文章主要介紹了springboot 使用zookeeper實現(xiàn)分布式隊列,通過ZooKeeper的協(xié)調(diào)和同步機制,多個應(yīng)用程序可以共享一個隊列,并按照先進先出的順序處理隊列中的消息,需要的朋友可以參考下2023-08-08

