Теперь я работаю с Джексоном, и у меня есть некоторые вопросы об этом.
Прежде всего. У меня есть две службы: сначала сбор данных и отправка службы, а второй - получение этих данных и, например, запись в файл.
Итак, первая служба имеет иерархию классов, например:
+----ConcreteC
|
Base ----+----ConcreteA
|
+----ConcreteB
И вторая служба имеет иерархию классов следующим образом:
ConcreteAAdapter extends ConcreteA implements Adapter {}
ConcreteBAdapter extends ConcreteB implements Adapter {}
ConcreteCAdapter extends ConcreteC implements Adapter {}
Первая служба ничего не знает о ConcreteXAdapter
.
Способ отправки данных на первую услугу:
Collection<Base> data = new LinkedBlockingQueue<Base>()
JacksonUtils utils = new JacksonUtils();
data.add(new ConcreteA());
data.add(new ConcreteB());
data.add(new ConcreteC());
...
send(utils.marshall(data));
...
public class JacksonUtils {
public byte[] marshall(Collection<Base> data) throws IOException {
ByteArrayOutputStream out = new ByteArrayOutputStream() {
@Override
public byte[] toByteArray() {
return buf;
}
};
getObjectMapper().writeValue(out, data);
return out.toByteArray();
}
protected ObjectMapper getObjectMapper() {
return new ObjectMapper();
}
public Object unmarshall(byte[] json) throws IOException {
return getObjectMapper().readValue(json, Object.class);
}
public <T> T unmarshall(InputStream source, TypeReference<T> typeReference) throws IOException {
return getObjectMapper().readValue(source, typeReference);
}
public <T> T unmarshall(byte[] json, TypeReference<T> typeReference) throws IOException {
return getObjectMapper().readValue(json, typeReference);
}
}
Итак, я хочу desirialize json в Collection ConcreteXAdapter
, а не в Collection of ConcreteX
(ConcreteA -> ConcreteAAdapter, ConcreteB -> ConcreteBAdapter, ConcreteC -> ConcreteCAdapter
). В случае, который я описал, я хочу получить:
Collection [ConcreteAAdapter, ConcreteBAdapter, ConcreteCAdapter]
Как я могу это сделать?