<DCS>
<bytes length="29235"><![CDATA[....]]></bytes>
</DCS>并具有以下代码
DCS {
bytes(length: "${docBytes.size()}",mkp.yieldUnescaped("<![CDATA[${docBytes}]]>"))
}但它会产生
<DCS>
<![CDATA[[....]]]>
<bytes length='135948'>groovy.xml.streamingmarkupsupport.StreamingMarkupWriter@32adca00</bytes>
</DCS>提前谢谢。
发布于 2012-10-17 18:44:00
您需要将您的mkp.yieldUnescaped放在一个闭包中,而不仅仅是作为bytes标记方法的第二个参数,即:
import groovy.xml.*
byte[] docBytes = 'Tim Yates'
new StreamingMarkupBuilder().bind {
DCS {
bytes( length:docBytes.length ) {
mkp.yieldUnescaped "<![CDATA[${docBytes.toList().join(' ')}]]>"
}
}
}这将生成:
<DCS><bytes length='9'><![CDATA[84 105 109 32 89 97 116 101 115]]></bytes></DCS>您可以在这里看到,我已经将每个字节编码成一个由空格分隔的字符串。如何做取决于你(我猜取决于解码字节的是什么) ;-)
https://stackoverflow.com/questions/12929060
复制相似问题