0.pom文件引入

        <!-- SECURITY begin --><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-core</artifactId><version>${shiro.version}</version></dependency><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-quartz</artifactId><version>${shiro.version}</version></dependency><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-spring</artifactId><version>${shiro.version}</version></dependency><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-cas</artifactId><version>${shiro.version}</version></dependency><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-web</artifactId><version>${shiro.version}</version></dependency><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-ehcache</artifactId><version>${shiro.version}</version></dependency><dependency><groupId>commons-collections</groupId><artifactId>commons-collections</artifactId><version>3.2.1</version></dependency><!-- SECURITY end -->

1.在web.xml中配置Shiro的过滤器

DelegatingFilterProxy作用是自动到spring容器查找 名字为shiroFilter(filter-name)的bean并把所有Filter的操作委托给它。 然后将ShiroFilter配置到spring容器即可.
DelegatingFilterProxy实际上是一个filter的代理对象,默认情况下,Spring会到IOC容器中查找和对应的bean.也可以通过targetBeanName的初始化参数来配置filter bean的id.

<filter><filter-name>shiroFilter</filter-name><filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class><init-param><param-name>targetFilterLifecycle</param-name><param-value>true</param-value></init-param>
</filter>
<filter-mapping><filter-name>shiroFilter</filter-name><url-pattern>/*</url-pattern>
</filter-mapping>

2.在Spring-shiro.xml中配置

1.配置SecurityManager.

<bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager"><property name="realm" ref="systemAuthorizingRealm" /><property name="cacheManager" ref="cacheManager" /><property name="sessionManager" ref="sessionManager" />
</bean>

Realm实现 域 安全数据源 我们认证和权限信息都是从Realm获取的(继承自org.apache.shiro.realm)

<bean id="systemAuthorizingRealm" class="com.yl.video.security.SystemAuthorizingRealm"><property name="credentialsMatcher" ref="credentialsMatcher" />
</bean>

一个自定义的Redis缓存管理器(自定义类继承自org.apache.shiro.cache.CacheManager)

<!--以后会使用Redis的缓存管理<bean id="cacheManager" class="com.yl.video.security.cache.JedisCacheManager">
</bean> --><!-- 暂时使用Ehcache -->
<bean id="cacheManager" class="org.apache.shiro.cache.ehcache.EhCacheManager"><property name="cacheManagerConfigFile" value="classpath:ehcache.xml" />
</bean>

Shiro提供了完整的企业级会话管理功能,不依赖于底层容器(如web容器tomcat), 不管JavaSE还是JavaEE环境都可以使用,提供了会话管理、会话事件监听、会话存储/持久化、容器无关的集群、失效/过期支持、对Web的透明支持、SSO单点登录的支持等特性。即直接使用Shiro的会话管理可以直接替换如Web容器的会话管理 Shiro提供了三个默认实现: DefaultSessionManager:DefaultSecurityManager使用的默认实现,用于JavaSE环境; ServletContainerSessionManager:DefaultWebSecurityManager使用的默认实现,用于Web环境,其直接使用Servlet容器的会话; DefaultWebSessionManager:用于Web环境的实现,可以替代ServletContainerSessionManager,自己维护着会话,直接废弃了Servlet容器的会话管理。

<bean id="sessionManager" class="org.apache.shiro.web.session.mgt.DefaultWebSessionManager"><property name="globalSessionTimeout" value="180300000" /><property name="deleteInvalidSessions" value="true" /><property name="sessionValidationSchedulerEnabled" value="true" /><property name="sessionValidationScheduler" ref="sessionValidationScheduler" /><property name="sessionDAO" ref="sessionDAO" /><property name="sessionIdCookieEnabled" value="true" /><property name="sessionIdCookie" ref="sessionIdCookie" />
</bean><!-- 会话验证调度器 -->
<bean id="sessionValidationScheduler"class="org.apache.shiro.session.mgt.quartz.QuartzSessionValidationScheduler"><property name="sessionValidationInterval" value="18000" /><property name="sessionManager" ref="sessionManager" />
</bean><!-- <bean id="sessionDAO" class="com.yl.video.security.session.JedisSessionDAO"> <property name="sessionIdGenerator" ref="sessionIdGenerator" /> </bean> --><!-- sessionDao的实现方式使用CacheSessionDao暂时不用Redis的SessionDao -->
<bean id="sessionDAO" class="com.yl.video.security.session.CacheSessionDAO"><property name="sessionIdGenerator" ref="sessionIdGenerator" /><property name="activeSessionsCacheName" value="activeSessionsCache" /><property name="cacheManager" ref="cacheManager" />
</bean><bean id="sessionIdGenerator" class="org.apache.shiro.session.mgt.eis.JavaUuidSessionIdGenerator" /><!-- 会话Cookie模板 sessionIdCookie是用于生产Session ID Cookie的模板; -->
<!-- 指定本系统SESSIONID, 默认为: JSESSIONID 问题: 与SERVLET容器名冲突, 如JETTY, TOMCAT 等默认JSESSIONID, 当跳出SHIRO SERVLET时如ERROR-PAGE容器会为JSESSIONID重新分配值导致登录会话丢失! httpOnly 如果设置为true,则客户端不会暴露给客户端脚本代码,使用HttpOnly cookie有助于减少某些类型的跨站点脚本攻击 -->
<bean id="sessionIdCookie" class="org.apache.shiro.web.servlet.SimpleCookie"><!-- cookie的name,对应的默认是 JSESSIONID --><constructor-arg name="name" value="SHAREJSESSIONID" /><property name="httpOnly" value="true" /><property name="maxAge" value="1000000" />
</bean>

2.配置lifecycleBeanPostProcessor 可以自动的来调用配置在Spring IOC 容器中 shiro bean的生命周期方法.

<!-- 保证实现了Shiro内部lifecycle函数的bean执行 -->
<bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor" />

3.启动IOC容器中使用Shiro的注解.但必须配置了lifecycleBeanPostProcessor后才可以调用.

<!-- AOP式方法级权限检查 -->
<beanclass="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator"depends-on="lifecycleBeanPostProcessor"><property name="proxyTargetClass" value="true" />
</bean>
<beanclass="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor"><property name="securityManager" ref="securityManager" />
</bean>

4.MethodInvokingFactoryBean (???)

<!-- 相当于调用SecurityUtils.setSecurityManager(securityManager) -->
<beanclass="org.springframework.beans.factory.config.MethodInvokingFactoryBean"><property name="staticMethod"value="org.apache.shiro.SecurityUtils.setSecurityManager" /><property name="arguments" ref="securityManager" />
</bean>

5 加密

<!-- 凭证匹配器 shiro 为我们提供了加密的功能 md5 是不可逆的 AES 对称加密,可以加密解密 RSA 非对称加密(公钥 私钥)(shiro 没有提供) -->
<bean id="credentialsMatcher"class="com.yl.video.security.RetryLimitHashedCredentialsMatcher"><constructor-arg ref="cacheManager" /><!-- 指定加密的方式是md5 --><property name="hashAlgorithmName" value="md5" /><!--进行两次md5 加盐 --><property name="hashIterations" value="2" /><property name="storedCredentialsHexEncoded" value="true" />
</bean>

6.Shiro的Web过滤器
6.1 bean的id必须和web.xml文件中配置的DelegatingFilterProxy的一致.

<!-- Shiro的Web过滤器 ShiroFilter是整个Shiro的入口点,用于拦截需要安全控制的请求进行处理,这个之前已经用过了 -->
<bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean"><property name="securityManager" ref="securityManager" /><property name="loginUrl" value="/admin/login.action" /><property name="filterChainDefinitions"><value><!-- “/authenticated.jsp = authc”表示访问该地址用户必须身份验证通过(Subject.isAuthenticated()==true); 而“/** = user”表示访问该地址的用户是身份验证通过或RememberMe登录的都可以anno 表示不需要认证和权限检查就可以访问 -->/static/** = anon/admin/addSysUser.action=anon<!-- 退出登录地址 -->/admin/logout.action =logout/admin/** = user</value></property>
</bean>

转载于:https://www.cnblogs.com/esileme/p/7467423.html

Shiro笔记(二)Shiro集成SpringMVC的环境配置相关推荐

  1. laravel5.8笔记一:安装与服务器环境配置

    laravel版本:5.8 环境要求: PHP >= 7.1.3 OpenSSL PHP 扩展 PDO PHP 扩展 Mbstring PHP 扩展 Tokenizer PHP 扩展 XML P ...

  2. Spring Boot基础学习笔记05:Spring Boot多环境配置

    文章目录 零.学习目标 1.掌握使用Profile文件进行多环境配置 2.掌握使用@Profile注解进行多环境配置 3.熟悉随机值设置以及参数间引用 一.项目进行多环境配置的必要性 二.使用Prof ...

  3. cocos2d-x的初步学习二十一之iosandroid跨平台环境配置

    这篇文章中,我们将来构建下跨平台开发的环境配置,我自己也是参考了别人了文章,折腾了几个小时,尤其是android的配置相对麻烦些.... 参考自子龙山人:http://www.cnblogs.com/ ...

  4. [学习笔记-VS Code篇]Windows下环境配置

    Windows下VS Code环境配置 VS Code安装 mingw-w64安装 插件安装 VS Code测试1 cmake安装 opencv安装 项目配置 从入门到放弃,配个opencv永远找不到 ...

  5. J2EE开发笔记(一)—— J2EE开发环境配置

    最近电脑重新装了系统,所有J2EE相关软件都需要重新安装配置,现将其中部分软件安装配置过程记录如下,方便参考查阅. tips:所有软件均可在官网免费下载,尽量不要使用第三方提供的软件包. Java开发 ...

  6. Z3 SMTsolver 学习笔记(一) ——安装,环境配置篇

    https://github.com/Z3Prover/z3 源文件从这里可以下载.然后看看readMe文件. Windows7下使用Visual Studio 命令符建立Z3 着急的兄弟可以直接跳到 ...

  7. Maven学习笔记(二) :Maven的安装与配置

    在Windows上安装Maven:  1.  首先检查安装JDK 通过命令行运行命令:echo %JAVA_HOME%和java  -version,能够查看当前java的安装文件夹及java的版本号 ...

  8. 前端进阶(二)webpack开发服务器环境配置

    webpack开发服务器 webpack 使用 babel 处理高版本的 js 语法 babel 的介绍 => 用于处理高版本 js语法 的兼容性 安装包 yarn add -D babel-l ...

  9. 【CANN训练营第三季】【进阶班笔记3】PyTorch安装与环境配置

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.pandas是什么? 二.使用步骤 1.引入库 2.读入数据 总结 前言 提示:这里可以添加本文要记录的大概内容: ...

最新文章

  1. 1029 Median
  2. TensorFlow Lattice:灵活、可控、可解释的机器学习
  3. python库整理:numpy 集合操作
  4. Python规范:提高可读性
  5. Java多线程(五):线程池应该设置多少核心线程数
  6. 找一份好工作真的很难?是的,很难。
  7. 中国计算机手机全部被黑,云南一高校电脑全被黑
  8. 飞鱼知识变现小程序2.5.3源码_小程序功能模块
  9. deprecated conversion from string constant to ‘char*’
  10. MFC获取文件夹路径并得到该字符串
  11. 开篇~试试word写博客
  12. We Chall-Encodings: URL -Writeup
  13. CSS实现文字竖排效果
  14. MP4转AVI转AMV教程:教你把B站视频导入你的MP3MP4随身听播放器
  15. QQ拼音输入法词库和搜狗输入法词库[相互导入](使用Excel公式)
  16. 启动Xshell报错:由于找不到MSVCR110.dll,无法继续执行代码。重新安装程序可能会解决此问题
  17. Synopsys工具安装之二【SCL License】
  18. (二)office2016-excel冻结窗格
  19. Python实现对主要城市及其周边地区天气数据的爬取
  20. 跨部门工作安排与绩效考评解决方案

热门文章

  1. 学英语专业后悔了_上大学一定不要读英语专业?当年志愿填报我选了英语专业...
  2. java aqs原理_Java并发之AQS详解
  3. java静态引用_Java开发中静态方法引用和实例方法引用案例详细讲解
  4. Springboot连接不上mysql8_springboot连接mysql8.0问题解决
  5. python3 socket 接收 bytes 长度 会变,Python解析Socket数据流异常bytes的问题(详细)...
  6. java工具方法1(数组)
  7. 李开复谈创业失败十原因:经不住诱惑 直接山寨
  8. C#二进制流的序列化和反序列化操作
  9. 中国区Azure基本实例更新
  10. struts2的json插件配置详解