2011-11-23 3 views
0

アプリケーションを実行した後、シリアライズ可能ではない例外エラーが発生しました。java.io.NotSerializableExceptionエラー

エラー・スタックは、次のことを示しています

SEVERE: IOException while loading persisted sessions: java.io.WriteAbortedException: writing aborted; java.io.NotSerializableException: br.dao.DriverManagerDAOFactory 
java.io.WriteAbortedException: writing aborted; java.io.NotSerializableException: br.dao.DriverManagerDAOFactory 
    at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1350) 
    at java.io.ObjectInputStream.defaultReadFields(ObjectInputStream.java:1963) 
    at java.io.ObjectInputStream.readSerialData(ObjectInputStream.java:1887) 
    at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:1770) 
    at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1346) 
    at java.io.ObjectInputStream.readObject(ObjectInputStream.java:368) 
    at org.apache.catalina.session.StandardSession.readObject(StandardSession.java:1496) 
    at org.apache.catalina.session.StandardSession.readObjectData(StandardSession.java:998) 
    at org.apache.catalina.session.StandardManager.doLoad(StandardManager.java:394) 
    at org.apache.catalina.session.StandardManager.load(StandardManager.java:321) 
    at org.apache.catalina.session.StandardManager.start(StandardManager.java:648) 
    at org.apache.catalina.core.ContainerBase.setManager(ContainerBase.java:446) 
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4631) 
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:799) 
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779) 
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:601) 
    at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:675) 
    at org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:601) 
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:502) 
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1317) 
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:324) 
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142) 
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1065) 
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:840) 
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1057) 
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463) 
    at org.apache.catalina.core.StandardService.start(StandardService.java:525) 
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:754) 
    at org.apache.catalina.startup.Catalina.start(Catalina.java:595) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:616) 
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289) 
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414) 
Caused by: java.io.NotSerializableException: br.dao.DriverManagerDAOFactory 
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1180) 
    at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1528) 
    at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1493) 
    at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1416) 
    at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1174) 
    at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:346) 
    at org.apache.catalina.session.StandardSession.writeObject(StandardSession.java:1572) 
    at org.apache.catalina.session.StandardSession.writeObjectData(StandardSession.java:1015) 

だから私は問題を修正することを望ん以下でした:

class DriverManagerDAOFactory extends DAOFactory implements Serializable{ 
    private String url; 
    private String username; 
    private String password; 

    DriverManagerDAOFactory(String url, String username, String password) { 
     this.url = url; 
     this.username = username; 
     this.password = password; 
    } 

    Connection getConnection() throws SQLException { 
     return DriverManager.getConnection(url, username, password); 
    } 
} 

私はSerializableを実装した後、エラーがまだ現れていても。 ..これについての何か手がかり? :/

+0

あなたに 'serialVersionUID'がない理由はありますか?コンパイラはそれについて警告する必要があります。 – Kane

答えて

4

スーパークラスDAOFactoryはシリアライズ可能ですか?あなたの変更はクラスパスで正しく取り上げられましたか?以前のjar/classesでソフトウェアが実行されている可能性があります。

+0

ああ、ありがとう...私のdaofactoryはシリアル化できませんでした。今は大丈夫です! – ShaunK

1

接続はシリアル化してはならず、シリアル化できません。あなたのDAOFactoryは、同様の理由で直列化できません。問題は、あなたのファクトリオブジェクトがあなたのセッションで参照/保存されているため、あなたのセッションがシリアル化されるときにDAOFactoryもシリアル化されて例外が発生するからです。あなたのセッションになぜあなたのファクトリオブジェクトが含まれるべきかについて、より詳しく調べるべきです。

+0

Humm okayうわー、私は自分のdaofactoryとDriverManagerDAOFactoryのためにシリアライズ可能なものを取り出して、もう一度アプリケーションを走らせました、エラーはありませんでした...これはとても変です.. – ShaunK

関連する問題