- 浏览: 1061062 次
- 性别:
- 来自: 南京
文章分类
- 全部博客 (501)
- dwr (6)
- javascript (84)
- oracle (66)
- jsp/servlet (18)
- ant (3)
- 基础知识 (12)
- EXT (10)
- My SQL (10)
- java (71)
- spring (37)
- 学习的对象 (2)
- Linux (24)
- 面试 (1)
- HTML/CSS (11)
- tomcat (11)
- 收藏夹 (2)
- Power Designer (2)
- struts.xml配置文件 (1)
- sturts2 (3)
- myeclipse (8)
- eclipse (7)
- Maven (34)
- SVN (3)
- SAP JCO (2)
- JBOSS (11)
- webservice (8)
- word (1)
- 敏捷开发 (1)
- sybase (4)
- Nexus (3)
- EhCache (3)
- log4j (3)
- Cookie (4)
- Session (4)
- CXF (7)
- AXIS (2)
- SSO (1)
- LDAP (1)
- velocity (2)
- Jquery (5)
- redis (2)
- http (4)
- dojo (1)
- Linux资源监控软件mnon的安装与运用 (1)
- notepad++ (1)
- EA (1)
- UML (1)
- JasperReports (1)
- 权限 (0)
- freemarker (4)
- Spring MVC (1)
- JMS (1)
- activeMQ (1)
- hession (3)
- 安全 (1)
- ibatis (2)
- log (1)
- nginx (1)
最新评论
-
winhbb:
我刚好遇到了一个问题(在可以依赖注入的场合有效):有两个模块A ...
解决Maven项目相互依赖/循环依赖/双向依赖的问题 -
nanjiwubing123:
<div class="quote_title ...
用XStream转换复杂XML -
zhoujianboy:
另外一个方法实现eclipse tomcat 热部署:http ...
eclipse下实现maven项目在tomcat容器热部署方法 -
long3ok:
你好 XmlOutputFormatter 请问这个类是在什么 ...
用XStream转换复杂XML -
ganbo:
总结的好,文章给力。
解决Maven项目相互依赖/循环依赖/双向依赖的问题
用XStream序列化对象,其中有Map类型的字段,结果不让人满意:
其中的key和value被序列化成:
我比较想要的结果是
<property key="region" value="非洲中东"/>
查看了XStream的文档,可以通过自定义Converter来转换,经过尝试,只需要很简单的步骤就可以完成:
然后这么使用:
序列化后的结果很漂亮:
针对标签里面直接使用值的xml,比如
<IDS>
<ID>1234534</ID>
<ID>1111111111</ID>
</IDS>
还有节点既有属性又有值的xml,比如
<INPUT>
<RAW_SQL TYPE="PERSON">select id from person</RAW_SQL>
</INPUT>
需要一个转换器来转换,转换器代码如下:
类的annotation配置如下:
后记:(2012-05-18日添加)
如果对象中定义的类型与实际类型不一致,比如定义的是Object类型,但是实际初始化的对象是其他类型,转换出来的xml文件都会加上class="实际类型"属性,举例:<PERSON class="PERSON">...</PERSON>
有两种方法去掉这个属性
我选择用后面一种,这样会把所有class属性去掉,如果只去掉某些类的这个多余的属性,用第一种方式即可。
对的,XmlOutputFormatter 是什么鬼?
1.<ExtractResult> 2. <dataRecords> 3. <DataRecord> 4. <properties> 5. <property> 6. <string>region</string> 7. <string>非洲中东</string> 8. </property> 9. <property> 10. <string>routeReference</string> 11. <string>首都机场集合,搭乘土耳其航空直飞伊斯坦布尔,夜宿机上。</string> 12. </property> 13. <property> 14. <string>routeDays</string> 15. <string>10</string> 16. </property> 17. <property> 18. <string>price</string> 19. <string>¥13500起</string> 20. </property> 21. <property> 22. <string>subject</string> 23. <string>常规</string> 24. </property> 25. <property> 26. <string>dayOfBookingExpired</string> 27. <string>2010-02-01</string> 28. </property> 29. <property> 30. <string>departure</string> 31. <string>北京</string> 32. </property> 33. <property> 34. <string>dayOfDeparture</string> 35. <string>2010-02-10</string> 36. </property> 37. <property> 38. <string>title</string> 39. <string>[团队游]埃及土耳其10日千年文明之旅(春节)</string> 40. </property> 41. </properties> 42. </DataRecord> 43. </dataRecords> 44.</ExtractResult>
其中的key和value被序列化成:
1.<string>region</string> 2.<string>非洲中东</string>
我比较想要的结果是
<property key="region" value="非洲中东"/>
查看了XStream的文档,可以通过自定义Converter来转换,经过尝试,只需要很简单的步骤就可以完成:
1.import java.util.HashMap; 2.import java.util.Hashtable; 3.import java.util.Iterator; 4.import java.util.Map; 5.import java.util.Map.Entry; 6. 7.import com.thoughtworks.xstream.converters.MarshallingContext; 8.import com.thoughtworks.xstream.converters.UnmarshallingContext; 9.import com.thoughtworks.xstream.converters.collections.AbstractCollectionConverter; 10.import com.thoughtworks.xstream.io.ExtendedHierarchicalStreamWriterHelper; 11.import com.thoughtworks.xstream.io.HierarchicalStreamReader; 12.import com.thoughtworks.xstream.io.HierarchicalStreamWriter; 13.import com.thoughtworks.xstream.mapper.Mapper; 14. 15./** 16. * @author fuliang 17. * 18. */ 19.public class MapCustomConverter extends AbstractCollectionConverter { 20. 21. /** 22. * @param mapper 23. */ 24. public MapCustomConverter(Mapper mapper) { 25. super(mapper); 26. } 27. 28. public boolean canConvert(Class type) { 29. return type.equals(HashMap.class) 30. || type.equals(Hashtable.class) 31. || type.getName().equals("java.util.LinkedHashMap") 32. || type.getName().equals("sun.font.AttributeMap") // Used by java.awt.Font in JDK 6 33. ; 34. } 35. 36. public void marshal(Object source, HierarchicalStreamWriter writer, MarshallingContext context) { 37. Map map = (Map) source; 38. for (Iterator iterator = map.entrySet().iterator(); iterator.hasNext();) { 39. Entry entry = (Entry) iterator.next(); 40. ExtendedHierarchicalStreamWriterHelper.startNode(writer, "property", Entry.class); 41. 42. writer.addAttribute("key", entry.getKey().toString()); 43. writer.addAttribute("value", entry.getValue().toString()); 44. writer.endNode(); 45. } 46. } 47. 48. public Object unmarshal(HierarchicalStreamReader reader, UnmarshallingContext context) { 49. Map map = (Map) createCollection(context.getRequiredType()); 50. populateMap(reader, context, map); 51. return map; 52. } 53. 54. protected void populateMap(HierarchicalStreamReader reader, UnmarshallingContext context, Map map) { 55. while (reader.hasMoreChildren()) { 56. reader.moveDown(); 57. Object key = reader.getAttribute("key"); 58. Object value = reader.getAttribute("value"); 59. map.put(key, value); 60. reader.moveUp(); 61. } 62. } 63.}
然后这么使用:
1.XStream xStream = new XStream(); 2.xStream.registerConverter(new MapCustomConverter(new DefaultMapper(XmlOutputFormatter.class.getClassLoader()))); 3.xStream.alias("DataRecord", ExtractDataRecord.class); 4.xStream.alias("ExtractResult", ExtractResult.class); 5.xStream.alias("property", Entry.class); 6.return xStream.toXML(extractResult);
序列化后的结果很漂亮:
1.<ExtractResult> 2. <dataRecords> 3. <DataRecord> 4. <properties> 5. <property key="region" value="港澳"/> 6. <property key="routeReference" value="搭乘国际航班直飞桃园国际机场,办理相关手续后,前往用晚餐。前往酒店入住休息。"/> 7. <property key="routeDays" value="8"/> 8. <property key="price" value="¥5680起"/> 9. <property key="subject" value="常规"/> 10. <property key="dayOfBookingExpired" value="2010-01-15"/> 11. <property key="departure" value="北京"/> 12. <property key="dayOfDeparture" value="2010-01-25"/> 13. <property key="title" value="[团队游]台湾8日宝岛乡情之旅"/> 14. </properties> 15. </DataRecord> 16. </dataRecords> 17.</ExtractResult>
针对标签里面直接使用值的xml,比如
<IDS>
<ID>1234534</ID>
<ID>1111111111</ID>
</IDS>
还有节点既有属性又有值的xml,比如
<INPUT>
<RAW_SQL TYPE="PERSON">select id from person</RAW_SQL>
</INPUT>
需要一个转换器来转换,转换器代码如下:
import com.thoughtworks.xstream.converters.Converter; import com.thoughtworks.xstream.converters.MarshallingContext; import com.thoughtworks.xstream.converters.UnmarshallingContext; import com.thoughtworks.xstream.io.HierarchicalStreamReader; import com.thoughtworks.xstream.io.HierarchicalStreamWriter; import com.zhhy.server.beans.RawSQL; public class RawSQLConverter implements Converter { @SuppressWarnings("rawtypes") public boolean canConvert(Class clazz) { return clazz.equals(RawSQL.class); } public void marshal(Object value, HierarchicalStreamWriter writer, MarshallingContext acontext) { RawSQL rawSQL = (RawSQL) value; if (rawSQL != null) { if (null != rawSQL.getType()) { writer.addAttribute("TYPE", rawSQL.getType()); } writer.setValue(rawSQL.getRawSql() == null ? "" : rawSQL.getRawSql()); } } public Object unmarshal(HierarchicalStreamReader reader, UnmarshallingContext arg1) { RawSQL rawSql = new RawSQL(); String type = reader.getAttribute("TYPE"); rawSql.setType(type); String value = reader.getValue(); rawSql.setRawSql(value); return rawSql; } }
类的annotation配置如下:
@XStreamAlias("RAW_SQL") @XStreamConverter(RawSQLConverter.class) public class RawSQL { @XStreamAsAttribute @XStreamAlias("TYPE") private String type; private String rawSql; 下面省略了getter和setter方法 }
后记:(2012-05-18日添加)
如果对象中定义的类型与实际类型不一致,比如定义的是Object类型,但是实际初始化的对象是其他类型,转换出来的xml文件都会加上class="实际类型"属性,举例:<PERSON class="PERSON">...</PERSON>
有两种方法去掉这个属性
1, xstream.alias("field name", Interface.class, ActualClassToUse.class); 2, xstream.aliasSystemAttribute(null, "class");
我选择用后面一种,这样会把所有class属性去掉,如果只去掉某些类的这个多余的属性,用第一种方式即可。
评论
2 楼
nanjiwubing123
2017-10-18
long3ok 写道
你好 XmlOutputFormatter 请问这个类是在什么包里面的?
对的,XmlOutputFormatter 是什么鬼?
1 楼
long3ok
2016-12-06
你好 XmlOutputFormatter 请问这个类是在什么包里面的?
发表评论
-
个人草稿使用
2017-08-19 09:02 0深入理解JVM: http://www.cnblogs.co ... -
Thread.setDaemon详解
2015-04-24 21:31 898java中线程分为两种类型:用户线程和守护线程。通过Threa ... -
怎么使用 ConcurrentHashMap 才能是线程安全的?
2015-04-13 11:54 1501public class test { public ... -
21,tomcat关闭钩子
2014-12-31 10:36 724在很多环境下,在关闭应用程序的时候需要做一些清理工作。问题在于 ... -
Java NIO使用及原理分析 (一) 【转载】
2014-10-24 00:04 484【转载】: http://blog.csdn.net/wuxi ... -
Java 两个集合取交集
2014-10-14 21:16 3122public static Set intersectionS ... -
Calendar类roll和add的区别
2014-10-10 22:28 489import java.text.SimpleDateForm ... -
Gson通过借助TypeToken获取泛型参数的类型的方法
2014-09-30 00:26 626[size=medium]最近在使用Goo ... -
HashMap的遍历效率讨论
2014-09-27 20:41 826经常遇到对HashMap中的key和value值对的遍历操作, ... -
Java 泛型
2014-06-26 12:44 852关键字说明 ? 通配符类型 <? extends T&g ... -
Java泛型集合的理解
2014-06-26 00:05 502[size=medium]什么是泛型? 泛型(Generic ... -
关于java字节码框架ASM的学习
2014-06-19 19:22 883一、什么是ASM ASM是一个java字节码操纵框架, ... -
Java动态代理详解
2014-06-19 17:41 857Java动态代理详解: http: ... -
Java内存,字符串文章收集
2014-06-18 16:24 714java--String常量池问题的几个例子 . http:/ ... -
Java内存解析
2014-06-18 11:48 773栈、堆、常量池等虽同 ... -
Java的堆与非堆内存
2014-01-07 10:59 713堆(Heap)和非堆(Non-heap)内存 按照官方的说法: ... -
JMX 资料收集
2014-01-07 10:53 448JavaSky的专栏 http://blog.csdn.net ... -
JAVA 注解示例 详解
2013-11-12 09:36 820注解(Annotation) 为我们在代码中天界信息提供了 ... -
Java 泛型详解
2013-11-11 22:35 796http://www.360doc.com/content/1 ... -
Java中的Enum的使用与分析
2013-11-09 12:49 814enum枚举类型:在实际问 ...
相关推荐
现在,我们可以使用XStream进行对象到XML的转换。首先,创建一个XStream实例,并对其进行配置: ```java XStream xstream = new XStream(); xstream.alias("person", Person.class); // 给类名设置别名,可读性更高...
- 对于复杂的XML结构,XStream的类型别名和数据转换功能能简化代码。 7. **总结** XML解析和JavaBean与XML之间的转换是Java开发中的常见任务。了解不同的解析方法,以及如何使用XStream,将有助于提升开发效率和...
**使用XStream进行Bean到XML转换的步骤:** 1. **引入库**:首先,你需要在项目中引入XStream库,这可以通过添加对应的jar文件(如xstream-1.3.1.jar)或者在Maven或Gradle等构建工具中配置依赖完成。 2. **创建...
xStream支持自定义类型转换器,可以处理自定义类型或者复杂的数据结构。 2. **安全模式** 对于生产环境,启用安全模式可以防止XSS攻击,限制xStream对未知类的序列化和反序列化。 3. **XML布局控制** 通过配置,...
首先创建XStream实例,然后使用`toXML()`方法将Java对象转换为XML字符串: ```java XStream xstream = new XStream(); User user = new User(); user.setName("Forest"); user.setAge(30); String xml = xstream.to...
XStream还提供了许多高级功能,比如自定义转换器来改变默认的XML表示,或者处理复杂的继承关系。此外,为了提高安全性,XStream提供了一种叫做"alias"的机制,可以将类名映射为更友好的XML标签。 总的来说,XStream...
4. **对象到XML**:使用`xstream.toXML(object)`方法将Java对象转换为XML字符串。 5. **XML到对象**:通过`xstream.fromXML(xmlString)`将XML字符串反序列化为Java对象。 6. **JSON转换**:如果需要转换为JSON,...
以下是一个简单的示例,演示如何使用XStream进行XML与Java对象的转换: ```java import com.thoughtworks.xstream.XStream; class User { private String name; private int age; // getters and setters ...
这篇博客“使用XStream是实现XML与Java对象的转换(6)--持久化”深入探讨了如何利用XStream进行持久化操作,使得对象状态能够持久保存到磁盘,同时也能够从XML文档中恢复。 首先,我们需要理解XStream的核心概念。...
在进行XML到JSON的转换时,xStream使用了JSONPath的概念,这是一种类似于XPath的语言,用于在JSON文档中查找和操作数据。通过内部的转换机制,xStream可以将XML的树状结构转换为JSON的键值对形式。例如,上述XML示例...
《xStream完美转换XML、JSON》学习笔记 在IT领域,数据交换是常见的需求,而XML和JSON作为两种广泛使用的数据格式,它们之间的转换尤为重要。xStream是一个强大的Java库,它能够轻松地将Java对象序列化为XML或反...
这就是XStream转换器的作用。 转换器分为两种类型:LocalConverter和HierarchicalStreamConverter。LocalConverter仅对特定的域对象实例进行转换,而HierarchicalStreamConverter则可以处理整个XML层级结构。 1. *...
在`beanToXml()` 方法中,同样需要初始化xStream实例,然后使用`toXML()` 方法将Bean对象转换为XML字符串: ```java public String beanToXml(YourBeanClass bean) { XStream xstream = new XStream(new DomDriver...
**XStream:JavaBean与XML/JSON之间的转换大师** XStream是一个开源库,它为Java对象提供了简单且直观的XML序列化和反序列化的解决方案。它不仅能够将Java对象转换成XML,反之亦然,还能支持JSON格式的转换。这个...
**XStream XML解析** ...总之,XStream 提供了一种高效且直观的 Java 对象与 XML 之间的转换方法,尤其适用于那些需要频繁进行对象序列化的项目。理解和掌握 XStream 的使用,可以极大地提升开发效率并简化代码维护。
在这个场景中,我们将探讨如何使用XStream将XML文档转换成Java对象,进而转化为JSON对象。 首先,我们需要引入XStream库。XStream的核心功能是能够将Java对象和XML之间的映射自动化,极大地简化了序列化和反序列化...
本篇文章将深入探讨如何使用XStream进行XML到对象的转换,并提供一个实际的案例。 首先,理解XStream的基本工作原理是至关重要的。XStream通过映射XML节点到Java类的字段来实现对象的序列化和反序列化。这意味着你...
以下是一个简单的示例,展示了如何使用XStream进行Java对象到XML的转换以及反向转换: ```java package test; import com.thoughtworks.xstream.XStream; import ...
【标题】:“xStream 实现xml与 java对象的转换” 在Java开发中,XML作为一种常见的数据交换格式,常用于存储和传输数据。然而,XML与Java对象之间的转换并不总是直观和简便的。这时,xStream库应运而生,它提供了...
如果需要自定义XML的输出,例如改变元素名或者添加额外的转换规则,可以使用`xstream.alias()`和`xstream.asAttribute()`等方法。 反序列化则是将XML字符串恢复为Java对象的过程。同样以User类为例: ```java User...