- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
如何将具有动态字段(如下面代码中称为故事的对象)的 JSON 对象反序列化为对象数组?
{
stories: {
-IhO1742Lki-Pit0snot: {
sentences: {
-IhO2fyAEn15XUge6HeY: {
userName: "Giulia",
text: "a dude created a new religion called PornDora"
},
-IhO2fyAEn15XUge6HeZ: {
userName: "Will",
text: "but it was kidnapped by a flying burrito copter"
},
-IhO2fyAEn15XUge6HeX: {
userName: "Jasmine",
text: "I went this morning at AngelHack hackaton"
}
}
},
-IhO-gNvUPHpB9fOn-Gm: {
sentences: {
-IhO0PBBnJavU2gfMcVO: {
userName: "Giorgio",
text: "I woke up alone in a dark alley and a yellow cat was starring at me"
},
-IhO11CWL9r6G4Pu8YXx: {
userName: "Will",
text: "the cat runned away when a blurred figure approached me and called my name"
}
}
}
}
}
下面是我用于反序列化的 Java 类:
public class Story {
private String id;
private List sentences;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public List getSentences() {
return sentences;
}
public void setSentences(List sentences) {
this.sentences = sentences;
}
}
public class Sentence {
private String id;
private String text;
private String userName;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getText() {
return text;
}
public void setText(String text) {
this.text = text;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
}
最佳答案
您是否控制 JSON 序列化的格式?例如,您能否改用以下格式:
{
"stories": [
{
"id": "-IhO1742Lki-Pit0snot",
"sentences": [
{
"id": "-IhO2fyAEn15XUge6HeY",
"text": "a dude created a new religion called PornDora",
"userName": "Giulia"
}
]
)
]
}
如果您控制序列化方面,您可以尝试使用 Polymorphic Type Handling (PTH)。
这将为 Jackson 提供足够的类型信息来反序列化您的对象。
另见 Tatu 的 accompanying blog post了解背景信息。
这是 Jackson 1.x 中 PTH 的代码片段。如果你想使用 Jackson 2.x,你将利用 com.fasterxml
packages并且需要稍微更改代码。
// import com.fasterxml.jackson.annotation.JsonTypeInfo;
// import com.fasterxml.jackson.databind.ObjectMapper;
import org.codehaus.jackson.annotate.JsonTypeInfo;
import org.codehaus.jackson.map.ObjectMapper;
public class MyObjectMapperProvider {
final ObjectMapper defaultObjectMapper;
public MyObjectMapperProvider() {
System.out.println("MyObjectMapperProvider()");
this.defaultObjectMapper = new ObjectMapper();
this.defaultObjectMapper.enableDefaultTyping(
ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.WRAPPER_OBJECT
);
// .enableDefaultTyping();
// .enableDefaultTyping(ObjectMapper.DefaultTyping.OBJECT_AND_NON_CONCRETE);
// .enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.WRAPPER_OBJECT);
// this.defaultObjectMapper.addMixInAnnotations(Bindable.class, MyObjectMapperProvider.MixIn.class);
// this.defaultObjectMapper.addMixInAnnotations(DataModel.WriteOp.class, MyObjectMapperProvider.MixIn.class);
}
}
顺便说一下,您提供的 json 实际上不是有效的 JSON。尝试使用
{
"stories": {
"-IhO-gNvUPHpB9fOn-Gm": {
"sentences": {
"-IhO0PBBnJavU2gfMcVO": {
"text": "I woke up alone in a dark alley and a yellow cat was starring at me",
"userName": "Giorgio"
},
"-IhO11CWL9r6G4Pu8YXx": {
"text": "the cat runned away when a blurred figure approached me and called my name",
"userName": "Will"
}
}
},
"-IhO1742Lki-Pit0snot": {
"sentences": {
"-IhO2fyAEn15XUge6HeX": {
"text": "I went this morning at AngelHack hackaton",
"userName": "Jasmine"
},
"-IhO2fyAEn15XUge6HeY": {
"text": "a dude created a new religion called PornDora",
"userName": "Giulia"
},
"-IhO2fyAEn15XUge6HeZ": {
"text": "but it was kidnapped by a flying burrito copter",
"userName": "Will"
}
}
}
}
}
您可以通过将其传递到 python -m json.tool
来验证您的 json 是否正确。在 OS X 上,您可以将 json 复制到剪贴板并将其传递给 json.tool
,如下所示:
> pbpaste | python -m json.tool
如果您想尝试一下,这里有一个利用 Jersey 的小例子。使用 curl http://localhost:7654/sandbox/test
来练习一下:
主类.java
import java.net.URI;
import org.glassfish.grizzly.http.server.HttpServer;
// import org.glassfish.hk2.utilities.binding.AbstractBinder;
import org.glassfish.jersey.grizzly2.httpserver.GrizzlyHttpServerFactory;
import org.glassfish.jersey.jackson.JacksonFeature;
import org.glassfish.jersey.server.ResourceConfig;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class MainClass {
private static final Logger LOG = LoggerFactory.getLogger(MainClass.class);
public static final String PATH = "http://localhost:7654/sandbox/";
public static void main(String[] args) {
// create a resource config that scans for JAX-RS resources and providers
// in com.mlbam.monitoring.lsg.data_aggregator package
final ResourceConfig rc = new ResourceConfig()
.packages("com.mlbam.internal")
// .packages("com.mlbam.monitoring.collector.provis")
.register(MyObjectMapperProvider.class)
.register(JacksonFeature.class)
;
// create and start a new instance of grizzly http server
// exposing the Jersey application at BASE_URI
final HttpServer grizzlyServerV1 = GrizzlyHttpServerFactory.createHttpServer(URI.create(PATH), rc);
LOG.info("Jersey app started with WADL available at {}application.wadl", PATH);
try {
Thread.sleep(10_000);
} catch (InterruptedException e) { }
LOG.info("Stopping");
}
}
MyObjectMapperProvider.java:
// import com.fasterxml.jackson.annotation.JsonTypeInfo;
// import com.fasterxml.jackson.databind.ObjectMapper;
import org.codehaus.jackson.annotate.JsonTypeInfo;
import org.codehaus.jackson.map.ObjectMapper;
import javax.ws.rs.ext.ContextResolver;
import javax.ws.rs.ext.Provider;
@Provider
public class MyObjectMapperProvider implements ContextResolver<ObjectMapper> {
final ObjectMapper defaultObjectMapper;
public MyObjectMapperProvider() {
System.out.println("MyObjectMapperProvider()");
this.defaultObjectMapper = new ObjectMapper();
this.defaultObjectMapper.enableDefaultTyping(
ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.WRAPPER_OBJECT
);
// .enableDefaultTyping();
// .enableDefaultTyping(ObjectMapper.DefaultTyping.OBJECT_AND_NON_CONCRETE);
// .enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.WRAPPER_OBJECT);
// this.defaultObjectMapper.addMixInAnnotations(Bindable.class, MyObjectMapperProvider.MixIn.class);
// this.defaultObjectMapper.addMixInAnnotations(DataModel.WriteOp.class, MyObjectMapperProvider.MixIn.class);
}
@Override
public ObjectMapper getContext(Class<?> type) {
System.out.println("MyObjectMapperProvider.getContext(" + type + ")");
return this.defaultObjectMapper;
}
// @JsonTypeInfo(use=JsonTypeInfo.Id.CLASS, include=JsonTypeInfo.As.PROPERTY, property="@class")
// public static class MixIn {
// }
}
我的资源.java
import javax.inject.Singleton;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
@Singleton
@Path("test/")
public class MyResource {
// public Thing[] state = {new Thing("asdf"), new Thing("foo"), new Thing("bar")};
public String[] state = {"asdf", "foo", "bar"};
@GET
@Produces(MediaType.APPLICATION_JSON)
public Response test() {
return Response.ok(state).build();
}
}
依赖关系(如果使用 maven):
<dependencies>
<!-- Logging -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.5</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.0.13</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.0.13</version>
</dependency>
<!-- Jersey Specific Dependencies -->
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-grizzly2-http</artifactId>
<version>2.3.1</version>
</dependency>
<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-json-jackson</artifactId>
<version>2.3.1</version>
</dependency>
</dependencies>
关于java - 如何使用 Jackson 反序列化动态 JSON 字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13666806/
我是 python 的新手。我试图找到我的文本的频率分布。这是代码, import nltk nltk.download() import os os.getcwd() text_file=open(
我对安卓 fragment 感到困惑。我知道内存 fragment 但无法理解什么是 android fragment 问题。虽然我发现很多定义,比如 Android fragmentation re
尝试对 WordPress 进行 dockerise 我发现了这个场景: 2个数据卷容器,一个用于数据库(bbdd),另一个用于wordpress文件(wordpress): sudo docker
这个问题已经有答案了: From the server is there a way to know that my page is being loaded in an Iframe (1 个回答)
我正在玩小型服务器,试图对运行在其上的服务进行docker化。为简化起见,假设我必须主要处理:Wordpress和另一项服务。 在Docker集线器上有许多用于Wordpress的图像,但是它们似乎都
我想要发生的是,当帐户成功创建后,提交的表单应该消失,并且应该出现一条消息(取决于注册的状态)。 如果成功,他们应该会看到一个简单的“谢谢。请检查您的电子邮件。” 如果不是,那么他们应该会看到一条适当
就是这样,我需要为客户添加一个唯一标识符。通过 strip 元数据。这就是我现在完全构建它的方式,但是我只有最后一部分告诉我用户购买了哪个包。 我试着看这里: Plans to stripe 代码在这
我有一个类将执行一些复杂的操作,涉及像这样的一些计算: public class ComplexAction { public void someAction(String parameter
这个问题已经有答案了: maven add a local classes directory to module's classpath (1 个回答) 已关闭10 年前。 我有一些不应更改的旧 E
我使用 fragment 已经有一段时间了,但我经常遇到一个让我烦恼的问题。 fragment 有时会相互吸引。现在,我设法为此隔离了一个用例,它是这样的: Add fragment A(也使用 ad
我的 html 中有一个 ol 列表,上面有行条纹。看起来行条纹是从数字后面开始的。有没有办法让行条纹从数字开始? 我已经包含了正在发生的事情的片段 h4:nth-child(even) {
如何仅使用 css 将附加图像 html 化? 如果用纯 css 做不到,那我怎么能至少用一个图像来做 最佳答案 这不是真正的问题,而是您希望我们为您编写代码。我建议您搜索“css breadcrum
以下是 Joshua 的 Effective Java 的摘录: If you do synchronize your class internally, you can use various te
在这里工作时,我们有一个框向业务合作伙伴提供 XML 提要。对我们的提要的请求是通过指定查询字符串参数和值来定制的。其中一些参数是必需的,但很多不是。 例如,我们要求所有请求都指定一个 GUID 来标
我有 3 个缓冲区,其中包含在 32 位处理器上运行的 R、G、B 位数据。 我需要按以下方式组合三个字节: R[0] = 0b r1r2r3r4r5r6r7r8 G[0] = 0b g1g2g3g4
我最近发现了关于如何使用 History.js、jQuery 和 ScrollTo 通过 HTML5 History API 对网站进行 Ajax 化的要点:https://github.com/br
我们有一个 Spring Boot 应用程序,由于集成需要,它变得越来越复杂——比如在你这样做之后发送一封电子邮件,或者在你之后广播一条 jms 消息等等。在寻找一些更高级别的抽象时,我遇到了 apa
我正在尝试首次实施Google Pay。我面临如何指定gateway和gatewayMarchantId的挑战。 我所拥有的是google console帐户,不知道在哪里可以找到此信息。 priva
昨天下午 3 点左右,我为两个想要从一个 Azure 帐户转移到另一个帐户的网站设置了 awverify 记录。到当天结束时,Azure 仍然不允许我添加域,所以我赌了一把,将域和 www 子域重新指
我正在使用terms facet在elasticsearch服务器中获取顶级terms。现在,我的标签"indian-government"不被视为一个标签。将其视为"indian" "governm
我是一名优秀的程序员,十分优秀!