【友价论坛源码】【hdfs源码修改】【科技首页源码】servlet filter 源码

1.Shiro源码分析---FilterChain创建过程
2.spring的事务管理有几种方式实现,如何实现

servlet filter 源码

Shiro源码分析---FilterChain创建过程

       在Shiro框架中,无论是进行认证还是权限控制,都依赖于过滤器的配置与应用。在实际开发中,可能需要配置多个过滤器,友价论坛源码但每个请求所经过的过滤器组合却因请求不同而异。因此,理解一个请求会通过哪些过滤器,对于熟练使用Shiro至关重要。本文将详细解析请求通过的过滤器创建过程。

       Shiro框架通过`org.apache.shiro.web.filter.mgt.FilterChainResolver`接口定义了如何确定一个请求应经过哪些过滤器。接口中的唯一方法`getChain`负责查找并组装一个过滤器链(FilterChain),该链包含了请求处理过程中所应用的所有过滤器。`FilterChain`是一个熟知的概念,尤其是对于Servlet开发人员来说,它在日常工作中常见。hdfs源码修改而`FilterChainResolver`仅是一个接口,Shiro提供了默认实现类`org.apache.shiro.web.filter.mgt.PathMatchingFilterChainResolver`,该实现类利用请求路径来匹配相应的过滤器。

       在深入理解PathMatchingFilterChainResolver的源码前,先来看看FilterChainManager是如何管理和创建FilterChain的。Shiro提供了一个默认的FilterChainManager实现类`org.apache.shiro.web.filter.mgt.DefaultFilterChainManager`。其关键方法`createChain`在系统启动时被调用,用于创建各个FilterChain。科技首页源码以配置示例`/static/**、/formfilterlogin,/role`为例,`chainName`与`chainDefinition`分别代表了需要管理的FilterChain名称与定义。

       了解了FilterChainManager的创建与管理机制后,接下来关注FilterChainResolver如何确定请求所需过滤器链。在`DefaultFilterChainManager.proxy`方法中,`NamedFilterList`的源码的结局实现类`org.apache.shiro.web.filter.mgt.SimpleNamedFilterList`被调用,此步骤是确定过滤器链的关键环节。

       至此,Shiro框架中FilterChain创建过程已全面解析完成。如有任何错误或需要进一步讨论的问题,欢迎指正。感谢阅读,期待更多的技术交流。

spring的多多拍源码事务管理有几种方式实现,如何实现

       Spring+Hibernate的实质:

       就是把Hibernate用到的数据源Datasource,Hibernate的SessionFactory实例,事务管理器HibernateTransactionManager,都交给Spring管理。

       那么再没整合之前Hibernate是如何实现事务管理的呢?

       通过ServletFilter实现数据库事务的管理,这样就避免了在数据库操作中每次都要进行数据库事务处理。

       一.事务的4个特性:

        原子性:一个事务中所有对数据库的操作是一个不可分割的操作序列,要么全做,要么全部做。

        一致性:数据不会因为事务的执行而遭到破坏。

        隔离性:一个事务的执行,不受其他事务(进程)的干扰。既并发执行的个事务之间互不干扰。

        持久性:一个事务一旦提交,它对数据库的改变将是永久的。

       二.事务的实现方式:

       实现方式共有两种:编码方式;声明式事务管理方式。

       基于AOP技术实现的声明式事务管理,实质就是:在方法执行前后进行拦截,然后在目标方法开始之前创建并加入事务,执行完目标方法后根据执行情况提交或回滚事务。

       声明式事务管理又有两种方式:基于XML配置文件的方式;另一个是在业务方法上进行@Transactional注解,将事务规则应用到业务逻辑中。

       三.创建事务的时机:

       是否需要创建事务,是由事务传播行为控制的。读数据不需要或只为其指定只读事务,而数据的插入,修改,删除就需要事务管理了。

       一种常见的事务管理配置:事务拦截器TransactionInterceptor和事务自动代理BeanNameAutoProxyCreator相结合的方式

       <!--定义Hibernate的事务管理器HibernateTransactionManager -->

        <bean id="transactionManager"

        class="org.springframework.orm.hibernate3.HibernateTransactionManager">

        <!-- 依赖注入上面定义的sessionFactory -->

        <property name="sessionFactory" ref="sessionFactory"/>

        </bean>

       <!--定义Spring的事务拦截器TransactionInterceptor -->

        <bean id="transactionInterceptor" class="org.springframework.transaction.interceptor.TransactionInterceptor">

        <!-- 依赖注入上面定义的事务管理器transactionManager -->

        <property name="transactionManager" ref="transactionManager"/>

        <!-- 定义需要进行事务拦截的方法及所采用的事务控制类型 -->

        <property name="transactionAttributes">

        <props>

        <!-- 以browse、list、load、get及is开头的所有方法采用只读型事务控制类型 -->

        <prop key="browse*">PROPAGATION_REQUIRED,readOnly</prop>

        <prop key="list*">PROPAGATION_REQUIRED,readOnly</prop>

        <prop key="load*">PROPAGATION_REQUIRED,readOnly</prop>

        <prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>

        <prop key="is*">PROPAGATION_REQUIRED,readOnly</prop>

        <!-- 所有方法均进行事务控制,如果当前没有事务,则新建一个事务 -->

        <prop key="*">PROPAGATION_REQUIRED</prop>

        </props>

        </property>

        </bean>

       <!-- 定义BeanNameAutoProxyCreatorf进行Spring的事务处理-->

        <bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">

        <!-- 针对指定的bean自动生成业务代理 -->

        <property name="beanNames">

        <list>

        <value>adminService</value>

        <value>columnsService</value>

        <value>newsService</value>

        <value>crawlService</value>

        <value>memberLevelService</value>

        <value>memberService</value>

        <value>categoryService</value>

        <value>merService</value>

        <value>cartService</value>

        <value>ordersService</value>

        <value>trafficService</value>

        </list>

        </property>

        <!-- 这个属性为true时,表示被代理的是目标类本身而不是目标类的接口 -->

        <property name="proxyTargetClass">

        <value>true</value>

        </property>

        <!-- 依赖注入上面定义的事务拦截器transactionInterceptor -->

        <property name="interceptorNames">

        <list>

        <value>transactionInterceptor</value>

        </list>

        </property>

        </bean>

       尤其注意:如下

       

更多内容请点击【娱乐】专栏

精彩资讯