Мне удалось заставить его работать, это смесь моего решения для преодоления броска deepClone NAMESPACE_ERR и решения, представленного в ссылке .
По сути, я не смог сделать копию данного узла без ошибки, поэтому я сглаживаю XML в строку и преобразую строку в новый узел, и с помощью acceptNode у меня есть решение :)
Я понимаю, что это чертовски хакерство, но оно работает для моего сжатого срока:)
Преобразование в строку выполняется с использованием класса Transformer следующим образом:
private static final String CLASS_NAME = "SendQueryTask";
//...
import java.io.StringWriter;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.TransformerFactoryConfigurationError;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
//...
private String transformXmlToString(Node node)
{
Transformer transformer = null;
try
{
transformer = TransformerFactory.newInstance().newTransformer();
}
catch (TransformerConfigurationException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (TransformerFactoryConfigurationError e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
if ( transformer != null )
{
transformer.setOutputProperty( OutputKeys.INDENT, "yes" );
// initialize StreamResult with File object to save to file
StreamResult result = new StreamResult( new StringWriter() );
DOMSource source = new DOMSource( node );
try
{
transformer.transform( source, result );
}
catch (TransformerException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
String xmlString = result.getWriter().toString();
Log.i( CLASS_NAME, "flattened=" + (xmlString) );
return xmlString;
}
return null;
}
и преобразовать его обратно в узел
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import org.apache.http.protocol.HTTP;
import java.io.UnsupportedEncodingException;
private Node dumbNodeCopy(Node item)
{
String xmlString = transformXmlToString( item );
if ( xmlString != null )
{
InputStream is = null;
try
{
is = new ByteArrayInputStream( xmlString.getBytes( HTTP.UTF_8 ) );
}
catch (UnsupportedEncodingException e)
{
e.printStackTrace();
}
if ( is != null )
{
Document doc = null;
dbf = DocumentBuilderFactory.newInstance();
try
{
db = dbf.newDocumentBuilder();
doc = db.parse( is );
doc.getDocumentElement().normalize();
}
catch (ParserConfigurationException e)
{
e.printStackTrace();
}
catch (SAXException e)
{
e.printStackTrace();
}
catch (IOException e)
{
e.printStackTrace();
}
if ( doc != null ) return doc.getFirstChild();
}
return null;
}
return null;
и, наконец, скопировать
NodeList nodes3 = (NodeList) xpath.evaluate( _sPathOfrObj, result,
XPathConstants.NODESET );
NodeList nodes4 = (NodeList) xpath.evaluate( _sPathHotelData, details,
XPathConstants.NODESET );
minimum = Math.min( nodes3.getLength(), nodes4.getLength() );
Log.i( CLASS_NAME, "obj=" + nodes3.getLength() );
Log.i( CLASS_NAME, "hdat=" + nodes4.getLength() );
for (i = 0; i < minimum; i++)
{
try
{
Node copy = dumbNodeCopy( nodes4.item( i ) );
if ( copy != null )
{
// nodes3.item( i ).appendChild( copy );
nodes3.item( i ).appendChild(
nodes3.item( i ).getOwnerDocument().adoptNode( copy ) );
}
else
Log.e( CLASS_NAME, "Copy of nodes4#" + i + ", failed." );
}
catch (DOMException dome)
{
dome.printStackTrace();
Log.e( CLASS_NAME, dome.code + "" );
}
}
кстати.не смейтесь над кодом :-) Я знаю, что это выглядит ужасно, но мой императивный банкомат должен уложиться в сроки, и если кто-нибудь предложит аккуратное решение, я с радостью буду придерживаться:)