Shiro搭建

1.在pom.xml中导入jar包

<dependency>
  <groupId>org.apache.shiro</groupId>
  <artifactId>shiro-core</artifactId>
  <version>1.2.3</version>
</dependency>

2.首先准备一些用户身份 / 凭据(shiro.ini)

[users]
root=123456,admin
test=000000,test


[roles]
admin=*
test=select,add,update

3.tes:

public class ShiroTest {
    public static void main(String[] args) {
        Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro.ini");
        SecurityManager securityManager = factory.getInstance();

		// 注入SecurityManager
        SecurityUtils.setSecurityManager(securityManager);

		// 获取当前的 Subject. 调用 SecurityUtils.getSubject();
        Subject subject = SecurityUtils.getSubject();
        
		// 把用户名和密码封装为 UsernamePasswordToken 对象
        UsernamePasswordToken token = new UsernamePasswordToken("root","123456");


        try {
            subject.login(token);
            if(subject.isAuthenticated()){
                System.out.println("登录成功");
                if (subject.hasRole("admin")){
                    System.out.println("有admin");
                }else{
                    System.out.println("没有");
                }
                //这行代码用来判断已登陆用户是否具有某权限
                if(subject.isPermitted("select")){
                    System.out.println("有select");
                }else{
                    System.out.println("没select");
                }
            }

            System.out.println("");
        } catch (AuthenticationException e) {
            System.out.println("用户名或密码错误");
        }

    }
}


实际开发中从MySQL中查询:
1.pom.xml导入jar包

  <!--jdbc类-->
  <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
        <version>5.1.32</version>
    </dependency>

      <dependency>
          <groupId>org.springframework</groupId>
          <artifactId>spring-jdbc</artifactId>
        <version>5.0.3.RELEASE</version>
      </dependency>


    <!--shiro核心类库-->
    <dependency>
      <groupId>org.apache.shiro</groupId>
      <artifactId>shiro-core</artifactId>
      <version>1.2.3</version>
    </dependency>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值