Я использую Spring .NEt и NHibernate вместе с ASP .NET MVC.
Недавно я решил интегрировать управление транзакциями с Spring. Я понимаю, что Spring дает возможность легко интегрировать переходы с помощью атрибута [Transaction ()] вашего сервиса. Я получил это на работу.
Моя старая архитектура заключалась в том, чтобы перехватывать вызовы в службу через совет с использованием AOP и проверять, разрешено ли вам вызывать этот метод.
CALL -> Tx Advice -> Permission Advice -> Service -> логика выполнения -> Commit / Rollback Tx в Tx Advice -> End CALL.
Теперь мне больше не нужен совет Tx из-за атрибута Transaction () в моих методах обслуживания.
Однако, как мне сделать так, чтобы транзакция запускалась до того, как она попадет в PermissionAdvice.
Файл: services.xml
<object id="BusinessLogicServiceBase" type="Winito.Server.Services.Impl.BusinessLogicService, Winito.Server">
<property name="ObjectPersistenceManager" ref="ObjectPersistenceManager" />
<property name="StatisticsStandingsManager" ref="StatisticsStandingsManager" />
....
</object>
<tx:attribute-driven/>
Файл: Dao.xml
<object type="Spring.Objects.Factory.Config.PropertyPlaceholderConfigurer, Spring.Core">
<property name="ConfigSections" value="databaseSettings"/>
</object>
<!-- Database and NHibernate Configuration -->
<!-- SqlServer-2.0 -->
<db:provider id="DbProvider" provider="System.Data.SqlClient" connectionString="" />
<!-- NHibernate Configuration -->
<object id="NHibernateSessionFactory" type="Winito.Data.Base.NHibernate.CustomLocalSessionFactoryObject, Winito.Data.Base">
<property name="DbProvider" ref="DbProvider"/>
<property name="MappingAssemblies">
<list>
<value>Winito.Core</value>
</list>
</property>
<property name="HibernateProperties">
<dictionary>
<entry key="connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
<entry key="use_proxy_validator" value="false" />
<entry key="dialect" value="NHibernate.Dialect.MsSql2008Dialect"/>
<entry key="connection.driver_class" value="NHibernate.Driver.SqlClientDriver" />
<entry key="connection.isolation" value="ReadCommitted" />
<!--<property name="cache.provider_class">NHibernate.Caches.SysCache.SysCacheProvider,NHibernate.Caches.SysCache</property>-->
<!--<property name="cache.use_second_level_cache">true</property>-->
<entry key="command_timeout" value="340" />
<entry key="use_outer_join" value="true" />
<entry key="proxyfactory.factory_class" value="NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle" />
</dictionary>
</property>
<!-- provides integation with Spring's declarative transaction management features -->
<property name="ExposeTransactionAwareSessionFactory" value="true" />
</object>
<!-- Transaction Management Strategy - local database transactions -->
<object id="transactionManager" type="Spring.Data.NHibernate.HibernateTransactionManager, Spring.Data.NHibernate30">
<property name="DbProvider" ref="DbProvider"/>
<property name="SessionFactory" ref="NHibernateSessionFactory"/>
</object>
<!-- Exception translation object post processor -->
<object type="Spring.Dao.Attributes.PersistenceExceptionTranslationPostProcessor, Spring.Data"/>
Старый код:
<object id="BusinessLogicService" type="Spring.Aop.Framework.ProxyFactoryObject">
<property name="target" ref="BusinessLogicServiceBase" />
<property name="interceptorNames">
<list>
<!-- <value>TimingAdvice</value> -->
<value>TransactionalAdvice</value>
<value>PermissionAdviceBusinessLogic</value>
</list>
</property>
</object>