Java Hibernate迁移:BeanlibException

Java Hibernate迁移:BeanlibException,java,hibernate,migration,hibernate-4.x,Java,Hibernate,Migration,Hibernate 4.x,在进行Hibernate迁移时,bean lib jar出现问题。正如你所见,我附上了所有与bean replicator相关的JAR 在运行时面临问题时: 11:56:33,354 ERROR [BeanPopulator] propertyName=handler readerMethod=public javassist.util.proxy.MethodHandler com.v4common.shared.beans.usermanagement.User_$$_jvst

在进行Hibernate迁移时,bean lib jar出现问题。正如你所见,我附上了所有与bean replicator相关的JAR

在运行时面临问题时:

      11:56:33,354 ERROR [BeanPopulator] 
propertyName=handler
readerMethod=public javassist.util.proxy.MethodHandler com.v4common.shared.beans.usermanagement.User_$$_jvstb35_4c.getHandler()
setterMethod=public void com.v4common.shared.beans.usermanagement.User_$$_jvstb35_4c.setHandler(javassist.util.proxy.MethodHandler)
fromBean=com.v4common.shared.beans.usermanagement.User@1
toBean=com.v4common.shared.beans.usermanagement.User_$$_jvstb35_4c@0

net.sf.beanlib.BeanlibException: java.lang.NoSuchMethodException: org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.<init>()
    at net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:169)
    at net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicateByBeanReplicatable(ReplicatorTemplate.java:125)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:120)
    at net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:224)
    at net.sf.beanlib.provider.BeanPopulator.doit(BeanPopulator.java:201)
    at net.sf.beanlib.provider.BeanPopulator.processSetterMethod(BeanPopulator.java:172)
    at net.sf.beanlib.provider.BeanPopulator.populate(BeanPopulator.java:270)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.populateBean(ReplicatorTemplate.java:174)
    at net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:173)
    at net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicateByBeanReplicatable(ReplicatorTemplate.java:125)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:120)
    at net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:224)
    at net.sf.beanlib.provider.BeanPopulator.doit(BeanPopulator.java:201)
    at net.sf.beanlib.provider.BeanPopulator.processSetterMethod(BeanPopulator.java:172)
    at net.sf.beanlib.provider.BeanPopulator.populate(BeanPopulator.java:270)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.populateBean(ReplicatorTemplate.java:174)
    at net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:173)
    at net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicateByBeanReplicatable(ReplicatorTemplate.java:125)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:120)
    at net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:224)
    at net.sf.beanlib.provider.BeanPopulator.doit(BeanPopulator.java:201)
    at net.sf.beanlib.provider.BeanPopulator.processSetterMethod(BeanPopulator.java:172)
    at net.sf.beanlib.provider.BeanPopulator.populate(BeanPopulator.java:270)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.populateBean(ReplicatorTemplate.java:174)
    at net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:173)
    at net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicateByBeanReplicatable(ReplicatorTemplate.java:125)
    at net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:120)
    at net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:224)
    at net.sf.beanlib.hibernate.HibernateBeanReplicator.copy(HibernateBeanReplicator.java:133)
    at net.sf.beanlib.hibernate.HibernateBeanReplicator.copy(HibernateBeanReplicator.java:111)
    at com.v4common.shared.util.other.ConversionUtil.copyProperties(ConversionUtil.java:364)
    at com.nextenders.dao.UserDetailsDao.fetchAllPostForUser(UserDetailsDao.java:3368)
    at com.nextenders.dao.UserDetailsDao.processsRequest(UserDetailsDao.java:119)
    at com.nextenders.common.DaoReceiver.processRequest(DaoReceiver.java:86)
    at com.nextenders.common.DaoHandler.handleRequest(DaoHandler.java:12)
    at com.nextenders.facadeimplementation.facade.UserFacade.fetchAllPostForUser(UserFacade.java:1526)
    at com.nextenders.facadeimplementation.facade.UserFacade.getDataOnLogIn(UserFacade.java:2671)
    at com.nextenders.facadeimplementation.facade.UserFacade.doLogin(UserFacade.java:2356)
    at com.nextenders.server.LoginServlet.doPost(LoginServlet.java:304)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1097)
    at com.nextenders.server.ExceptionHandler.doFilter(ExceptionHandler.java:28)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1088)
    at com.nextenders.server.BaseFilter.doFilter(BaseFilter.java:79)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1088)
    at com.google.inject.servlet.FilterChainInvocation.doFilter(FilterChainInvocation.java:66)
    at com.google.inject.servlet.ManagedFilterPipeline.dispatch(ManagedFilterPipeline.java:118)
    at com.google.inject.servlet.GuiceFilter.doFilter(GuiceFilter.java:113)
    at org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1088)
    at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:360)
    at org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
    at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
    at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:729)
    at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.handler.RequestLogHandler.handle(RequestLogHandler.java:49)
    at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
    at org.mortbay.jetty.Server.handle(Server.java:324)
    at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:505)
    at org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:843)
    at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:647)
    at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
    at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:380)
    at org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:395)
    at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:488)
11:56:33354错误[BeanPoperator]
propertyName=处理程序
readerMethod=public javassist.util.proxy.MethodHandler com.v4common.shared.beans.usermanagement.User_$$\u jvstb35_4c.getHandler()
setterMethod=public void com.v4common.shared.beans.usermanagement.User_$$\u jvstb35_4c.setHandler(javassist.util.proxy.MethodHandler)
fromBean=com.v4common.shared.beans.usermanagement。User@1
toBean=com.v4common.shared.beans.usermanagement.User\u$$\ ujvstb35_4c@0
net.sf.beanlib.BeanlibException:java.lang.NoSuchMethodException:org.hibernate.proxy.pojo.javassist.javassistLazInitializer.()
位于net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:169)
位于net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
位于net.sf.beanlib.provider.replicator.ReplicatorTemplate.ReplicateBeanReplicatable(ReplicatorTemplate.java:125)
在net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:120)上
位于net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:224)
位于net.sf.beanlib.provider.BeanPopulator.doit(BeanPopulator.java:201)
位于net.sf.beanlib.provider.BeanPopulator.processSetterMethod(BeanPopulator.java:172)
位于net.sf.beanlib.provider.BeanPopulator.populate(BeanPopulator.java:270)
位于net.sf.beanlib.provider.replicator.ReplicatorTemplate.populateBean(ReplicatorTemplate.java:174)
位于net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:173)
位于net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
位于net.sf.beanlib.provider.replicator.ReplicatorTemplate.ReplicateBeanReplicatable(ReplicatorTemplate.java:125)
在net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:120)上
位于net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:224)
位于net.sf.beanlib.provider.BeanPopulator.doit(BeanPopulator.java:201)
位于net.sf.beanlib.provider.BeanPopulator.processSetterMethod(BeanPopulator.java:172)
位于net.sf.beanlib.provider.BeanPopulator.populate(BeanPopulator.java:270)
位于net.sf.beanlib.provider.replicator.ReplicatorTemplate.populateBean(ReplicatorTemplate.java:174)
位于net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:173)
位于net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
位于net.sf.beanlib.provider.replicator.ReplicatorTemplate.ReplicateBeanReplicatable(ReplicatorTemplate.java:125)
在net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:120)上
位于net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:224)
位于net.sf.beanlib.provider.BeanPopulator.doit(BeanPopulator.java:201)
位于net.sf.beanlib.provider.BeanPopulator.processSetterMethod(BeanPopulator.java:172)
位于net.sf.beanlib.provider.BeanPopulator.populate(BeanPopulator.java:270)
位于net.sf.beanlib.provider.replicator.ReplicatorTemplate.populateBean(ReplicatorTemplate.java:174)
位于net.sf.beanlib.provider.replicator.BeanReplicator.replicateBean(BeanReplicator.java:173)
位于net.sf.beanlib.hibernate3.Hibernate3JavaBeanReplicator.replicateBean(Hibernate3JavaBeanReplicator.java:71)
位于net.sf.beanlib.provider.replicator.ReplicatorTemplate.ReplicateBeanReplicatable(ReplicatorTemplate.java:125)
在net.sf.beanlib.provider.replicator.ReplicatorTemplate.replicate(ReplicatorTemplate.java:120)上
位于net.sf.beanlib.provider.BeanTransformer.transform(BeanTransformer.java:224)
位于net.sf.beanlib.hibernate.HibernateBeanReplicator.copy(HibernateBeanReplicator.java:133)
位于net.sf.beanlib.hibernate.HibernateBeanReplicator.copy(HibernateBeanReplicator.java:111)
位于com.v4common.shared.util.other.ConversionUtil.copyProperties(ConversionUtil.java:364)
在com.nextenders.dao.UserDetailsDao.fetchAllPostForUser上(UserDetailsDao.java:3368)
在com.nextenders.dao.UserDetailsDao.processsRequest(UserDetailsDao.java:119)上
位于com.nextenders.common.DaoReceiver.processRequest(DaoReceiver.java:86)
位于com.nextenders.common.DaoHandler.handleRequest(DaoHandler.java:12)
在com.nextenders.facadeimplementation.facade.UserFacade.fetchAllPostForUser(UserFacade.java:1526)上
位于com.nextenders.facademployment.facade.UserFacade.getDataOnLogIn(UserFacade.java:2671)
在com.nextenders.facadeimplementation.facade.UserFacade.doLogin(UserFacade.java:2356)
位于com.nextenders.server.LoginServlet.doPost(LoginServlet.java:304)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
位于javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
位于org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:487)
位于org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1097)
位于com.nextenders.server.ExceptionHandler.doFilter(ExceptionHandler.java:28)
位于org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1088)
位于com.nextenders.server.BaseFilter.doFilter(BaseFilter.java:79)
位于org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1088)
在com.google.inject.servlet.filterchaininciation.doFilter上(filterchaininciation.java:66)
位于com.google.inject.servlet.ManagedFilterPipeline.dispatch(ManagedFilterPipeline.java:118)
位于com.google.inject.servlet.GuiceFilter.doFilter(GuiceFilter.java:113)
位于org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1088)
位于org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:360)
位于org.mortbay.jetty.security.SecurityHandler.handle(Securit
private static final String JAVASSIST_STARTWITH = "org.javassist.tmp."; 
private static final String JAVASSIST_INDEXOF = "_$$_javassist_";

/** 
 * Returns true if the given class is found to be a javassist enhanced class; 
 * false otherwise. 
 */ 
private static boolean isJavassistEnhanced(Class c) {
    String className = c.getName();
    // pattern found in javassist 3.4 and 3.6's ProxyFactory 
    return className.startsWith(JAVASSIST_STARTWITH)
        || className.indexOf(JAVASSIST_INDEXOF) != -1
    ;
    }
private static final String JAVASSIST_STARTWITH = "org.javassist.tmp."; 
private static final String JAVASSIST_INDEXOF = "_$$_javassist_";
private static final String HB4_JAVASSIST  = "_$$_jvst" ;

/** 
 * Returns true if the given class is found to be a javassist enhanced class; 
 * false otherwise. 
 */ 
private static boolean isJavassistEnhanced(Class c) {
   String className = c.getName();
   // pattern found in javassist 3.4 and 3.6's ProxyFactory
   boolean isEnhanced =
      className.startsWith(JAVASSIST_STARTWITH)
      || className.indexOf(JAVASSIST_INDEXOF) != -1
      || className.in`enter code here`dexOf(HB4_JAVASSIST) != -1  // 3.18.1-GA
      ;
   return isEnhanced ;
}