- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
来自 http://weblogs.java.net/blog/2005/04/22/xmladapter-jaxb-ri-ea
import java.io.StringReader;
import java.io.StringWriter;
import java.util.HashMap;
import java.util.Map;
import javax.xml.bind.JAXBContext;
import javax.xml.bind.Marshaller;
import javax.xml.bind.Unmarshaller;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.adapters.XmlAdapter;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
public class BrochureOriginal {
@XmlRootElement(name = "brochure")
static class Brochure {
@XmlJavaTypeAdapter(CourseListAdapter.class)
@XmlElement(name = "courses")
Map<String, Course> coursesByIdMap;
}
static class Course {
@XmlAttribute
String id;
@XmlElement
String name;
}
static class CourseListAdapter extends XmlAdapter<Course[], Map<String, Course>> {
public Course[] marshal(Map<String, Course> value) {
return value.values().toArray(new Course[value.size()]);
}
public Map<String, Course> unmarshal(Course[] value) {
Map<String, Course> r = new HashMap<String, Course>();
for (Course c : value)
r.put(c.id, c);
return r;
}
}
private static <T> String convertObjectToXml(Class<T> clazz, T instance) {
try {
JAXBContext jc = JAXBContext.newInstance(clazz);
Marshaller m = jc.createMarshaller();
m.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
StringWriter sw = new StringWriter();
m.marshal(instance, sw);
return sw.toString();
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
@SuppressWarnings("unchecked")
private static <T> T convertXmlToObject(Class<T> clazz, String xml) {
try {
JAXBContext jc = JAXBContext.newInstance(clazz);
Unmarshaller m = jc.createUnmarshaller();
StringReader sr = new StringReader(xml);
T instance = (T) m.unmarshal(sr);
return instance;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
public static void main(String[] args) {
Brochure b = new Brochure();
Course c = null;
// 1st course
c = new Course();
c.id = "cs501";
c.name = "Software Engineering";
b.coursesByIdMap = new HashMap<String, Course>();
b.coursesByIdMap.put(c.id, c);
// 2nd course
c = new Course();
c.id = "cs519";
c.name = "Network Security";
b.coursesByIdMap.put(c.id, c);
Brochure source = b;
String sourceDisplay = getDisplay(source);
String xml = convertObjectToXml(Brochure.class, b);
System.out.println(sourceDisplay);
System.out.println(xml);
Brochure restored = convertXmlToObject(Brochure.class, xml);
String restoredDisplay = getDisplay(restored);
System.out.println(restoredDisplay);
}
private static String getDisplay(Brochure b) {
String nl = System.getProperty("line.separator");
StringBuilder sb = new StringBuilder();
sb.append(nl + "Brochure");
for (Map.Entry<String, Course> entry : b.coursesByIdMap.entrySet()) {
Course course = entry.getValue();
sb.append(nl + " coursesByIdMap.entry");
sb.append(nl + " key: String(" + entry.getKey() + ")");
sb.append(nl + " value: Course(id=" + course.id + ", name=" + course.name + ")");
}
return sb.toString();
}
}
这是输出...
Brochure
coursesByIdMap.entry
key: String(cs519)
value: Course(id=cs519, name=Network Security)
coursesByIdMap.entry
key: String(cs501)
value: Course(id=cs501, name=Software Engineering)
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<brochure>
<courses>
<item id="cs519">
<name>Network Security</name>
</item>
<item id="cs501">
<name>Software Engineering</name>
</item>
</courses>
</brochure>
Brochure
coursesByIdMap.entry
key: String(cs519)
value: Course(id=cs519, name=Network Security)
coursesByIdMap.entry
key: String(cs501)
value: Course(id=cs501, name=Software Engineering)
我想要的是……
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<brochure>
<courses>
<course id="cs519">
<name>Network Security</name>
</course>
<course id="cs501">
<name>Software Engineering</name>
</course>
</courses>
</brochure>
我似乎找不到摆脱那个“item”元素名称的方法。
根据答案的资源,这里有一种方法可以用拐杖对象来完成。
import java.io.StringReader;
import java.io.StringWriter;
import java.util.HashMap;
import java.util.Map;
import javax.xml.bind.JAXBContext;
import javax.xml.bind.Marshaller;
import javax.xml.bind.Unmarshaller;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.adapters.XmlAdapter;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
public class BrochureTest {
@XmlRootElement(name = "brochure")
static class Brochure {
@XmlJavaTypeAdapter(CourseListAdapter.class)
@XmlElement(name = "courses")
Map<String, Course> coursesByIdMap;
}
static class Course {
@XmlAttribute
String id;
@XmlElement
String name;
}
static class CourseListAdapter extends XmlAdapter<CoursesJaxbCrutch, Map<String, Course>> {
public CoursesJaxbCrutch marshal(Map<String, Course> value) {
CoursesJaxbCrutch courses = new CoursesJaxbCrutch();
courses.courses = value.values().toArray(new Course[value.size()]);
return courses;
}
public Map<String, Course> unmarshal(CoursesJaxbCrutch value) {
Map<String, Course> r = new HashMap<String, Course>();
for (Course c : value.courses)
r.put(c.id, c);
return r;
}
}
private static class CoursesJaxbCrutch {
@XmlElement(name = "course")
private Course[] courses;
}
private static <T> String convertObjectToXml(Class<T> clazz, T instance) {
try {
JAXBContext jc = JAXBContext.newInstance(clazz);
Marshaller m = jc.createMarshaller();
m.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
StringWriter sw = new StringWriter();
m.marshal(instance, sw);
return sw.toString();
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
@SuppressWarnings("unchecked")
private static <T> T convertXmlToObject(Class<T> clazz, String xml) {
try {
JAXBContext jc = JAXBContext.newInstance(clazz);
Unmarshaller m = jc.createUnmarshaller();
StringReader sr = new StringReader(xml);
T instance = (T) m.unmarshal(sr);
return instance;
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
public static void main(String[] args) {
Brochure b = new Brochure();
Course c = null;
// 1st course
c = new Course();
c.id = "cs501";
c.name = "Software Engineering";
b.coursesByIdMap = new HashMap<String, Course>();
b.coursesByIdMap.put(c.id, c);
// 2nd course
c = new Course();
c.id = "cs519";
c.name = "Network Security";
b.coursesByIdMap.put(c.id, c);
Brochure source = b;
String sourceDisplay = getDisplay(source);
String xml = convertObjectToXml(Brochure.class, b);
System.out.println(sourceDisplay);
System.out.println(xml);
Brochure restored = convertXmlToObject(Brochure.class, xml);
String restoredDisplay = getDisplay(restored);
System.out.println(restoredDisplay);
}
private static String getDisplay(Brochure b) {
String nl = System.getProperty("line.separator");
StringBuilder sb = new StringBuilder();
sb.append(nl + "Brochure");
for (Map.Entry<String, Course> entry : b.coursesByIdMap.entrySet()) {
Course course = entry.getValue();
sb.append(nl + " coursesByIdMap.entry");
sb.append(nl + " key: String(" + entry.getKey() + ")");
sb.append(nl + " value: Course(id=" + course.id + ", name=" + course.name + ")");
}
return sb.toString();
}
}
输出是:
Brochure
coursesByIdMap.entry
key: String(cs519)
value: Course(id=cs519, name=Network Security)
coursesByIdMap.entry
key: String(cs501)
value: Course(id=cs501, name=Software Engineering)
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<brochure>
<courses>
<course id="cs519">
<name>Network Security</name>
</course>
<course id="cs501">
<name>Software Engineering</name>
</course>
</courses>
</brochure>
Brochure
coursesByIdMap.entry
key: String(cs519)
value: Course(id=cs519, name=Network Security)
coursesByIdMap.entry
key: String(cs501)
value: Course(id=cs501, name=Software Engineering)
那么现在没有拐杖怎么办呢?
最佳答案
您链接中的示例不起作用 - 这里有两个链接讨论了如何获得您正在寻找的结果:
http://old.nabble.com/XmlJavaTypeAdapter-help-td19127284.html
http://forums.java.net/jive/message.jspa?messageID=267376
请注意,您的 main()
方法存在一个小问题,我已突出显示修复方法:
public static void main(String[] args) {
Brochure b = new Brochure();
Course c = new Course();
c.id = "cs501";
c.name = "Software Engineering";
b.courses = new HashMap<String, Course>();
b.courses.put(c.id, c);
c = new Course() // You need to add this
c.id = "cs519";
c.name = "Network Security";
b.courses.put(c.id, c);
System.out.println(convertObjectToXml(Brochure.class, b));
}
关于java - 在 JAXB 中将 XmlJavaTypeAdapter 用于 java.util.Map 时如何摆脱项目元素名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2338847/
我在这个网站上发布的代码有这个问题 https://developers.google.com/drive/quickstart-cs是 Google Drive 快速入门的开发人员站点。我按照网站上
我正在尝试制作一个非常简单的 Kafka Producer,目前正在关注 producer example除了我的制作人没有分区程序类。 将所需文件导出到 jar 后,我将它们传输到我的 Linux
问题 在java中,我有一个“Util项目”,在进行单元测试时使用另一个“Mock项目”。 我的问题是“模拟项目”也使用“Util项目”来构建一些模拟对象。 当我使用 Maven 构建项目时,我无法构
据我所知,这些包已经存在很长时间了。但是,我从未见过它们的实际用法。而且这些包似乎不成熟,不再维护。如果是,为什么这些包现在存在? 最佳答案 包裹automata被 scala.xml.dtd 使用,
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question Co
在java.util.Collections中,有一个方法: public static void fill(List list, T obj) 用第二个参数指定的对象填充第一个参数指定的List。
我不明白它要我做什么。分配给 sentence正在工作: val sentences : java.util.List[CoreMap] = document.get(classOf[Sentence
在我的 React 应用程序中,我想使用一些实用程序。我见过两种不同的方法。第一个是,只是创建函数并将其导出。第二个是,创建一个 Util 类并导出一个对象,这样它就不能被实例化(静态类)。 clas
我有一个 util 类,它接受 String jwtToken 和 Key key 并使用 io.jsonwebtoken.jwts 解码 jwt。 但是,我无法对此进行测试。原因是,我无法模拟公钥并
我有使用目标命名空间的专有架构 xmlns:ax216="http://util.java/xsd" 这给我带来了从 java (java.util.xsd) 开始生成禁止的(由 Java 安全管理器
我正在阅读集合以查看 Javadocs 中的实现层次结构。 Collections声明为public class Collections extendds Object Collection声明为pu
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我在使用格式说明符时遇到问题。这是否意味着我正在使用 %d? public static void main(String[] args) { double y, x; for (x =
鉴于此代码 import java.util.Iterator; private static List someList = new ArrayList(); public static void
我正在 HackerEarth 解决问题,我无法弄清楚为什么我的程序在命令行上正确运行并给出正确的结果,但在代码编辑器上运行时却给出 java.util.NoSuchElementException
我正在尝试使用以下代码使用对象列表列表中的数据填充tableModel readExcel.readSheet(0): TableModel tableModel = new DefaultTabl
java.util.Set 、 java.util.List 和其他 Collection 接口(interface)不可序列化。需要一个简单、直接的解决方案来在可序列化的 POJO 中使用它。 pu
我试图从 servlet 返回数据库搜索结果的 ArrayList 以显示在 jsp 页面上。 在servlet中设置arraylist作为请求的属性,并将请求转发到jsp页面。当我尝试在 jsp 页
我是android新手,最近我试图从firebase中提取数据到recyclerview/cardview中以垂直布局显示数据,它显示将Hashmap转换为Arraylist的错误,其中代码是:
我是一名优秀的程序员,十分优秀!