学习 Spring Boot(七):集成 Apache Shiro 安全框架

栏目: 后端 · 发布时间: 7年前

内容简介:学习 Spring Boot(七):集成 Apache Shiro 安全框架

Authentication 和 Authorization

Authentication 认证,你是谁???

Authorization 授权,你能做什么???

Apache Shiro

Apache Shiro 是一个简单易用的 Java 安全框架,提供了 认证授权加密会话管理 的功能。

示例

添加依赖

编辑 pom.xml 添加以下依赖:

<dependency>  
    <groupId>org.apache.shiro</groupId>
    <artifactId>shiro-core</artifactId>
    <version>1.3.2</version>
</dependency>  
<dependency>  
    <groupId>org.apache.shiro</groupId>
    <artifactId>shiro-web</artifactId>
    <version>1.3.2</version>
</dependency>  
<dependency>  
    <groupId>org.apache.shiro</groupId>
    <artifactId>shiro-spring</artifactId>
    <version>1.3.2</version>
</dependency>

shiro-core Shiro 核心库

shiro-web Web 应用支持库

shiro-spring Spring 集成库

配置 Bean

编辑 WebConfiguration.java 文件:

@Configuration
public class WebConfiguration {

    @Bean
    public ServletListenerRegistrationBean servletListenerRegistrationBean() {
        ServletListenerRegistrationBean bean = new ServletListenerRegistrationBean();

        EnvironmentLoaderListener listener = new EnvironmentLoaderListener();
        bean.setListener(listener);

        return bean;
    }

    @Bean
    public FilterRegistrationBean filterRegistrationBean() {
        FilterRegistrationBean bean = new FilterRegistrationBean();

        ShiroFilter shiroFilter = new ShiroFilter();
        bean.setFilter(shiroFilter);

        return bean;
    }

}

说明:

配置 EnvironmentLoaderListener 监听器, EnvironmentLoaderListener 初始化了一个 WebEnvironment ,使其可以在 ServletContext 中访问

配置 ShiroFilter 过滤器, ShiroFilter 会使用 WebEnvironment 对所有过滤的请求执行必要的安全操作

编辑 ShiroConfiguration.java 文件:

@Configuration
public class ShrioConfiguration {

    @Bean
    public SecurityManager securityManager() {
        WebIniSecurityManagerFactory securityManagerFactory = new WebIniSecurityManagerFactory();
        return securityManagerFactory.getInstance();
    }

    @Bean
    public LifecycleBeanPostProcessor lifecycleBeanPostProcessor() {
        return new LifecycleBeanPostProcessor();
    }

}

说明:

通过工厂类 WebIniSecurityManagerFactory 构建一个适用于 Web 基于 ini 配置的 SecurityManager 实例

通过 LifecycleBeanPostProcessor 自动调用 Spring 中 Shiro Bean 的 init 方法和 destroy 方法

配置 shiro.ini

编辑 shiro.ini

[main]

[users]
admin = admin, admin

[roles]
admin = *

[urls]
/api/** = authcBasic

[main] 定义了 SecurityManager 的配置

[users] 定义了用户名、密码和角色

[roles] 定义了角色和权限

[urls] 定义了 URL 过滤器

参考: https://shiro.apache.org/configuration.html


以上所述就是小编给大家介绍的《学习 Spring Boot(七):集成 Apache Shiro 安全框架》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Java5.0Tiger程序高手秘笈

Java5.0Tiger程序高手秘笈

BrettMclaughlin / 东南大学出版社 / 2005-10 / 28.00元

代号为 “Tiger”的下一个 Java 版本,不只是个小改动版。在语言核心中有超过 100 项以上的变动,同时有大量的对 library 与 API 所做的加强,让开发者取得许多新的功能、工具与技术。但在如此多的变化下,应该从何处开始着手?也许可以从既长又无趣的语言规范说明书开始看起;或等待最少 500 页的概念与理论巨著出版;甚至还可以直接把玩新的 JDK 看看能够有什么发现;或者借由《Jav......一起来看看 《Java5.0Tiger程序高手秘笈》 这本书的介绍吧!

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具