IllegalArgumentException:输入字节数组在 396 处的结束字节不正确xmlStreamReader CHARACTERS 事件以错误的顺序读取字符

问题描述

所以我使用 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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...