springboot+shiro整合

本文介绍了Apache Shiro作为Java安全框架的基础知识,包括认证、授权的概念,以及Shiro的三大核心组件:Subject、SecurityManager和Realm。详细阐述了SpringBoot结合Shiro的实战步骤,包括环境配置、 Realm的自定义、相关API的使用,以及静态资源的处理。通过本文,读者可以了解如何在SpringBoot项目中实现用户认证和授权功能。
摘要由CSDN通过智能技术生成

什么是shiro?

  • Apache shiro是java的一个安全框架,shiro在开发中简单易用,其中shiro可以帮我们做:认证,授权,拦截,加密,会话处理,缓存等一些功能。

什么是认证?

  • 登陆某一个网站的时候,需要判断用户使用已经登陆,判断用户是否登录就是认证

什么是授权?

  • 登陆之后,需要判断用户的权限,然后按照不同的权限跳转到不同的页面。

shiro的三大核心组件:

  • Subject

    Subject:即“当前操作用发户”。但是,在Shiro中,Subject这一概念并不仅仅指人,也可以是第三方进程、后台帐户(Daemon Account)或其他类似事物。它仅仅意味着“当前跟软件交互的东西”。但考虑到大多数目的和用途,你可以把它认为是Shiro的“用户”概念。Subject代表了当前用户的安全操作,SecurityManager则管理所有用户的安全操作。

  • SecurityManager

    SecurityManager:它是Shiro框架的核心,典型的Facade模式,Shiro通过SecurityManager来管理内部组件实例,并通过它来提供安全管理的各种服务。

  • Realm

    Realm充当了Shiro与应用安全数据间的“桥梁”或者“连接器”。也就是说,当对用户执行认证(登录)和授权(访问控制)验证时,Shiro会从应用配置的Realm中查找用户及其权限信息。

shiro相关Api

  • shiroFilterFactoryBean 设置安全管理器。
  • Token:令牌(用户名+密码的封装)----进行进行认证的封装对象
  • AuthorizationInfo 授权 用户登录
  • AuthenticationInfo 认证 权限认证
  • Realm:用户认证和授权的时候 和数据库交互的对象(这里面干的事情就是从数据库查询数据 封装成token然后取进行认证和授权)
  • Principal:用户名(还可以是用户信息的封装)
  • Credential:登录密码

springboot+shiro实战

环境准备

数据库:


Create DATABASES JK;
USER JK;

CREATE TABLE `land` (
  `username` varchar(20) NOT NULL,
  `password` varchar(20) DEFAULT NULL,
  `xinxi` varchar(20) DEFAULT NULL,
  `Author` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`username`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

在这里插入图片描述
application.yml

spring:
  datasource:
    name: druidDataSource
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
      driver-class-name: com.mysql.cj.jdbc.Driver
      url: jdbc:mysql://localhost:3306/jk?serverTimezone=GMT%2B8&amp&useSSL=false
      username: root
      password: 123456
      filters: stat,wall,log4j,config
      max-active: 100
      initial-size: 1
      max-wait: 60000
      min-idle: 1
      time-between-eviction-runs-millis: 60000
      min-evictable-idle-time-millis: 300000
      validation-query: select 'x'
      test-while-idle: true
      test-on-borrow: false
      test-on-return: false
      pool-prepared-statements: true
      max-open-prepared-statements: 50
      max-pool-prepared-statement-per-connection-size: 20
      stat-view-servlet:
        enabled: true
        login-password: 123456
        login-username: admin
mybatis:
  type-aliases-package: com.lsc.pojo
  mapper-locations: classpath:mybatis/Mapper/*.xml  #定义*Mapper.xml的位置

相关依赖

<dependencies>
		<!--druid数据源-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.23</version>
        </dependency>
        
        <!--log4j日志-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        
        <!--jdbc-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.2.5.RELEASE</version>
        </dependency>
        
        <!--数据库连接-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.19</<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值