Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Serialization - future direction and support for other serialization protocols, via a public Serialization API and JERI Serialization Layer. #103

Open
pfirmstone opened this issue Sep 19, 2019 · 6 comments

Comments

@pfirmstone
Copy link
Owner

No description provided.

@pfirmstone
Copy link
Owner Author

@pfirmstone
Copy link
Owner Author

 [java] WARNING: An illegal reflective access operation has occurred
 [java] WARNING: Illegal reflective access by org.apache.river.api.io.ObjectStreamClassContainer$3 (file:/C:/Users/HD.Design/Documents/NetBeansProjects/JGDMS/JGDMS/dist/target/JGDMS-3.1.1-SNAPSHOT/lib/jgdms-platform-3.1.1-SNAPSHOT.jar) to method java.lang.Enum.readObjectNoData()
 [java] WARNING: Please consider reporting this to the maintainers of org.apache.river.api.io.ObjectStreamClassContainer$3
 [java] WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
 [java] WARNING: All illegal access operations will be denied in a future release

@pfirmstone
Copy link
Owner Author

Serializable classes annotated with @AtomicSerial can be serialized using AtomicMarshalOutputStream and deserialized using AtomicMarshalInputStream.

AtomicMarshalInputStream is a complete re-implementation of deserialization.

@AtoimcSerial is serial form compatible with Java Serialization, with the exception of circular object graphs.

@pfirmstone
Copy link
Owner Author

AtomicMarshalInputStream requires @AtomicSerial deserialization constructors, it doesn't call readObject(), although it does check whether it exists. AtomicMarshalInputStream allows deserialization of Serializable Objects that have ONLY primitive fields and do not have a readObject() method.

We probably aren't going to have access to these private deserialization methods in future, so will need to work without them. It probably also means that we will need all classes to have deserialization constructors.

@pfirmstone
Copy link
Owner Author

According to the Project Amber link above, java will likely have a new keyword "open" to allow legal reflective access to private methods and constructors.

It is unlikely that fields will be accessible in future.

Currently AtomicMarshalInputStream allows deserialization of simple Object's that contain only primitive fields and has no readObject method. Since it is unlikely that we will have reflective access to readObject and other standard java serialization methods, we will probably need to remove support for this functionality, probably sooner the better and require all serializable objects to implement @AtomicSerial and its required constructor.

AtomicMarshalOutputStream will need to be modified to support an annotated deconstructor, this can be defined by an interface, with a caller sensitive parameter, so that each class in the object heirarchy with state, implements as well as calls the superclass method implementation.

@pfirmstone pfirmstone changed the title Java Serialization - future direction Serialization - future direction and support of other serialization protocols. Feb 7, 2021
@pfirmstone pfirmstone changed the title Serialization - future direction and support of other serialization protocols. Serialization - future direction and support of other serialization protocols, via a public Serialization API and JERI Serialization Layer. Feb 7, 2021
@pfirmstone pfirmstone changed the title Serialization - future direction and support of other serialization protocols, via a public Serialization API and JERI Serialization Layer. Serialization - future direction and support for other serialization protocols, via a public Serialization API and JERI Serialization Layer. Feb 8, 2021
pfirmstone pushed a commit that referenced this issue Feb 8, 2021
…protocols, via a public Serialization API and JERI Serialization Layer. #103
pfirmstone pushed a commit that referenced this issue Feb 8, 2021
…protocols, via a public Serialization API and JERI Serialization Layer. #103
pfirmstone pushed a commit that referenced this issue May 4, 2021
…protocols, via a public Serialization API and JERI Serialization Layer. #103

Add Replace interface to allow similar functionality to Java Serialization's writeReplace method.
pfirmstone pushed a commit that referenced this issue May 4, 2021
…protocols, via a public Serialization API and JERI Serialization Layer. #103

Implement Replace interface for URICodeSource

PreferredClassProvider creating ClassLoader using proxy codebase URL ProtectionDomain #125

Add AccessControlContext parameter to constructor, to allow context to be passed in.
@pfirmstone
Copy link
Owner Author

Anyone interested in this topic, feel free to post ideas or thoughts on this issue.

I have been considering other Serialization protocols, most Object protocols represent Object data as fields with name value tuples.

So far in developing the @AtomicSerial public API, I have been duplicating the capabilities of Java Serialization, I first re- implemented Java de-serialization and now I have re-implemented serialization (I haven't yet uploaded it). However one of my concerns is that it is unnecessarily overly complex and could only be partially supported by other serialization protocols.

The name tuple pairs allow for flexibility in evolution of serial form, in my current implementation of deserialization, it is possible to change the serial form in a backward compatible manner. Access to the underlying stream, from object classes, which Java Serialization permits, creates extraneous artifacts that are not part of an object's declared serial from, the order of these artifacts, whether objects, or primitives, when written to the stream is of critical importance and cannot be changed, without breaking compatibility.

As @AtomicSerial uses a completely different API, and wouldn't yet have a significant user base, it would be better to make a breaking change now, rather than leave it until later.

This would also mean deprecation and removal of the @AtomicExternal API's, Objects would be limited to defining a set of parameter tuple name value pairs that represents the serial form of the class in an object's inheritance hierarchy, within a tree graph of objects.

To date I have maintained a serial form identical to that of Java serialization, however it's possible for a class to support both @atomic and Serializable, with different serial forms for each.

The benefit would be support of a wider range of cross platform serialization protocols.

It would seem better not to repeat the mistakes of Java Serialization.

Thoughts?

pfirmstone pushed a commit that referenced this issue May 11, 2021
…protocols, via a public Serialization API and JERI Serialization Layer. #103
pfirmstone pushed a commit that referenced this issue May 11, 2021
…protocols, via a public Serialization API and JERI Serialization Layer. #103
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant