Details
Description
This behavior is not consistent with java serialization, java serialization only calls readResolve() on superclass if visibility of this method is public or protected.
See: ObjectStreamClass.getInheritableMethod
As a result of this serialized classes may be replaced by superclass instances on deserialization.
Workaround: Implement readresolve() in all subclasses.
Activity
data:image/s3,"s3://crabby-images/db776/db77696d63af37997786b86548899c8fc160e0bb" alt=""
Field | Original Value | New Value |
---|---|---|
Resolution | Fixed [ 1 ] | |
Fix Version/s | 1.4.x Maintenance [ 19602 ] | |
Status | Open [ 1 ] | Resolved [ 5 ] |
data:image/s3,"s3://crabby-images/db776/db77696d63af37997786b86548899c8fc160e0bb" alt=""
Fix Version/s | 1.4.x Maintenance [ 19602 ] | |
Fix Version/s | 1.4.8 [ 20992 ] |
data:image/s3,"s3://crabby-images/db776/db77696d63af37997786b86548899c8fc160e0bb" alt=""
Status | Resolved [ 5 ] | Closed [ 6 ] |
Thanks for heads-up. Actually you found a bug present in XStream for more than 10 yearsdata:image/s3,"s3://crabby-images/27772/27772fc6e3af541e6b0af9e1b654eb082ade11d8" alt=""