Итак, я пытаюсь маршалировать общий список объектов, но я хочу, чтобы каждый список имел определенный XmlRootElement(name. .). То, как я это делаю, я знаю, что это невозможно без написания определенного класса-оболочки для каждого типа объекта и объявления XmlRootElement. Но, может быть, есть другой способ...?
Рассмотрим следующие классы:
abstract public class Entity {
}
@XmlAccessorType(XmlAccessType.FIELD)
@XmlRootElement(name="user")
public class User extends Entity {
private String username;
public String getUsername() {
return username;
}
public void setUsername( String username ) {
this.username = username;
}
}
@XmlRootElement
public class EntityList<T extends Entity> {
@XmlAnyElement(lax=true)
private List<T> list = new ArrayList<T>();
public void add( T entity ) {
list.add( entity );
}
public List<T> getList() {
return list;
}
}
public class Test {
public static void main( String[] args ) throws JAXBException {
User user1 = new User();
user1.setUsername( "user1" );
User user2 = new User();
user2.setUsername( "user2" );
EntityList<User> list = new EntityList<User>();
list.add( user1 );
list.add( user2 );
JAXBContext jc = JAXBContext.newInstance( EntityList.class, User.class );
Marshaller m = jc.createMarshaller();
m.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);
m.marshal( list, System.out );
}
}
Как и ожидалось, это дает:
<entityList>
<user>
<username>user1</username>
</user>
<user>
<username>user2</username>
</user>
</entityList>
Я хочу иметь возможность изменять имя этого тега в зависимости от типа Entity, с которым я создаю EntityList.
Я знаю, что здесь мы говорим о компиляции и времени выполнения, но, может быть, есть какой-то хакерский способ изменить оболочку родительского элемента из дочернего?