核心类简介
  
  xxxToken:用户凭证 xxxFilter:生产token,设置登录成功,登录失败处理方法,判断是否登录连接等 xxxRealm:依据配置的支持Token来认证用户信息,授权用户权限
  
  核心配置
  
  Shrio整体配置:ShrioConfig.java
  
  @Bean
  
  public ShiroFilterFactoryBean shirFilter(SecurityManager securityManager) {
  
  ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
  
  shiroFilterFactoryBean.setSecurityManager(securityManager);
  
  Map<String, Filter> filters = shiroFilterFactoryBean.getFilters();
  
  //将自定义 的FormAuthenticationFilter注入shiroFilter中
  
  filters.put("authc", new AuthenticationFilter());
  
  filters.put("wechat",new ExWechatAppFilter());
  
  shiroFilterFactoryBean.setFilters(filters);
  
  Map<String, String> filterChainDefinitionMap = new LinkedHashMap<String, String>();
  
  ...
  
  //建立url和filter之间的关系
  
  filterChainDefinitionMap.put("/wechat/**","wechat");
  
  filterChainDefinitionMap.put("/**", "authc");
  
  ...
  
  shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
  
  return shiroFilterFactoryBean;
  
  }
  
  @Bean
  
  public SecurityManager securityManager() {
  
  DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
  
  securityManager.setAuthenticator(exModularRealmAuthenticator());
  
  List<Realm> realms = new ArrayList<>();
  
  //设置多Realm
  
  realms.add(systemRealm());
  
  realms.add(wechatAppRealm());
  
  securityManager.setRealms(realms);
  
  securityManager.setCacheManager(ehCacheManager());
  
  securityManager.setRememberMeManager(cookieRememberMeManager());
  
  return securityManager;
  
  }
  
  //重要!!定义token与Realm关系,设置认证策略
  
  public MyModularRealmAuthenticator www.tianjuyuLe.cn myModularRealmAuthenticator(){
  
  MyModularRealmAuthenticator authenticator = new MyModularRealmAuthenticator();
  
  FirstSuccessfulStrategy strategy = new FirstSuccessfulStrategy();
  
  authenticator.setAuthenticationStrategy(strategy);
  
  return authenticator;
  
  }
  
  @Bean
  
  public SystemRealm systemRealm() {
  
  SystemRealm systemRealm = new SystemRealm();
  
  systemRealm.setAuthorizationCachingEnabled(true);
  
  systemRealm.setAuthorizationCacheName("authorization");
  
  systemRealm.setCredentialsMatcher(hashedCredentialsMatcher());
  
  return systemRealm;
  
  }
  
  @Bean
  
  public WechatAppRealm WechatAppRealm( www.dfgjpt.com){
  
  WechatAppRealm wechatAppRealm www.huarenyl.cn= new WechatAppRealm();
  
  wechatAppRealm.setAuthorizationCachingEnabled(false);
  
  return WechatAppRealm;
  
  }
  
  Realm,Token关联关系配置:MyModularRealmAuthenticator.java
  
  public class MyModularRealmAuthenticator extends ModularRealmAuthenticator {
  
  @Override
  
  protected AuthenticationInfo www.yongshi123.cn doAuthenticate(www.tiaotiaoylzc.com AuthenticationToken authenticationToken) throws AuthenticationException {
  
  assertRealmsConfigured();
  
  //依据Realm中配置的支持Token来进行过滤
  
  List<Realm> realms www.yongshiyule178.com/ = this.getRealms()
  
  .stream()
  
  .filter(realm -> realm.supports(www.michenggw.com authenticationToken))
  
  .collect(Collectors.toList());
  
  if (realms.size() == 1) {
  
  return doSingleRealmAuthentication(realms.get(0), authenticationToken);
  
  } else {
  
  return doMultiRealmAuthentication(realms, authenticationToken);
  
  }
  
  }
  
  }
  
  认证授权配置:Realm.java
  
  public class SystemRealm extends AuthorizingRealm {
  
  ...
  
  @Override
  
  protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
  
  //重要!!多realm每个都会执行授权相关信息,此处进行过滤
  
  if(principals.fromRealm(getName()).isEmpty()){
  
  return null;
  
  }
  
  //授权代码...
  
  return authorizationInfo;
  
  }
  
  /**
  
  * 主要是用来进行身份认证的
  
  */
  
  @Override
  
  protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token)
  
  throws AuthenticationException {
  
  //生产AuthenticationInfo代码...
  
  //校验的部分由配置的credentialsMatcher进行处理
  
  return authenticationInfo;
  
  }
  
  /**
  
  * 扩展认证token
  
  *
  
  * @param authenticationToken
  
  * @return boolean
  
  * @author mjm
  
  * @date 2018/7/3 12:32
  
  */
  
  @Override
  
  public boolean supports(AuthenticationToken authenticationToken) {
  
  //设置此Realm支持的Token
  
  return authenticationToken != null && (authenticationToken instanceof UsernamePasswordToken );
  
  }
  
  }
  
  过滤器配置:AuthenticationFilter.java
  
  基础的过滤器类型:官网中默认有很多已实现的过滤器,可依据需求扩展
  
  public class AuthenticationFilter extends FormAuthenticationFilter {
  
  ....
  
  /**
  
  * 创建令牌
  
  *
  
  * @param servletRequest ServletRequest
  
  * @param servletResponse ServletResponse
  
  * @return 令牌
  
  */
  
  @Override
  
  protected AuthenticationToken createToken(ServletRequest servletRequest, ServletResponse servletResponse) {
  
  //依据request中不同的参数创建不同的token...
  
  return new xxxToken(...);
  
  }
  
  ....

Spring Boot -Shiro配置多Realm的更多相关文章

  1. (39.4) Spring Boot Shiro权限管理【从零开始学Spring Boot】

    在读此文章之前您还可能需要先了解: (39.1) Spring Boot Shiro权限管理[从零开始学Spring Boot] http://412887952-qq-com.iteye.com/b ...

  2. (39.3) Spring Boot Shiro权限管理【从零开始学Spring Boot】

    在学习此小节之前您可能还需要学习: (39.1) Spring Boot Shiro权限管理[从零开始学Spring Boot] http://412887952-qq-com.iteye.com/b ...

  3. (39.2). Spring Boot Shiro权限管理【从零开始学Spring Boot】

    (本节提供源代码,在最下面可以下载) (4). 集成Shiro 进行用户授权 在看此小节前,您可能需要先看: http://412887952-qq-com.iteye.com/blog/229973 ...

  4. (39.1) Spring Boot Shiro权限管理【从零开始学Spring Boot】

    (本节提供源代码,在最下面可以下载)距上一个章节过了二个星期了,最近时间也是比较紧,一直没有时间可以写博客,今天难得有点时间,就说说Spring Boot如何集成Shiro吧.这个章节会比较复杂,牵涉 ...

  5. Spring Boot Shiro 权限管理

    Spring Boot Shiro 权限管理 标签: springshiro 2016-01-14 23:44 94587人阅读 评论(60) 收藏 举报 .embody{ padding:10px ...

  6. spring boot shiro redis整合基于角色和权限的安全管理-Java编程

    一.概述 本博客主要讲解spring boot整合Apache的shiro框架,实现基于角色的安全访问控制或者基于权限的访问安全控制,其中还使用到分布式缓存redis进行用户认证信息的缓存,减少数据库 ...

  7. Spring Boot Shiro

    Shiro 核心 API Subject:用户主体(每次请求都会创建Subject). principal:代表身份.可以是用户名.邮件.手机号码等等,用来标识一个登录主体的身份. credentia ...

  8. Spring Boot Shiro 使用教程

    Apache Shiro 已经大名鼎鼎,搞 Java 的没有不知道的,这类似于 .Net 中的身份验证 form 认证.跟 .net core 中的认证授权策略基本是一样的.当然都不知道也没有关系,因 ...

  9. 玩转spring boot——properties配置

    前言 在以往的java开发中,程序员最怕大量的配置,是因为配置一多就不好统一管理,经常出现找不到配置的情况.而项目中,从开发测试环境到生产环境,往往需要切换不同的配置,如测试数据库连接换成生产数据库连 ...

随机推荐

  1. Docker学习笔记 — 开启Docker远程访问

    默认情况下,Docker守护进程会生成一个socket(/var/run/docker.sock)文件来进行本地进程通信,而不会监听任何端口,因此只能在本地使用docker客户端或者使用Docker ...

  2. 【本地服务器】利用openssl生成证书

    (一)下载openssl软件,解压,进入bin目录 下载地址 (二)1.在当前bin目录,按住shift键右击,选择"在此处打开命令窗口" 2.打开cmd命令窗口之后,在窗口中输入 ...

  3. Exp1 PC平台逆向破解(5)M

    Exp1 PC平台逆向破解(5)M [ 直接修改程序机器指令,改变程序执行流程] 用命令cp pwn1 20155320备份pwn1 输入objdump -d 20155320反汇编,找到call指令 ...

  4. 使用Gzip压缩数据,加快页面访问速度

                 在返回的json数据量大时,启用Gzip压缩,可以提高传输效率.下面为Gzip压缩对json字符串压缩并输出到页面的代码. 一.代码 /** 向浏览器输出字符串响应数据,启用 ...

  5. Luogu P1120 小木棍 [数据加强版]

    看了题目心中只有一个字——搜索!!! 但是很显然,朴素的搜索(回溯)绝壁超时. 剪枝&优化(要搞很多,要不然过不了) 1:从小到大搜索它们的因数,这样找到就exit. 2:将数据从大到小排序, ...

  6. Codeforces 954C Matrix Walk (思维)

    题目链接:Matrix Walk 题意:设有一个N×M的矩阵,矩阵每个格子都有从1-n×m的一个特定的数,具体数的排列如图所示.假设一个人每次只能在这个矩阵上的四个方向移动一格(上下左右),给出一条移 ...

  7. 第二十九章 springboot + zipkin + mysql

    zipkin的数据存储可以存在4个地方: 内存(仅用于测试,数据不会持久化,zipkin-server关掉,数据就没有了) 这也是之前使用的 mysql 可能是最熟悉的方式 es Cassandra ...

  8. redis安装启动和数据操作

    redis安装和启动 1.安装包下载地址 >> redis基本数据类型 string(字符串和数值) .list(列表/队列).hashmap(哈希表[键唯一]). set(集合[值唯一] ...

  9. FastDFS教程Ⅰ-文件服务器安装与Nginx配置

    1.简介     FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等,解决了大容量存储和负载均衡的问题.特别适合以文件为载 ...

  10. kubeadm安装kubernetes 1.13.1集群完整部署记录

    k8s是什么 Kubernetes简称为k8s,它是 Google 开源的容器集群管理系统.在 Docker 技术的基础上,为容器化的应用提供部署运行.资源调度.服务发现和动态伸缩等一系列完整功能,提 ...