我将 Jackson 2.7.5 与 Jersey 2.25.1 配合使用。我正在尝试修复现有的生产代码,当它在JSON输入中获得意外字段时,它现在因“无法识别的PropertyException:无法识别的字段”而失败。
在研究这个问题时,我发现了几篇旧帖子(5年),建议各种修复方法与我当前的代码非常不同。我不太关注这些,因为它们是针对旧版本的Jackson/Jersey。最近的建议,包括泽西岛自己的文档(https://jersey.github.io/documentation/latest/media.html#json.jackson),看起来与我已经拥有的内容非常相似。事实上,在我看来,我现有的代码似乎已经遵循了当前的做法。但是,泽西岛似乎忽略了我的自定义对象映射器设置...
DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false
我很确定该设置应该修复错误,但泽西似乎使用默认的ObjectMapper而不是我的自定义设置。
首先,这里是依赖信息,我相信它与泽西留档(https://jersey.github.io/documentation/latest/media.html#json.jackson)中显示的信息相匹配。
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-json-jackson</artifactId>
<version>${jersey.version}</version>
</dependency>
下面是返回错误的调用:
// this will throw an exception if it can't convert the string to the class
PropSearchResponse propResponse = null;
try {
propResponse = getResponse.readEntity(PropSearchResponse.class);
} catch(final ProcessingException e) {
throw new ProcessResultException(Code.FAILED, "failed to map from prop response", e);
}
以下是我的自定义对象映射器的原始代码:
@Provider()
@Produces(value = MediaType.APPLICATION_JSON)
public class OutMapperProvider implements ContextResolver<ObjectMapper> {
private final ObjectMapper mapper;
public OutMapperProvider() {
mapper = new ObjectMapper();
mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
mapper.configure(JsonGenerator.Feature.ESCAPE_NON_ASCII, true);
mapper.setSerializationInclusion(Include.NON_NULL);
mapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ssZ"));
}
@Override()
public ObjectMapper getContext(final Class<?> type) {
return mapper;
}
}
以下是泽西岛文档中的示例:
@Provider
public class MyObjectMapperProvider implements ContextResolver<ObjectMapper> {
final ObjectMapper defaultObjectMapper;
public MyObjectMapperProvider() {
defaultObjectMapper = createDefaultMapper();
}
@Override
public ObjectMapper getContext(Class<?> type) {
return defaultObjectMapper;
}
private static ObjectMapper createDefaultMapper() {
final ObjectMapper result = new ObjectMapper();
result.configure(Feature.INDENT_OUTPUT, true);
return result;
}
}
我已经尝试了泽西示例(当然是更改名称以匹配我的名称)以及我在网上找到的其他几个示例。泽西示例在@覆盖之后进行自定义。大多数其他示例在@覆盖之前进行自定义,但它们似乎都与彼此和我现有的代码基本相似。但似乎没有任何区别。无论我尝试了什么,自定义配置都被忽略,泽西调用了默认的ObjectMapper,它在意外的JSON字段上失败。
免责声明:这是我第一次接触泽西和杰克逊。我还没有很好地理解潜在的机制。我只是想遵循例子的模式。
更新:我相信上面的代码基本正确。但是Paul下面的评论说我需要注册自定义ObjectMapper。我试着复制了几个我在网上找到的例子(比如https://docs . hui hoo . com/jersey/2.13/deployment . html # environment EMT . app model的例子4.2),但是没有成功。对于我目前的尝试,我已经尝试使用Jersey的ResourceConfig向现有的配置包(com.dmx.repl.config)添加一个新的MyApplication类。代码如下。但是,它仍然不起作用。
编辑:忽略此代码,它不起作用。请参阅下面的解决方案。
package com.dmx.repl.config;
import org.glassfish.jersey.server.ResourceConfig;
import com.dmx.repl.commons.OutMapperProvider;
/**
*
* @author Greg
* @version 1.0
*/
// Attempt to register custom ObjectMapper
public class MyApplication extends ResourceConfig {
public MyApplication() {
// I've tried both of these.
//register(OutMapperProvider.class);
packages("com.dmx.repl.commons");
}
}
泽西现在正在识别自定义ObjectMapper,它被配置为忽略带有“FAIL_ON_UNKNOWN_PROPERTIES、false”的未知JSON字段。
上面的对象映射器代码是正确的。问题(正如Paul在评论中指出的)是客户端没有注册自定义ObjectMapper。这个问题很容易解决,只需在使用ClientBuilder进行客户端设置之后,在客户端设置方法中添加以下代码行。
this.client.register(OutMapperProvider.class);
我在glassfish服务器上使用Jersey的最新版本(2.13),以及jackson的最新版本(版本.2.4)。我已经编写并注册了一个自定义ObjectMapper,但它似乎只有集合被我的自定义ObjectMapper序列化。 我在这个页面上看到了类似的问题:https://java.net/jira/browse/glassfish-20815,但是这里提供的解决方案对我不起作用。
我有一个用例,其中我需要维护两组JSON输出,一组具有JSON属性的漂亮名称,另一组没有。所以我决定自定义ObjectMapper,以便它忽略字段上的@JSONProperty(“pretty name”)注释,而使用字段属性名。在本例中,希望得到以下JSON输出 具有漂亮名称的JSON输出如下所示 我的ObjectMapper配置代码如下所示 我看了一些其他的答案,但对我不起作用。我得到了一个N
初始化服务器时,出现以下错误: java.lang.IllegalStateException:无法将[java.lang.String]类型的值转换为属性“Object Mapper”所需的类型[org.codehaus.jackson.map.objectMapper]:在org.springframework.beans.typeConverterDelegate.ConvertifEmen
如何使Gson正确序列化我的密钥?
使用代替和代替 然后在请求属性中添加 但是当我在javascript中检索它时,我得到了jsonObject的值 我在我的项目中已经使用了下面的库,如果需要,可以使用任何新的库
给出以下SQL模式: 我想要一个地图绘制者,比如: 所以我可以这样做: 我不知道怎么做,除了在personMapper之后。getPersons()来操作结果。