问题描述
所以我使用 XMLStreamReader
来解析包含 <Data>....</Data>
标记之间的 Base64 编码数据的 xml 文档,我必须逐行提取和解码。我为 XMLInputFactory
设置了以下属性:xmlInputFactory.setProperty("javax.xml.stream.isCoalescing",true)
以便 <Data>....</Data>
标记中的所有 Base64 编码文本都在一个 CHaraCTER
事件中累积。但是,当我将数据提取到大小为 1024 字节的 char
缓冲区时,字符的顺序被打乱了。而且因为订单被打乱了,我无法解码它。下面是我的代码:
XMLInputFactory xmlInputFactory = XMLInputFactory.newInstance();
xmlInputFactory.setProperty("javax.xml.stream.isCoalescing",true);
FileInputStream inputStream = new FileInputStream(tmpFile);
XMLStreamReader xmlStreamReader = xmlInputFactory.createXMLStreamReader(inputStream);
while(xmlStreamReader.hasNext()){
if(xmlStreamReader.isstartElement() && xmlStreamReader().getName().getLocalPart().equals("Data"))
{
xmlStreamReader.next() // get Character event
int length = 1024;
char[] buffer = new char[1024];
int sourceStart = 0;
FileOutputStream out = new FileOutputStream(targetFile);
for(sourceStart=0;;sourceStart+=length){
int numcopied = xmlStreamReader.getTextCharacters(sourceStart,buffer,length);
out.write(Base64.getMimeDecoder().decode(new String(buffer).getBytes()));
if(numcopied < length){
break;
}
}
}
}
<Data>....</Data>
标签之间总共有 23944 个字符。同样,当异常发生时,sourceStart
位于 23552 并且第 396 个字节有错误。还有当
sourceStart
在 23552 处, numcopied
的值为 1024 这显然是不正确的,因为我应该只有 23944 个字符,因此 if(numcopied < length)
永远不会变为真。知道为什么会这样吗?此外,要解码的数据是机密的,所以我可能无法共享它。对不起!
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)