我有一个带有大型复杂json对象的大型CouchDB。反序列化时,有时会出现错误,因为文档格式不正确。
可悲的是,gson封装并没有提供比以下更多的信息:
com.google.gson.JsonSyntaxException:
java.lang.IllegalStateException: Expected BLAH but was BLUB
我必须开始调试整个应用程序,以找到哪个文档是无法解析的文档。
我希望在发生异常时获取正在反序列化的父文档,以便我可以记录其id。
这可能吗?
答案 0 :(得分:0)
所以到目前为止我发现的方法是创建一个记录错误并尝试创建空对象或至少返回null的TypeAdapterFactory。这很好,虽然我在对象层次结构的最低级别得到错误(即在无法解析的点,所以我错过了关于它是哪个文档的信息。)
以下是代码:
public class RobustTypeAdapterFactory implements TypeAdapterFactory {
private static final Logger LOG = LoggerFactory.getLogger(RobustTypeAdapterFactory.class);
@Override
public <T> TypeAdapter<T> create(final Gson gson, final TypeToken<T> type) {
final TypeAdapter<T> delegate = gson.getDelegateAdapter(this, type);
return new TypeAdapter<T>() {
@Override
public void write(final JsonWriter out, final T value) throws IOException {
delegate.write(out, value);
}
@SuppressWarnings("unchecked")
@Override
public T read(final JsonReader in) throws IOException {
try {
return delegate.read(in);
} catch (IOException | IllegalStateException | JsonSyntaxException e) {
LOG.info("Could not parse value for {}", type.getRawType());
in.skipValue();
try {
// try to create empty object
return (T) type.getRawType().newInstance();
} catch (ReflectiveOperationException e1) {
// we couldn't create an empty object, so we return null
return null;
}
}
}
};
}
}
有更好的主意吗?