0

Struts/HibernateアプリケーションをGoogleAppEngineに変換しています。アプリケーションのフロントページを起動しようとすると、次のエラーメッセージが表示されます。誰かがこれを手伝ってくれますか?

java.lang.IllegalAccessError
    at net.sf.cglib.core.ClassEmitter.setTarget(ClassEmitter.java:47)
    at net.sf.cglib.core.ClassEmitter.<init>(ClassEmitter.java:39)
    at net.sf.cglib.core.KeyFactory$Generator.generateClass(KeyFactory.java:165)
    at net.sf.cglib.core.DefaultGeneratorStrategy.generate(DefaultGeneratorStrategy.java:25)
    at net.sf.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:215)
    at net.sf.cglib.core.KeyFactory$Generator.create(KeyFactory.java:145)
    at net.sf.cglib.core.KeyFactory.create(KeyFactory.java:117)
    at net.sf.cglib.core.KeyFactory.create(KeyFactory.java:108)
    at net.sf.cglib.core.KeyFactory.create(KeyFactory.java:104)
    at org.hibernate.impl.SessionFactoryImpl.<clinit>(SessionFactoryImpl.java:321)
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1005)
    at com.configuration.ConfigurationListener.contextInitialized(ConfigurationListener.java:19)
    at org.mortbay.jetty.handler.ContextHandler.startContext(ContextHandler.java:548)
    at org.mortbay.jetty.servlet.Context.startContext(Context.java:136)
    at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1250)
    at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:517)
    at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:467)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
    at org.mortbay.jetty.Server.doStart(Server.java:224)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
    at com.google.appengine.tools.development.JettyContainerService.startContainer(JettyContainerService.java:196)
    at com.google.appengine.tools.development.AbstractContainerService.startup(AbstractContainerService.java:239)
    at com.google.appengine.tools.development.DevAppServerImpl.start(DevAppServerImpl.java:146)
    at com.google.appengine.tools.development.DevAppServerMain$StartAction.apply(DevAppServerMain.java:189)
    at com.google.appengine.tools.util.Parser$ParseResult.applyArgs(Parser.java:48)
    at com.google.appengine.tools.development.DevAppServerMain.<init>(DevAppServerMain.java:128)
    at com.google.appengine.tools.development.DevAppServerMain.main(DevAppServerMain.java:104)

上記のエラーメッセージには、ConfigurationListenerというクラスへの参照があります。これは、アプリケーションのデータベースセッションを取得するために提供したクラスです。これがエラーが発生する方法であり、どの行が19行目であるかをマークしました。

public void contextInitialized(ServletContextEvent contextEvent) {
            /* The following line is line 19. */
    this.sessionFactory = this.configuration.configure().buildSessionFactory();
    this.context = contextEvent.getServletContext();
    this.context.setAttribute("sessionFactory", sessionFactory);
}
4

1 に答える 1

0

Hibernate は GAE では直接サポートされていないことに注意してください。

http://code.google.com/p/googleappengine/wiki/WillItPlayInJava

さらに、これがあなたの以前の質問に関連している場合、バイトコード操作ライブラリを大幅に古いものに単純に置き換えることは状況によっては機能する可能性がありますが、ほぼ間違いなく悪い考えであることを指摘することが重要です。ライブラリの依存関係、特にそのような基本的なレベルで動作する依存関係の任意の混合と一致は、良いアプローチではありません.IMO.

于 2012-06-18T10:03:36.957 に答える