XStream中设置编码、忽略没有关联属性和支持CDATA

本文介绍XStream的高级用法,包括设置编码、忽略无关属性、使用常见注解、支持CDATA块及安全警告处理。通过实例展示了如何避免转换错误、增强数据安全性并优化XML与对象间的转换。

一、设置编码

XStream中可以设置转换后的编码格式;

XStream xStream = new XStream(new DomDriver("GBK"));

二、忽略没有关联的属性

“no such field”类似于这样的错误。
问题分析
我们在使用XStream对象时,一般都会直接new一个对象出来,例如

XStream xstream = new XStream();
1
这样使用之后,xml中的所有属性都需要被待转化的模型识别,假如有一个字段没有对应上,即会抛出错误。
问题解决方案
XStream 官方也提供这样一种构造方法。

XStream xstream = new XStream() {
    @Override
    protected MapperWrapper wrapMapper(MapperWrapper next) {
        return new MapperWrapper(next) {
            @Override
            public boolean shouldSerializeMember(Class definedIn, String fieldName) {
                if (definedIn == Object.class) {
                    return false;
                }
                return super.shouldSerializeMember(definedIn, fieldName);
            }
        };
    }
};
xstream.processAnnotations(XXX.class);

三、常用的注解

1)注解 @XStreamAlias(“ProdCount”) 可以为普通的字段进行别名设置
2)注解 @XStreamImplicit(itemFieldName=“Product”) 可以对list集合进行别名设置
3)注解 @XStreamConverter(value = XmlDateConverter.class) 日期转化器
4)注解 @XStreamOmitField 忽略某个字段

四、xml转换为对象时,使其支持CDATA块

/**
 * 对象到xml的处理
 * 扩展xstream,使其支持CDATA块
 */
	private XStream xstream = new XStream(new XppDriver() {
	    public HierarchicalStreamWriter createWriter(Writer out) {
	            return new PrettyPrintWriter(out) {
	                // 对所有xml节点的转换都增加CDATA标记
	                boolean cdata = true;
	 
	                @SuppressWarnings("rawtypes")
	                public void startNode(String name, Class clazz) {
	                    super.startNode(name, clazz);
	                }
	 
	                protected void writeText(QuickWriter writer, String text) {
	                    if (cdata) {
	                        writer.write("<![CDATA[");
	                        writer.write(text);
	                        writer.write("]]>");
	                    } else {
	                        writer.write(text);
	                    }
	                }
	            };
	        }
	    });

五、xstream出现安全警告
在debug运行的时候,发现一个警告:Security framework of XStream not initialized, XStream is probably vulnerable

意思是:xstream 的安全框架没有初始化,xstream 容易受攻击。

解决方法:xStream对象设置默认安全防护,同时设置允许的类

XStream xStream = newXStream();
XStream.setupDefaultSecurity(xStream);
xStream.allowTypes(new Class[]{Test.class, Test1.class});
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

喵喵@香菜

感谢观众老爷送的一发火箭!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值