项目简介
springboot中使用shiro大都是通过shiro-spring.jar进行的整合的,虽然不是太复杂,但是也无法做到spring-boot-starter风格的开箱即用。
项目中经常用到的功能比如:验证码、密码错误次数限制、账号唯一用户登陆、动态URL过滤规则、无状态鉴权等等,shiro还没有直接提供支持。
jsets-shiro-spring-boot-starter对这些常用的功能进行了封装和自动导入,少量的配置就可以应用在项目中。
1、项目地址:jsets-shiro-spring-boot-starter
2、使用说明:使用说明
3、示例应用:jsets-shiro-demo
如果您对这个组件感兴趣请star收藏,在使用这个组件中有任何问题或意见都可以在这里交流,欢迎提交代码。
已完成功能
1、spring-boot-starter风格的开箱即用。
2、区分ajax请求和普通请求,普通请求通过跳转来响应未登陆和未授权,AJAX请求通过状态码和消息响应未登陆和未授权。
3、集成jcaptcha验证码。
4、密码输入错误,重试次数限制。
5、账号唯一用户登陆,一个账号只允许一个用户登陆。
6、redis缓存(单机、分布式)支持,认证\授权数据缓存同步。
7、动态URL过滤规则。
8、无状态认证授权支持,共存有状态和无状态两种鉴权方式,无状态鉴权支持JWT(JSON WEB TOKEN)、HMAC(哈希消息认证码)两种协议。
9、在线session管理,强制用户下线功能。
后续计划功能
1、cas单点登陆集成
2、oauth2.0支持
快速体验
1、pom.xml中添加:
<dependency>
<groupId>org.jsets</groupId>
<artifactId>jsets-shiro-spring-boot-starter</artifactId>
<version>0.0.1</version>
</dependency>
2、application.properties添加下面配置:
###jsets-shiro配置
#登陆页面
jsets.shiro.login-url=/login
#登陆成功页面
jsets.shiro.login-success-url=/index
#忽略拦截的URL,静态资源
jsets.shiro.filte-rules[0]=/assets/**-->anon
#登陆
jsets.shiro.filte-rules[1]=/login/**-->authc
#退出
jsets.shiro.filte-rules[2]=/logout/**-->logout
#所有路径,断言session中存在用户
jsets.shiro.filte-rules[3]=/**-->user
3、创建Controller类IndexAction.java:
@Controller
public class IndexAction {
@RequestMapping("/")
public String def() {
return "index";
}
@RequestMapping("/index")
public String index() {
return "index";
}
@RequestMapping("/login")
public String login() {
return "login";
}
}
4、创建登陆页面login.html:
<form class="login-form" action="${ctx}/login" method="post">
<div class="form-item">
用户名:<input type="text" name="username" />
</div>
<div class="form-item">
密码:<input type="password" name="password" />
</div>
<div class="form-item">
<button type="submit">登录</button>
</div>
</form>
<!-- 认证信息 -->
<font color="red">${Request["shiro_auth_message"]!}</font>
5、创建主页index.html:
<div class="body">
欢迎您:${Session.shiro_current_user.account!}
<br>
退出:<a href="${ctx}/logout">退了</a>
</div>
6、启用jsets-shiro-spring-boot-starter:
@SpringBootApplication
@EnableJsetsShiro
public class Application{
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
启动springboot应用,控制台会打印出组件预置的体验账号和密码:
使用这个账号和密码就可以登陆系统了。
鉴权要素
鉴:认证(Authentication)即证明您是账号表示的那个人,基于form的认证中使用口令(密码),rest api认证中使用令牌(token)。
权:权限验证(Authorization)即根据一个判断规则来验证您是否能执行一个操作。
认证的过程需要账号数据,这个数据至少包含三个元素:账号(用户名)、密码、账号是否可用。
jsets-shiro-spring-boot-starter中使用Account接口表示账号数据、使用ShiroAccountProvider接口为鉴权操作提供Account数据,数据来源不限比如可以从数据库、文件、LDAP、远程服务等各种方式加载。
权限验证的过程需要权限数据和规则数据,权限泛指能否操作资源,角色是权限的集合,如果使用权限来表示一个用户能操作的资源显然不方便,所以大部分系统的安全模型都是基于RBAC(Role-Based Access Control 基于角色的权限访问控制)的。jsets-shiro-spring-boot-starter同样使用ShiroAccountProvider接口为鉴权操作提供权限(角色)数据,数据来源不限。
具体参见"使用说明--接入用户数据"一章。
规则数据,如果没有规则就不存在判断,权限验证也就无从谈起,在shiro中规则表示成这样:
article/update=roles[role_editor]
article/delete=roles[role_chief]
article/publish=roles[role_chief]
"article/update"就是操作的资源,"roles[role_editor]"是判断标准,表示用户的角色列表中包含"role_editor"角色,操作加上判断标准就是规则。jsets-shiro-spring-boot-starter中您可以在application.properties中配置这样的规则。也可以通过shiro的AOP方式配置规则,类似于这样:
@RequiresRoles("role_editor")
public void update(Article article){
}
这两种方式是有局限的,比如角色-资源的对应关系发生变更,比如新增了一种角色,那就只能修改配置或者代码然后重启动系统才能使得这些变更生效。实际开发中则更希望通数据库查询出角色-资源的对应数据,动态生成URL规则,当角色-资源的对应关系发生变更时能刷新并立即用户这些规则。
您可以通过ShiroFilteRulesProvider接口为鉴权操作提供规则数据,并且支持实时刷新应用这些规则。
具体参见"使用说明--动态URL过滤"一章。
无状态鉴权
无状态(Stateless)鉴权通常应用在微服务(REST API)架构中,使用数字摘要(签名)技术生成一个token作为认证和授权的凭证,整个认证和授权过程不依赖于cookie或session,服务端不保留客户端状态因此每次请求都要携带这个token。
jsets-shiro-spring-boot-starter提供两种无状态鉴权方式,分别是散列消息认证码(HMAC)、JSON WEB TOKEN(JWT)。
HMAC适合端到端的鉴权,即客户端拿着签名让服务端进行验签。
JWT适合客户端询问系统B是否有权访问系统C和系统N如果有请开份凭证,然后拿着凭证让系统C和系统N进行验签。
JWT是自包含的,令牌中携带访问主张(角色或权限),所以JWT鉴权不需要查询数据。HMAC鉴权则需要查询数据库获取角色或权限数据。HMAC和JWT鉴权过程均不产生session。
如果您的系统即有状态鉴权(即基于FORM的登陆认证)又有无状态鉴权(即提供rest接口),毕竟不是所有的系统都做了服务化拆分的,默认情况下HMAC也是使用ShiroAccountProvider接口为鉴权操作提供身份认证和权限验证数据,和有状态鉴权公用一套数据。如您想拆分它们,即HMAC使用自己的鉴权数据,可以使用ShiroStatelessAccountProvider为无状态鉴权提供数据。
具体参见"使用说明--无状态鉴权"一章。
组件扩展
JsetsShiroConfigurationAdapter是shiro配置的适配器,通过它您可以定制Realm、filter、SessionDAO、CacheManager等。
示例展示
jsets-shiro-demo是jsets-shiro-spring-boot-starter是应用示例,做的不是很精细,主要为了演示功能实现。
主界面:
验证码:
用户被踢出:
密码输入错误重试次数限制:
角色列表:
权限拦截:
资源分配:
权限验证通过:
HMAC验签通过:
HMAC签名失效:
HMAC签名无效:
JWT权限验证失败:
JWT需要身份认证:
在线用户列表:
强制用户下线:
更多功能和特性请参见jsets-shiro-spring-boot-starter源码和使用说明。
相关推荐
Shiro 是一种功能强大且易于使用的 Java 安全框架,它执行身份验证、授权、加密和会话管理, 可用于保护从命令行应用程序、移动应用程序到 Web 和企业应用程序等应用的安全。Shiro 的核心组件包括 Subject、...
3. **编写Shiro配置**:创建一个Shiro配置类,配置Realm(权限认证),并设置SessionManager使用RedisSessionDAO,以便将Session数据保存到Redis中。 4. **自定义Realm**:根据实际业务需求,实现自定义的...
SpringBoot集成Shiro是Java开发中常见的权限管理实践,它结合了SpringBoot的便捷性和Apache Shiro的安全特性,为Web应用程序提供了用户认证和授权的解决方案。以下是对这一主题的详细阐述: 1. **SpringBoot简介**...
### SpringBoot与Shiro整合-权限管理实战视频+源码 #### 一、Spring Boot简介 Spring Boot是由Pivotal团队提供的全新框架,其设计目标是简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式(比如...
当我们将SpringBoot2与Shiro整合时,可以构建出安全且易于管理的Web应用。本文将详细介绍如何在SpringBoot2项目中整合Shiro,并探讨相关的知识点。 ### 1. SpringBoot2基础知识 首先,我们需要了解SpringBoot的...
- 利用 SpringBoot 的自动配置特性,你可以创建一个 `ShiroConfig` 类,注册 Shiro 的相关组件,如 SecurityManager、FilterChainResolver 等。 6. **整合 Spring Security**: - 虽然 Shiro 功能强大,但在某些...
SpringBoot和Shiro是两个非常重要的Java开发框架,它们在构建高效、简洁的企业级Web应用中发挥着关键作用。SpringBoot简化了Spring框架的配置,提供了开箱即用的功能,而Shiro则是一个轻量级的安全框架,专注于认证...
- **依赖配置**:在`pom.xml`中添加Shiro的相关依赖,如`shiro-spring`,确保Spring Boot项目可以识别并使用Shiro的功能。 - **Shiro配置**:创建`ShiroConfig`类,进行Shiro的配置,包括安全 Realm(域)的设置、...
例如,我们可以设置`/login`路由使用`authc`过滤器进行登录验证,`/logout`路由使用`logout`过滤器实现用户登出,而其他受保护的路由则使用`perms`或`roles`过滤器进行权限检查。 在实际的业务逻辑中,我们需要创建...
在IT行业中,SpringBoot和Apache Shiro是两个非常重要的框架,它们在构建现代Web应用程序时起着关键作用。本文将详细讲解如何结合SpringBoot与Shiro实现一个简单的权限管理案例。 首先,SpringBoot是由Pivotal团队...
SpringBoot+Mybatis+Shiro 是一种常见的Java后端开发技术栈,用于构建高效、简洁的应用程序。这个项目可能是为了创建一个包含权限管理和数据库操作功能的Web应用。 **SpringBoot** 是Spring框架的一个轻量级扩展,...
在实际项目中,我们可以创建一个简单的登录页面,然后配置Shiro的过滤器链,当用户尝试访问受保护的资源时,如果没有登录,会被重定向到登录页面。登录成功后,根据用户角色和权限分配相应的访问权限。 总结,...
【SpringBoot与Shiro整合-权限管理实战】的课程主要关注如何将Spring Boot与Apache Shiro框架结合起来,实现高效的安全管理。Spring Boot是Spring框架的一个简化版本,旨在提高开发效率,减少配置工作,同时提供了很...
在SpringBoot应用中,Druid可以作为数据源,有效管理数据库连接,提高数据库操作性能。通过其内置的监控界面,开发者可以实时查看数据库连接状态,监控SQL执行效率,便于优化数据库操作。 **Shiro** Apache Shiro是...
可以尝试使用`@DependsOn`注解指定Shiro Bean的依赖顺序,或者使用`@PostConstruct`注解来确保初始化操作在特定时刻执行。 6. **shiro_login文件分析** "shiro_login"可能是登录相关的文件,可能包含登录控制器、...
5. 最后,启动SpringBoot应用,Shiro就会根据配置进行权限管理。在实际运行中,用户访问受保护的URL时,Shiro会检查Subject的权限,如果权限不足,会阻止访问或重定向到错误页面。 整合Shiro到SpringBoot可以极大地...
3. 使用Shiro进行权限控制:在Shiro配置中,我们可以定义一个自定义的CasRealm,该realm使用Pac4J进行认证。这样,当用户尝试访问受保护的资源时,Shiro将通过Pac4J与CAS交互,获取ticket并验证用户身份。 4. 实现...
本项目"shirodemo"就是一个很好的示例,展示了如何在SpringBoot环境中配置和使用Shiro来实现基本的登录验证和权限拦截。 首先,SpringBoot提供了便捷的起步依赖(starters)来简化项目的初始化工作。在Shiro的整合...
3. **编写Shiro配置类**:在SpringBoot项目中创建一个@Configuration注解的配置类,使用@Bean注解定义Shiro的FilterChainDefinitionService、SecurityManager等核心组件。 4. **创建Shiro Realm**:Realm是Shiro与...
3. **自定义Realm**: Realm是Shiro与应用数据源交互的接口,你需要创建一个继承自`AuthorizingRealm`的类,实现认证和授权逻辑。例如,通过JDBC连接数据库进行用户验证。 4. **过滤器链配置**:在Shiro配置中,...