这两天搭了一个Spring jpa示例小程序。搭建过程遇到一些小问题如下:
1.提示Failed to load class "org.slf4j.impl.StaticLoggerBinder" 、tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON 等。都是slf4j几个相关jar包版本的问题。最后成功的配置如下:
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>hibernateTest</groupId> <artifactId>hibernateTest</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>asm</groupId> <artifactId>asm</artifactId> <version>3.3.1</version> </dependency> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-core</artifactId> <version>4.1.0.Final</version> </dependency> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-annotations</artifactId> <version>3.4.0.GA</version> </dependency> <dependency> <groupId>cglib</groupId> <artifactId>cglib</artifactId> <version>2.2.2</version> </dependency> <dependency> <groupId>org.antlr</groupId> <artifactId>antlr</artifactId> <version>3.3</version> </dependency> <dependency> <groupId>net.sf.ehcache</groupId> <artifactId>ehcache-core</artifactId> <version>2.5.2</version> </dependency> <dependency> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> <version>1.1.3</version> </dependency> <dependency> <groupId>commons-collections</groupId> <artifactId>commons-collections</artifactId> <version>3.2.1</version> </dependency> <dependency> <groupId>javax.transaction</groupId> <artifactId>jta</artifactId> <version>1.1</version> </dependency> <dependency> <groupId>dom4j</groupId> <artifactId>dom4j</artifactId> <version>1.6.1</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.16</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.20</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>3.2.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>3.2.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>3.2.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>3.2.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-commons</artifactId> <version>1.8.0.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-jpa</artifactId> <version>1.6.0.RELEASE</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.7</version> </dependency> <dependency> <groupId>aopalliance</groupId> <artifactId>aopalliance</artifactId> <version>1.0</version> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjrt</artifactId> <version>1.8.0</version> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.6.12</version> </dependency> <dependency> <groupId>commons-beanutils</groupId> <artifactId>commons-beanutils</artifactId> <version>1.8.3</version> </dependency> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.8</version> </dependency> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>20030825.184428</version> </dependency> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.2.2</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.1</version> </dependency> <dependency> <groupId>commons-pool</groupId> <artifactId>commons-pool</artifactId> <version>20030825.183949</version> </dependency> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-entitymanager</artifactId> <version>4.1.0.Final</version> </dependency> <dependency> <groupId>org.hibernate.javax.persistence</groupId> <artifactId>hibernate-jpa-2.0-api</artifactId> <version>1.0.1.Final</version> </dependency> <dependency> <groupId>javassist</groupId> <artifactId>javassist</artifactId> <version>3.12.0.GA</version> </dependency> <dependency> <groupId>org.jboss.logging</groupId> <artifactId>jboss-logging</artifactId> <version>3.1.1.GA</version> </dependency> <dependency> <groupId>org.jboss.spec.javax.transaction</groupId> <artifactId>jboss-transaction-api_1.1_spec</artifactId> <version>1.0.0.Final</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.0.13</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> <version>1.0.13</version> </dependency> </dependencies> </project>2.搭建mysql忘记登录密码。。。
使用如下修改密码:
net stop mysql56
mysqld -nt --skip-grant-tables
mysql -u root
使用安全模式登录且修改密码:
use mysql;
update user set password=PASSWORD('12345678') where host='localhost' and user='root'; (这里有个问题,由于使用了安全模式,不允许修改不以主键为条件的数据。这个user表的主键为user和红色他,所以,如果只根据host或者user来修改password,不会生效。)
然后刷新权限表:
flush privileges;
关掉mysqld进程,重启mysql
。。。。。。。。。。。。。。。。。。。。。。。。。。
然而这个方法无效。。。。
。。。。
瞎鼓捣了一阵,最后打开mysql的installer直接报错。。。。。。巨汗。。。。。。。。
于是只好重新安装mysql。
3.运行这个Spring jpa 的初衷是为了探索jpa事务方面的问题。所以开始debug事务。
@Service public class EventService { @Autowired EventRepository eventRepository; @Transactional(propagation = Propagation.REQUIRES_NEW) public void addEvent(EventobjEntity eventobjEntity){ eventRepository.save(eventobjEntity); } }
本意是为了打印slf4j日志。但是。。。。
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
。。。暂时不管他
使用调试模式跟进去
- doGetTransaction():325, JpaTransactionManager {org.springframework.orm.jpa}
- getTransaction():336, AbstractPlatformTransactionManager {org.springframework.transaction.support}
- createTransactionIfNecessary():417, TransactionAspectSupport {org.springframework.transaction.interceptor}
- invokeWithinTransaction():255, TransactionAspectSupport {org.springframework.transaction.interceptor}
- invoke():94, TransactionInterceptor {org.springframework.transaction.interceptor}
- proceed():172, ReflectiveMethodInvocation {org.springframework.aop.framework}
- intercept():633, CglibAopProxy$DynamicAdvisedInterceptor {org.springframework.aop.framework}
- addEvent():-1, EventService$$EnhancerBySpringCGLIB$$56b75b4 {cn.com.myhiber.service}
可见,EventService是由Spring使用cglib动态代理在运行时创建的。cglib是Spring AOP实现的方法。定义的Interceptor中,Spring写了在执行方法前后需要做的事。如判断是否使用事务、事务的各种属性定义等。