JSF backing bean should be serializable?
I'm getting these开发者_运维知识库 messages:
[#|2010-07-30T11:28:32.723+0000|WARNING|glassfish3.0.1|javax.faces|_ThreadID=37;_ThreadName=Thread-1;|Setting non-serializable attribute value into ViewMap: (key: MyBackingBean, value class: foo.bar.org.jsf.MyBackingBean)|#]
Do these mean that my JSF backing beans should implement Serializable? Or are they refering to some other problem?
Yes, you understood it correctly. The view is basically stored in the session scope. The session scope is in JSF backed by the Servlet's HttpSession
. All session attributes are supposed to implement Serializable
, this because the average servletcontainer may persist session data to harddisk among others to be able to share with other servers in a cluster, or to survive heavy load, or to revive sessions during server restart.
Storing raw Java objects on harddisk is only possible if the respective class implements Serializable
. Then ObjectOutputStream
can be used to write them to harddisk and ObjectInputStream
to read them from harddisk. The servletcontainer manages this all transparently, you actually don't need to worry about it. JSF is just giving a warning so that you understand the risks.
Beans that use session, application, or conversation scope must be serializable, but beans that use request scope do not have to be serializable. Source: https://docs.oracle.com/javaee/6/tutorial/doc/gjbbk.html
Yes, Backing Beans / Managed Beans are basically meant to persist the state of the view, so it should be implemented serialization, but UI Components may not allow it to serializable and JSF Runitime will show you errror/ warning message. one thing you can do is mark such component transient in your MBeans.
Thanks.
精彩评论