2021-3-9 Shiro案例一

pom.xml

添加如下依赖:shiro核心、日志slf4j、druid连接池、mysql连接jar包

<dependencies>
        <dependency>
            <groupId>org.apache.shiro</groupId>
            <artifactId>shiro-core</artifactId>
            <version>1.4.2</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-simple</artifactId>
            <version>1.7.21</version>
            <scope>compile</scope>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>jcl-over-slf4j</artifactId>
            <version>1.7.21</version>
            <scope>compile</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.21</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.47</version>
        </dependency>
    </dependencies>

shiro.ini 或 jdbc_realm.ini

shiro.ini:

[users]
admin=root
zhangsan=root

jdbc_realm.ini:

[main]
jdbcRealm=org.apache.shiro.realm.jdbc.JdbcRealm
dataSource=com.alibaba.druid.pool.DruidDataSource
dataSource.driverClassName=com.mysql.jdbc.Driver
dataSource.url=jdbc:mysql:///train?userUnicode=true&characterEncoding=UTF-8&useSSL=false
dataSource.username=root
dataSource.password=""
jdbcRealm.dataSource=$dataSource
securityManager.realms=$jdbcRealm

HelloWorld主类

public class HelloWorld {
    public static void main(String[] args) {
        //1.读取配置文件,初始化工厂对象
        Factory<SecurityManager> factory=new IniSecurityManagerFactory("classpath:shiro.ini");
        //2.获取SecurityManager实例
        SecurityManager securityManage=factory.getInstance();
        //3.将SecurityManager 绑定到工具类
        SecurityUtils.setSecurityManager(securityManage);
        //4.通过SecurityUtils得到当前登录的用户
        Subject subject=SecurityUtils.getSubject();
        //5.创建令牌对象
        UsernamePasswordToken token=new UsernamePasswordToken("admin","root");
        try {
            //6.登录
            subject.login(token);
            System.out.println("身份验证成功!");
        } catch (AuthenticationException e) {
            e.printStackTrace();
            System.out.println("身份验证失败!");
        }
        //7.注销
        subject.logout();
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值