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

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

内容简介:学习 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


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

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

技术之瞳——阿里巴巴技术笔试心得

技术之瞳——阿里巴巴技术笔试心得

阿里巴巴集团校园招聘笔试项目组 / 电子工业出版社 / 2016-11 / 69

《技术之瞳——阿里巴巴技术笔试心得》由阿里巴巴集团校园招聘笔试项目组所著,收集了阿里历年校招中的精华笔试题,涉 及多个领域。《技术之瞳——阿里巴巴技术笔试心得》中内容大量结合了阿里巴巴的实际工作场景,以例题、解析、习题的形式,引 导读者深入理解技术上的关键点、紧要处,夯实基础,启发思考。《技术之瞳——阿里巴巴技术笔试心得》内容不仅专业、有趣,更 是将理论知识与实践应用结合起来,以场景化的问答娓娓道......一起来看看 《技术之瞳——阿里巴巴技术笔试心得》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码