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

How to define Java classes to serialize or deserialize according to the content of this XML example #367

Open
MartyAlien opened this issue Jan 2, 2025 · 3 comments
Assignees
Labels

Comments

@MartyAlien
Copy link

hi all:
I want to define a class that can deserialize the following XML content and also serialize it into this XML format. But I don't know how to handle the List type anymore.

<!-- xml demo-->

<stream>
    <action>abc</action>
    <userName>tom</userName>
    <list name="userDataList">
        <row>
            <accountNo>a1000</accountNo>
        </row>
        <row>
            <accountNo>b456</accountNo>
        </row>
    </list>
    <list name="others">
        <row>
            <name>job</name>
        </row>
        <row>
            <name>ace</name>
        </row>
    </list>
</stream>

This class is what I expected to define, but I don't know how to use XStream annotations or other APIs to complete it. Do you have any better suggestions?

    @Data
    @XStreamAlias("stream")
    public static class Demo implements Serializable {
        private String action;
        private String userName;

        // TODO how to deal this?
        private List<UserAccount> userDataList;

        // TODO how to deal this?
        private List<User> others;

        @Data
        public static class UserAccount implements Serializable {
            private String accountNo;
        }

        @Data
        public static class User implements Serializable {
            private String name;
        }
    }
@joehni joehni self-assigned this Jan 3, 2025
@joehni joehni added the question label Jan 3, 2025
@joehni
Copy link
Member

joehni commented Jan 3, 2025

Two comments in advance: XStream has no clue about the Data annotation and you classes don't have to be serializable for XStream.

Then as a general advice: Try to configure the XStream instance so, that it writes the XML you want to read. It is a lot less tedious, if you see the XML that is generated (and then typically also expected when reading).

Then you will have to answer yourself the question how far you want to sacrifice your class types to enable XStream to write the requested structure out of the box? Your XML contains two list elements in stream, i.e. that's something that cannot match the default mechanism that maps from member names to XML elements. The only way to configure XStream to generate or process something like this is the usage of an implicit collection, i.e. your Demo type would not contain two members of type list, but one List of type List of anything (List<List<?>> lists), which the in turn is declared as implicit collection. While this is possible, it is also very nasty when working with the data structure.

The alternative would be to create a custom converter (see XStream tutorials) for Demo that is able to read/write the appropriate member from the name attribute of its list elements and use then a separate instance of the NamedCollectionConverter for each list to write/read the list content.

@MartyAlien
Copy link
Author

@joehni It should be noted here that changing this XML structure is not allowed. This means that all collection types must be defined as list node pairs, and collection elements must be defined as row node pairs.

I'm more interested in what you mentioned about using NamedCollectionConverter to do field processing of collection types. If NamedCollectionConverter could not do the conversion of the xml structure I am talking about, is it possible for me to customize the Converter subclass to handle the conversion of collection types?

@joehni
Copy link
Member

joehni commented Jan 13, 2025

Read again, I did not propose any change to your XML structure. I proposed the creation of an own converter for your Demo class. And I proposed indeed the creation of a subclass of the NamedCollectionConverter. See Javadoc or XStream unit tests, how the converter works and see my comment above what has to be changed.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants