shiro和spring的集成(详细步骤)
2017-04-27 09:49
501 查看
首先说下,流程,最后上实现代码,即如何配置xml。1.搭建开发环境 • 加入如下 jar 包: – shiro-all-1.3.2.jar – log4j-1.2.15.jar – slf4j-api-1.6.1.jar – slf4j-log4j12-1.6.1.jar官网可以下载:下载地址:http://shiro.apache.org/2.集成 Spring • 加入 Spring 和 Shiro 的 jar 包 • 配置 Spring 及 SpringMVC • 参照:1.3.2\shiro-root-1.3.2-source-release\shiro-root-1.3.2\samples\spring 配置web.xml 文件和 Spring 的配置文件3.与Web 集成• Shiro 提供了与 Web 集成的支持,其通过一个ShiroFilter 入口来拦截需要安全控制的URL,然后进行相应的控制• ShiroFilter 类似于如 Strut2/SpringMVC 这种web 框架的前端控制器,是安全控制的入口点,其负责读取配置(如ini 配置文件),然后判断URL是否需要登录/权限等工作。 (ShiroFilter 的工作原理)实现步骤和详细配置: 1)首先是在web.xml 中配置:
<!-- 配置shiro 的监听 --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- 配置springmvc 的前端控制器--> <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springmvc</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!-- 1. 配置 Shiro 的 shiroFilter. 2. DelegatingFilterProxy 实际上是 Filter 的一个代理对象. 默认情况下, Spring 会到 IOC 容器中查找和 <filter-name> 对应的 filter 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>注意:• DelegatingFilterProxy 作用是自动到 Spring 容器查找名字为 shiroFilter(filter-name)的 bean 并把所有 Filter的操作委托给它。 2)applicationContext.xml的配置(也就是shiro的xml配置,重点)
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <!-- 1. 配置 SecurityManager! --> <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager"> <!-- cacheManager缓存管理器 --> <property name="cacheManager" ref="cacheManager"/> <property name="realm" ref="jdbcRealm"/> </bean> <!-- 2. 配置 CacheManager. 2.1 需要加入 ehcache 的 jar 包及配置文件. (百度上搜索就可以下载) --> <bean id="cacheManager" class="org.apache.shiro.cache.ehcache.EhCacheManager"> <property name="cacheManagerConfigFile" value="classpath:ehcache.xml"/> </bean> <!-- 3. 配置 Realm 3.1 直接配置实现了 org.apache.shiro.realm.Realm 接口的 bean --> <bean id="jdbcRealm" class="com.atguigu.shiro.realms.ShiroRealm"></bean> <!-- 4. 配置 LifecycleBeanPostProcessor. 可以自动的来调用配置在 Spring IOC 容器中 shiro bean 的生命周期方法. --> <bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor"/> <!-- 5. 启用 IOC 容器中使用 shiro 的注解. 但必须在配置了 LifecycleBeanPostProcessor 之后才可以使用. --> <bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" depends-on="lifecycleBeanPostProcessor"/> <bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor"> <property name="securityManager" ref="securityManager"/> </bean> <!-- 6. 配置 ShiroFilter. 6.1 id 必须和 web.xml 文件中配置的 DelegatingFilterProxy 的 <filter-name> 一致. 若不一致, 则会抛出: NoSuchBeanDefinitionException. 因为 Shiro 会在 IOC 容器中查找和 <filter-name> 名字对应的 filter bean. No bean named 'shiroFilter' is defined --> <bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean"> <property name="securityManager" ref="securityManager"/> <property name="loginUrl" value="/login.jsp"/> <property name="successUrl" value="/list.jsp"/> <property name="unauthorizedUrl" value="/unauthorized.jsp"/> <!-- 配置哪些页面需要受保护. 4000 以及访问这些页面需要的权限. 1). anon 可以被匿名访问 2). authc 必须认证(即登录)后才可能访问的页面. 3). logout 登出. 4). roles 角色过滤器 --> <property name="filterChainDefinitions"> <value> /login.jsp = anon # everything else requires authentication: /** = authc </value> </property> </bean> </beans>3)springmvc-config.xml的配置(具体意思,我以前的博客当中写过,请参考SpringMVC 详细流程 + 入门程序(详细步骤))
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:mvc="http://www.springframework.org/schema/mvc"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd"> <context:component-scan base-package="com.atguigu.shiro"/><bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="prefix" value="/"/><property name="suffix" value=".jsp"/></bean><mvc:annotation-driven/><mvc:default-servlet-handler/></beans>4)配置完成, 这里我们,设置了除了 login.jsp页面可以匿名访问,其他的页面必须登录(认证)过后才能访问。相关知识点:1) • [urls] 部分的配置,其格式是: “url=拦截器[参数],拦截器[参数]”; • 如果当前请求的 url 匹配 [urls] 部分的某个 url 模式,将会执行其配置的拦截器。 • anon(anonymous) 拦截器表示匿名访问(即不需要登录即可访问) • authc (authentication)拦截器表示需要身份认证通过后才能访问2)shiro中的默认过滤器3)URL 匹配模式 • url 模式使用 Ant 风格模式 • Ant 路径通配符支持 ?、*、**,注意通配符匹配不包括目录分隔符“/”: – ?:匹配一个字符,如 /admin? 将匹配 /admin1,但不匹配 /admin 或 /admin/; – *:匹配零个或多个字符串,如 /admin 将匹配 /admin、/admin123,但不匹配 /admin/1; – **:匹配路径中的零个或多个路径,如 /admin/** 将匹配 /admin/a 或 /admin/a/b4)URL 匹配顺序 • URL 权限采取第一次匹配优先的 方式,即从头开始使用第一个匹配的 url 模式对应的拦截器链。 • 如: – /bb/**=filter1 – /bb/aa=filter2 – /**=filter3 – 如果请求的url是“/bb/aa”,因为按照声明顺序进行匹配,那么将使用 filter1 进行拦截。
相关文章推荐
- Spring Boot集成无状态Shiro--内容详细介绍
- spring boot 集成shiro详细教程
- Spring-Boot 集成Solr客户端的详细步骤
- spring boot集成shiro详细教程(小结)
- SpringBoot+Shiro+SpringSession的简单集成配置简要步骤
- shiro 权限认证框集成到spring中,实现登陆与权限拦截
- Spring、SpringMVC、Hibernate详细整合实例,包含所有步骤
- 01 shiro与spring集成
- spring boot 集成shiro记住我实现
- spring+springmvc+mybatis整合详细步骤
- Spring 应用中集成 Apache Shiro的方法
- Spring整合Hibernate详细步骤
- spring+hibernate+dwr集成步骤
- spring 集成shiro 之 自定义过滤器
- 亚马逊SNS集成GCM的详细步骤
- Shiro简介及与spring集成
- spring 集成shiro 之 自定义过滤器
- Shiro-集成Spring
- spring3.0.5与quartz1.8.4的集成详细说明
- spring整合hibernate的步骤详细