- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想将具有配置属性的 XML 文件解析为 JSON,然后将此 JSON 转换为最终结果对象。
我的类(class)看起来像:
@SpringBootApplication
public class AdvancedApplication {
public static void main(String[] args) {
SpringApplication.run(AdvancedApplication.class, args);
XmlMapper xmlMapper = new XmlMapper();
try {
List XMLEntries = xmlMapper
.readValue(new ClassPathResource("configuration.xml")
.getFile(), List.class);
ObjectMapper mapper = new ObjectMapper();
String jsonConfig = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(XMLEntries);
JsonNode parent = new ObjectMapper().readTree(jsonConfig);
String content = parent.path("serverport").asText();
System.out.println(content);
System.out.println(jsonConfig);
} catch (IOException e) {
e.printStackTrace();
}
}
}
在第一种情况下:
List XMLEntries = xmlMapper
.readValue(new ClassPathResource("configuration.xml")
.getFile(), List.class);
上述方法将 JSON 包装在列表中,结果如下:
[ {
"serverport" : "9966"
}, {
"clientport" : "9999",
"serverHost" : "localhost"
} ]
但在这种情况下,我无法使用以下行读取值:
String content = parent.path("serverport").asText();
因为内容是空的。
最后,我决定以这种特殊方式将 JSON 转换为结果对象 Config:
Config configObject = mapper.readValue(jsonConfig, Config.class);
但不幸的是,我收到了如下异常:
com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `com.javase.advanced.config.Config` out of START_ARRAY token
at [Source: (String)"[ {
"serverport" : "9966"
}, {
"clientport" : "9999",
"serverHost" : "localhost"
} ]"; line: 1, column: 1]
我的configuration.xml 文件如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<config>
<server serverport="9966"/>
<client clientport="9999">
<serverHost>localhost</serverHost>
</client>
</config>
配置类如下:
@NoArgsConstructor
@Getter
@AllArgsConstructor
@ToString
public class Config {
private Server server;
private Client client;
}
服务器类
@AllArgsConstructor
@Getter
@NoArgsConstructor
public class Server {
@JsonProperty("serverport")
private String serverPort;
}
配置类
@Getter
@NoArgsConstructor
public class Client {
@JsonProperty("serverHost")
private String serverHost;
@JsonProperty("clientport")
private String clientPort;
}
我想要实现的是将configuration.xml 文件解析为JSON 并将其转换为Config 对象以创建配置类以供进一步使用。
编辑:
在@pvpkiran
建议之后,我尝试了如下方法:
Config configValue = xmlMapper.readValue(new ClassPathResource("configuration.xml")
.getFile(), Config.class);
但毕竟我收到了如下错误:
org.codehaus.jackson.map.exc.UnrecognizedPropertyException: Unrecognized field "serverport" (Class com.javase.advanced.server.Server), not marked as ignorable
at [Source: C:\Users\mzawadzki\Desktop\advanced\target\classes\configuration.xml; line: 3, column: 30] (through reference chain: com.javase.advanced.config.Config["server"]->com.javase.advanced.server.Server["serverport"])
编辑2:
修改后我的类看起来像:
客户端类
@Getter
@NoArgsConstructor
public class Client {
@JacksonXmlProperty(localName = "clientport")
private String clientPort;
@JacksonXmlProperty(localName = "serverHost")
private String serverHost;
}
服务器类
@AllArgsConstructor
@Getter
@NoArgsConstructor
public class Server {
@JacksonXmlProperty(localName = "serverport")
private String serverPort;
}
我为我的配置类创建了一个包装器,例如消除 [
和 ]
的出现。
@Getter
@Setter
@AllArgsConstructor
@NoArgsConstructor
@ToString
@JacksonXmlRootElement(localName = "config")
public class ConfigWrapper {
private Config[] configurations;
}
现在我的配置类看起来像:
@NoArgsConstructor
@Getter
@AllArgsConstructor
@ToString
public class Config {
@JacksonXmlProperty(localName = "serverport")
private Server server;
@JacksonXmlProperty(localName = "client")
private Client client;
}
但这并没有解决问题,毕竟我收到了异常:
org.codehaus.jackson.map.exc.UnrecognizedPropertyException: Unrecognized field "server" (Class com.javase.advanced.config.ConfigWrapper), not marked as ignorable
at [Source: (through reference chain: com.javase.advanced.config.ConfigWrapper["server"])
如果您提出有关如何实现目标并消除此异常的建议,我将不胜感激。
最佳答案
这应该有效。您可以使用 JAXB 进行解码。请阅读有关 JAXB 的信息。另请注意 XmlElement
和 XmlAttribute
的使用方式。
String xmlString = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" +
"<config>\n" +
" <server serverport=\"9966\"/>\n" +
" <client clientport=\"9999\">\n" +
" <serverHost>localhost</serverHost>\n" +
" </client>\n" +
"</config>";
JAXBContext jaxbContext;
try
{
jaxbContext = JAXBContext.newInstance(Config.class);
Unmarshaller jaxbUnmarshaller = jaxbContext.createUnmarshaller();
Config config = (Config) jaxbUnmarshaller.unmarshal(new StringReader(xmlString));
System.out.println(config);
}catch (JAXBException e){
e.printStackTrace();
}
配置类将是这样的
@XmlRootElement(name = "config")
@XmlAccessorType(XmlAccessType.PROPERTY)
public class Config {
public Server server;
public Client client;
public Config() {
}
public Server getServer() {
return server;
}
public void setServer(Server server) {
this.server = server;
}
public Client getClient() {
return client;
}
public void setClient(Client client) {
this.client = client;
}
}
服务器类
public class Server {
@XmlAttribute(name = "serverport")
public String serverPort;
}
客户端类
public class Client {
@XmlAttribute(name = "clientport")
public String clientPort;
@XmlElement
public String serverHost;
}
关于java - 获取 MismatchedInputException : Cannot deserialize instance of Object while parsing JSON to result object,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58095608/
我知道我的问题有点含糊,但我不知道如何描述它。我问过很多地方,但似乎没有人理解我为什么要这样做。但请耐心等待,我会解释为什么我想要这样的东西。 我使用 Liquid Templates 允许用户在我的
这个问题在这里已经有了答案: what is the difference between null != object and object!=null [duplicate] (2 个回答) 7年
当我在我的本地主机 Google App Engine 应用程序中将日志记录级别更改为 FINE 时,我开始在我的跟踪堆栈中看到这些: Apr 17, 2013 4:54:20 PM com.goog
Python 有内置函数 type : class type(object) With one argument, return the type of an object. The return v
我正在使用深度学习进行语义分割,我遇到了以下术语:语义分割、实例检测、对象检测 和对象分割. 它们有什么区别? 最佳答案 这些术语的某些用法对用户而言是主观的或依赖于上下文,但据我所知对这些术语的合理
我面临 -[NSConcreteMutableData release] 的问题:消息发送到已释放的实例,我也附上了我的示例代码。 - (IBAction)uploadImage { NSString
我试图显示模型中的单个实例(数据库行),其中多个实例共享多行的相同字段(列)值。为了澄清这一说法,我有以下情况: ID/Title/Slug/Modified 1 Car A 1s ag
我正在尝试使用mockito来模拟服务。然而,我没有找到一种方法来告诉mockito,给定一个类的实例返回给我相同的实例: 类似于: given(service.add(any(Individua
我知道如何从父类(super class)原型(prototype)创建子类原型(prototype)。但是,如果我已经有了父类(super class)对象的实例来创建子类对象怎么办? 在 JS 中
鉴于 Kotlin 1.1。对于某个类的 instance,instance::class.java 和 instance.javaClass 似乎几乎是等价的: val i = 0 println(
这个问题在这里已经有了答案: 8年前关闭。 Possible Duplicate: Find out the instance id from within an ec2 machine 我正在寻找从
为什么我的 Instantiate 函数没有创建 That 的“空白”实例? 我有以下最小类: classdef That < handle properties This = '' end
Session session = HibernateUtil.getSessionFactory().openSession(); Transaction tx = session.beginTra
考虑以下几点: public class A { public String name = "i am a A instance"; } public class B extends A {
我正在使用 Scalr 来扩展网站服务器。 在 Apache 服务器上,我安装了 Sakai,并为 Linux 机器创建了一个启动脚本。 问题是,如何确保MySQL实例在Apache服务器启动之前启动
Android Realm DB 允许使用 Realm.getInstance() 获取多个实例。这些中的最佳实践是什么? :1.创建单个实例(应用程序范围)并在任何地方使用它2. 在需要时获取一个新
我很难理解为什么修改实例 a 中的属性会修改实例 b 中的相同属性。 var A = function (){ }; A.prototype.data = { value : 0 }; var
我将 Weka 用作更长管道的一部分,因此,我无法承受将所有数据写入文件或数据库只是为了创建一个 Instances。目的。我可以即时做的是创建 Instance 的列表对象。 来自 this pag
class C: def func(self, a): print(a) c = C() print(c.__dict__) # {} c.func = c.func # c.func i
Angular Routing 文档提到了组件实例创建、组件实例激活和路由激活。 文档没有解释这些概念的区别,以及每次创建/激活发生的时间。 问题 实例创建和实例激活有什么区别? 实例激活和路由激活有
我是一名优秀的程序员,十分优秀!