在web.xml中配置spring
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
在web.xml中配置springMvc
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
在web.xml中配置shiro代理过滤器
<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>
spring.xml中文件配置
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd
">
设置扫描的包
<context:component-scan base-package="com"></context:component-scan>
开启注解支持
<mvc:annotation-driven/>
配置扫描的页面属性
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"></property>
<property name="suffix" value=".jsp"/>
</bean>
配置连接到数据库
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url"
value="jdbc:mysql://localhost:3306/shiro01?useUnicode=true&characterEncoding=utf-8"></property>
<property name="username" value="root"></property>
<property name="password" value="mmmm"></property>
</bean>
配置shiro的jdbccrealm
<bean id="jdbcrealm" class="org.apache.shiro.realm.jdbc.JdbcRealm">
<property name="permissionsLookupEnabled" value="true"></property>
<property name="dataSource" ref="dataSource"></property>
<property name="authenticationQuery" value=" SELECT password FROM sec_user WHERE user_name= ?"></property>
<property name="userRolesQuery" value="SELECT role_name from sec_user_role left join sec_role using(role_id) left join sec_user using(user_id) WHERE user_name= ?"></property>
<property name="permissionsQuery" value="SELECT permission_name FROM sec_role_permission left join sec_role using(role_id) left join sec_permission using(permission_id) WHERE role_name = ? "></property>
</bean>
配置shiro的缓存管理
<bean id="cacheManager" class="org.apache.shiro.cache.MemoryConstrainedCacheManager"></bean>
配置shiro的安全管理
<bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">
<property name="cacheManager" ref="cacheManager"></property>
<property name="realm" ref="jdbcrealm"></property>
</bean>
配置shiro的过滤器
<bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">
<property name="securityManager" ref="securityManager"></property>
配置默认登录界面
<property name="loginUrl" value="login.jsp"></property>
配置无权访问时去的界面
<property name="unauthorizedUrl" value="noqx.jsp"></property>
配置各个权限能访问的页面
<property name="filterChainDefinitions">
<value>
/index.jsp=anon
/result.jsp=authc,roles[admin]
</value>
</property>
</bean>
配置识别注解时各个权限访问
<bean class="org.apache.shiro.spring.LifecycleBeanPostProcessor"></bean>
<bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator">
<property name="proxyTargetClass" value="true"></property>
</bean>
<bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">
<property name="securityManager" ref="securityManager"></property>
</bean>
配置各个异常时访问的页面
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<prop key="org.apache.shiro.authz.UnauthorizedException">
redirect:/noqx.jsp
</prop>
</props>
</property>
</bean>
</beans>
分享到:
相关推荐
5. **shiro-spring-1.7.1.jar**: 这是Shiro与Spring框架的整合模块,允许开发者在Spring的IoC容器中管理Shiro的bean,实现依赖注入和AOP安全控制。 6. **encoder-1.2.2.jar**: 这可能是一个密码编码库,通常用于将...
在Web应用中,Shiro可以帮助控制用户的访问权限,实现用户登录、权限验证以及安全相关的操作。例如,它可以限制未登录用户访问特定页面,或者根据用户角色分配不同的操作权限。 **Redis** 是一个高性能的键值存储...
shiro-spring-1.2.4
- **shiro-spring.jar**:Spring框架的集成,便于在Spring应用中使用Shiro。 - **log4j.jar, slf4j.jar**:日志处理库,Shiro依赖这些库进行日志输出。 了解和使用这些jar包,开发者可以根据项目需求选择合适的模块...
这个模块提供了Spring Bean的定义和配置,使得Shiro的组件可以被Spring管理。 9. **shiro-all-1.7.1.jar**: 包含了Shiro的所有模块,如果你希望在一个项目中使用Shiro的所有功能,可以直接引入这个包,而无需单独...
这样,我们可以利用Spring的依赖注入来管理Shiro的组件。 5. **安全控制**:在控制器方法上添加注解,如`@RequiresAuthentication`或`@RequiresRoles`,以实现基于注解的访问控制。 **Spring MVC整合** 1. **创建...
4. 集成Spring:通过Spring的Bean管理,将Shiro的组件声明为Spring Bean,实现依赖注入。 5. 配置Spring AOP:使用Shiro的注解或切面来控制方法级别的访问权限。 6. 编写安全逻辑:在业务代码中调用Subject的API进行...
Spring Shiro 学习系统是针对Java开发人员设计的一个教程,特别适合那些正在探索权限管理和认证解决方案的初学者。Spring Shiro-training项目旨在提供一个综合的学习环境,帮助开发者理解和掌握如何在Spring应用中...
提供一套基于SpringBoot-shiro-vue的权限管理思路. 前后端都加以控制,做到按钮/接口级别的权限 DEMO 测试地址 admin/123456 管理员身份登录,可以新增用户,角色. 角色可以分配权限 控制菜单是否显示,新增/删除按钮...
spring+mybatis+shiro整合。。。简单入门案例,maven项目
将Shiro与Spring结合,可以利用Spring的IOC容器管理Shiro的组件,如Realm(领域对象,用于处理认证和授权)。这使得配置更加灵活,代码更易于测试。在Spring的配置文件中,我们可以定义Shiro的...
3. **shiro-lang-1.7.1.jar**:Shiro的语言支持模块,可能包含了表达式语言(EL)支持,用于权限判断和配置。 4. **shiro-config-ogdl-1.7.1.jar**:这可能是OGDL配置解析器,OGDL(Object-Graph Description ...
开发者可以通过阅读源码,了解如何将Shiro的各个组件与Spring的bean管理相结合,以及如何实现自定义的权限控制逻辑。这将是一个很好的学习资源,对于提升在企业级应用开发中的安全实践能力大有裨益。
本文将深入探讨一个基于SpringMVC、Mybatis、Shiro和Redis的Web应用架构,这四个组件共同构成了一个强大而灵活的框架,能够满足复杂业务需求并提供高性能的数据处理和用户权限管理。 首先,SpringMVC作为Spring框架...
在Java应用程序中,Shiro 可以帮助开发者处理身份验证(登录)、授权(权限控制)、会话管理和密码加密等常见安全问题。"shiro-all-1.2.3.jar" 是Apache Shiro框架的一个完整集合,包含了所有必要的类和库,用于在...
Shiro 不像Spring Security那样复杂,它提供了一种直观、简单的API来处理常见的安全需求,如用户身份验证、授权、会话管理和加密。 2. **Shiro的核心组件** - **Authentication(认证)**:验证用户身份,确保登录...
在实际使用中,你还需要了解如何将Shiro与Spring、MyBatis等其他框架集成,以实现更复杂的业务需求。 总之,Apache Shiro是一个功能丰富的安全框架,能够帮助开发者快速地实现应用的安全控制。通过深入学习和实践,...
7. **集成**:Shiro 可以轻松地与Spring、Struts、JSF等其他框架集成,以提供全面的安全解决方案。 在 "shiro-root-1.3.2-source-release" 源码包中,你可以找到以下内容: - `src/main/java`: 源代码,包括各个...
jsets-shiro-spring-boot-starter项目说明springboot中使用shiro大都是通过shiro-spring.jar进行的整合的,虽然不是太复杂,但是也无法做到spring-boot-starter风格的开箱即用。项目中经常用到的功能比如:验证码、...
《Spring-Shiro集成实战:构建企业级权限管理系统》 在当今的企业级Web开发中,权限管理是不可或缺的一部分,它确保了系统的安全性和用户访问的合法性。本教程将深入探讨如何结合Spring框架与Apache Shiro库,构建...