`
wj596
  • 浏览: 26623 次
  • 性别: Icon_minigender_1
  • 来自: 安徽
社区版块
存档分类
最新评论

请您先登录,才能继续操作

使用shiro保护你的springboot应用

阅读更多

项目简介

 

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 + JWT + SpringBoot应用示例代码详解

    Shiro 是一种功能强大且易于使用的 Java 安全框架,它执行身份验证、授权、加密和会话管理, 可用于保护从命令行应用程序、移动应用程序到 Web 和企业应用程序等应用的安全。Shiro 的核心组件包括 Subject、...

    springboot+shiro+redis整合

    3. **编写Shiro配置**:创建一个Shiro配置类,配置Realm(权限认证),并设置SessionManager使用RedisSessionDAO,以便将Session数据保存到Redis中。 4. **自定义Realm**:根据实际业务需求,实现自定义的...

    springboot 集成shiro代码实例

    SpringBoot集成Shiro是Java开发中常见的权限管理实践,它结合了SpringBoot的便捷性和Apache Shiro的安全特性,为Web应用程序提供了用户认证和授权的解决方案。以下是对这一主题的详细阐述: 1. **SpringBoot简介**...

    SpringBoot与Shiro整合-权限管理实战视频+源码

    ### SpringBoot与Shiro整合-权限管理实战视频+源码 #### 一、Spring Boot简介 Spring Boot是由Pivotal团队提供的全新框架,其设计目标是简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式(比如...

    SpringBoot2整合shiro

    当我们将SpringBoot2与Shiro整合时,可以构建出安全且易于管理的Web应用。本文将详细介绍如何在SpringBoot2项目中整合Shiro,并探讨相关的知识点。 ### 1. SpringBoot2基础知识 首先,我们需要了解SpringBoot的...

    springboot 1.5 集成 shiro 1.4

    - 利用 SpringBoot 的自动配置特性,你可以创建一个 `ShiroConfig` 类,注册 Shiro 的相关组件,如 SecurityManager、FilterChainResolver 等。 6. **整合 Spring Security**: - 虽然 Shiro 功能强大,但在某些...

    springBoot+shiro简单测试mvc项目

    SpringBoot和Shiro是两个非常重要的Java开发框架,它们在构建高效、简洁的企业级Web应用中发挥着关键作用。SpringBoot简化了Spring框架的配置,提供了开箱即用的功能,而Shiro则是一个轻量级的安全框架,专注于认证...

    权限管理(项目和源码):springboot与shiro整合

    - **依赖配置**:在`pom.xml`中添加Shiro的相关依赖,如`shiro-spring`,确保Spring Boot项目可以识别并使用Shiro的功能。 - **Shiro配置**:创建`ShiroConfig`类,进行Shiro的配置,包括安全 Realm(域)的设置、...

    springboot shiro 权限管理项目

    例如,我们可以设置`/login`路由使用`authc`过滤器进行登录验证,`/logout`路由使用`logout`过滤器实现用户登出,而其他受保护的路由则使用`perms`或`roles`过滤器进行权限检查。 在实际的业务逻辑中,我们需要创建...

    SpringBoot + Shiro,单WEB项目的简单权限案例

    在IT行业中,SpringBoot和Apache Shiro是两个非常重要的框架,它们在构建现代Web应用程序时起着关键作用。本文将详细讲解如何结合SpringBoot与Shiro实现一个简单的权限管理案例。 首先,SpringBoot是由Pivotal团队...

    springBoot+mybatis+shiro

    SpringBoot+Mybatis+Shiro 是一种常见的Java后端开发技术栈,用于构建高效、简洁的应用程序。这个项目可能是为了创建一个包含权限管理和数据库操作功能的Web应用。 **SpringBoot** 是Spring框架的一个轻量级扩展,...

    springboot-08-shiro.rar

    在实际项目中,我们可以创建一个简单的登录页面,然后配置Shiro的过滤器链,当用户尝试访问受保护的资源时,如果没有登录,会被重定向到登录页面。登录成功后,根据用户角色和权限分配相应的访问权限。 总结,...

    SpringBoot与Shiro整合-权限管理实战-课堂笔记.docx

    【SpringBoot与Shiro整合-权限管理实战】的课程主要关注如何将Spring Boot与Apache Shiro框架结合起来,实现高效的安全管理。Spring Boot是Spring框架的一个简化版本,旨在提高开发效率,减少配置工作,同时提供了很...

    Java SpringBoot+Mybatis+Druid+Shiro

    在SpringBoot应用中,Druid可以作为数据源,有效管理数据库连接,提高数据库操作性能。通过其内置的监控界面,开发者可以实时查看数据库连接状态,监控SQL执行效率,便于优化数据库操作。 **Shiro** Apache Shiro是...

    Shiro整合springboot报错代码

    可以尝试使用`@DependsOn`注解指定Shiro Bean的依赖顺序,或者使用`@PostConstruct`注解来确保初始化操作在特定时刻执行。 6. **shiro_login文件分析** "shiro_login"可能是登录相关的文件,可能包含登录控制器、...

    【SpringBoot】廿三、SpringBoot中整合Shiro实现权限管理.pdf

    5. 最后,启动SpringBoot应用,Shiro就会根据配置进行权限管理。在实际运行中,用户访问受保护的URL时,Shiro会检查Subject的权限,如果权限不足,会阻止访问或重定向到错误页面。 整合Shiro到SpringBoot可以极大地...

    一个简单的springboot整合shiro demo,实现了登录页面拦截,账户密码提交正确放行

    本项目"shirodemo"就是一个很好的示例,展示了如何在SpringBoot环境中配置和使用Shiro来实现基本的登录验证和权限拦截。 首先,SpringBoot提供了便捷的起步依赖(starters)来简化项目的初始化工作。在Shiro的整合...

    基于springboot,cas5.3,shiro,pac4j,rest接口获取ticket不再跳转cas server登录页

    3. 使用Shiro进行权限控制:在Shiro配置中,我们可以定义一个自定义的CasRealm,该realm使用Pac4J进行认证。这样,当用户尝试访问受保护的资源时,Shiro将通过Pac4J与CAS交互,获取ticket并验证用户身份。 4. 实现...

    springboot整合shiro.zip

    3. **编写Shiro配置类**:在SpringBoot项目中创建一个@Configuration注解的配置类,使用@Bean注解定义Shiro的FilterChainDefinitionService、SecurityManager等核心组件。 4. **创建Shiro Realm**:Realm是Shiro与...

    springboot与shiro整合—登录认证和权限管理实例项目

    3. **自定义Realm**: Realm是Shiro与应用数据源交互的接口,你需要创建一个继承自`AuthorizingRealm`的类,实现认证和授权逻辑。例如,通过JDBC连接数据库进行用户验证。 4. **过滤器链配置**:在Shiro配置中,...

Global site tag (gtag.js) - Google Analytics