shiro认证
Posted 小虾米的java梦
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shiro认证相关的知识,希望对你有一定的参考价值。
shiro权限认证:
具体的认证流程是这样的:
一般流程:
通过.ini的文件来初始化工厂,.ini的文件的好处是可以创建多个组,而.properties的文件只能创建一组。
系统默认有shiro.ini的文件,但是一般我们是自定义数据源Realm:来存放数据;
该类如下:这里采用了模拟数据库;
package cn.itcast.shiro; import java.util.HashMap; import java.util.Map; import org.apache.shiro.authc.AuthenticationException; import org.apache.shiro.authc.AuthenticationInfo; import org.apache.shiro.authc.AuthenticationToken; import org.apache.shiro.authc.SimpleAuthenticationInfo; import org.apache.shiro.authz.AuthorizationInfo; import org.apache.shiro.realm.AuthorizingRealm; import org.apache.shiro.subject.PrincipalCollection; public class TestCustomRealm extends AuthorizingRealm{ //模拟数据库 private static HashMap<String,String> userInfo=new HashMap<String,String>(); static{ userInfo.put("zhangsan","123456"); userInfo.put("lisi","1234"); } @Override public void setName(String name) { // TODO Auto-generated method stub super.setName("testCustomRealm"); } //认证功能 @Override protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException { String userCode=(String) token.getPrincipal(); String pwd=null; for (Map.Entry<String,String> entry:userInfo.entrySet()) { pwd=entry.getValue(); break; } SimpleAuthenticationInfo simpleAuthenticationInfo = new SimpleAuthenticationInfo(userCode, pwd,this.getName()); return simpleAuthenticationInfo; } //授权功能 @Override protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection arg0) { return null; } }
测试的话就是跟之前一样创建工厂,不同的是运用了.ini的文件换了。
以上是关于shiro认证的主要内容,如果未能解决你的问题,请参考以下文章
Shiro01 功能点框图架构图身份认证逻辑身份认证代码实现
全栈编程系列SpringBoot整合Shiro(含KickoutSessionControlFilter并发在线人数控制以及不生效问题配置启动异常No SecurityManager...)(代码片段