首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用StreamingMarkupBuilder在标记内生成CDATA

使用StreamingMarkupBuilder在标记内生成CDATA
EN

Stack Overflow用户
提问于 2012-10-17 15:16:41
回答 1查看 2.4K关注 0票数 3
代码语言:javascript
复制
<DCS>
    <bytes length="29235"><![CDATA[....]]></bytes>
</DCS>

并具有以下代码

代码语言:javascript
复制
DCS {
bytes(length: "${docBytes.size()}",mkp.yieldUnescaped("<![CDATA[${docBytes}]]>"))
}

但它会产生

代码语言:javascript
复制
   <DCS>
    <![CDATA[[....]]]>
<bytes length='135948'>groovy.xml.streamingmarkupsupport.StreamingMarkupWriter@32adca00</bytes>
    </DCS>

提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-10-17 18:44:00

您需要将您的mkp.yieldUnescaped放在一个闭包中,而不仅仅是作为bytes标记方法的第二个参数,即:

代码语言:javascript
复制
import groovy.xml.*

byte[] docBytes = 'Tim Yates'

new StreamingMarkupBuilder().bind {
  DCS {
    bytes( length:docBytes.length ) {
      mkp.yieldUnescaped "<![CDATA[${docBytes.toList().join(' ')}]]>"
    }
  }
}

这将生成:

代码语言:javascript
复制
<DCS><bytes length='9'><![CDATA[84 105 109 32 89 97 116 101 115]]></bytes></DCS>

您可以在这里看到,我已经将每个字节编码成一个由空格分隔的字符串。如何做取决于你(我猜取决于解码字节的是什么) ;-)

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12929060

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档