Java xmlエラーjavax.xml.transform.TransformerException:java.lang.Null PointerException
11535 ワード
Java xmlエラーjavax.xml.transform.TransformerException:java.lang.Null PointerException解決策:
Javaを利用してXMLを操作し、XMLを操作する過程で最後のステップまで実行し、Transformerを利用してXML変換を行う時にNull PointerExceptionエラーが発生し、問題の部分コードは以下の通りである.
transform関数を実行中に次のエラーが発生しました(比較的長いですが、SWINGを使用してグラフィックインタフェースを設計しているので、グラフィックインタフェースイベント呼び出しのエラーがいくつかあります).
最初は私も不思議に思っていましたが、transform関数はメモリにあるXMLツリーをファイルに変換するだけで、なぜnullPointerエラーが発生したのでしょうか.インターネットで調べてみると、誰も答えを見つけられず、最後に(http://blog.awe.cz/post/english/beware-of-null-text-nodes/)というブログでかなり役に立つ答えを見つけました.
実はエラーの情報をよく見てみると、重要な情報があります.
ここから分かるのは、com.sun.org.apache.xml.internal.serializer.ToUnknownStream.javaファイルのcharacters関数でエラーが発生しました.行数は317です.jdkインストールディレクトリに行き、srcを見つけ、対応するフォルダserializerにToUnknownStream.javaを見つけ、次の関数を見つけます.
明らかに、int length=chars.length()に注意してください.パラメータcharsがnullの場合、length関数を呼び出すとnullpoiterExceptionエラーが発生します.さらに、com.sun.org.apache.xalan.internal.xsltc.traxの下にあるDOM 2 TO.javaファイルのparse関数(240行):
ここではcharacters関数にnullパラメータがなぜ現れるのかを知ることができます.なぜなら、このノードがテキストノードTEXT_であるからです.NODEは、本ノードにコンテンツ(null)がないことを呼び出し、getNodeValueを呼び出すとnullを返す.
transform関数に上昇すると、ノードの内容がnullとなります.DOMSourceクラスでは、メモリに構築されたXMLツリーであるため、このXMLツリーの1つ以上の要素またはノードの内容がnullであるに違いありません.
OK、問題の原因が見つかりました.解決策は簡単で、DOMSourceには要素やノードがnullで、それはXMLを操作するとき、あるいは内容を修正したり、要素を追加したりして、内容をnullに変えます.したがって、エレメントの内容を変更または追加するコードを見つけてnullが発生する可能性がある場合を処理し、nullが検出された場合はXMLを変更しないか、追加しない必要があります.最も簡単な方法はif文を使うことです.すなわち、setNodeValue(String str)またはsetTextContent(String str)の前に、パラメータstrが空であるかどうかを確認し(if(str==null)、空である場合はこの関数を呼び出さない.
私のプログラムでは、確かに空の内容を要素に追加しています.コードは次のとおりです.deviceAndeIDMapはHashMapで、getを呼び出すとこのプライマリ・キーが存在しない場合nullが返されます.
したがってif文を追加すると、問題を解決できます.コード(このコードはforループにあるので、coninueで今回の変更をスキップします)は次のようになります.
問題解決!
読書に感謝して、みんなを助けることができることを望んで、みんなの当駅に対する支持に感謝します!
Javaを利用してXMLを操作し、XMLを操作する過程で最後のステップまで実行し、Transformerを利用してXML変換を行う時にNull PointerExceptionエラーが発生し、問題の部分コードは以下の通りである.
//
TransformerFactory tFactory =TransformerFactory.newInstance();
Transformer transformer = tFactory.newTransformer();
// XML
DOMSource source = new DOMSource(xmlDoc1);
// xml
File xmlDoc2 = new File(outPutPath+generateXmlFileName);
StreamResult result = new StreamResult(xmlDoc2);
//
transformer.transform(source, result);
transform関数を実行中に次のエラーが発生しました(比較的長いですが、SWINGを使用してグラフィックインタフェースを設計しているので、グラフィックインタフェースイベント呼び出しのエラーがいくつかあります).
javax.xml.transform.TransformerException: java.lang.NullPointerException
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transfor
m(TransformerImpl.java:717)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transfor
m(TransformerImpl.java:313)
at operation.AddNeuronID.addNeuronId(AddNeuronID.java:273)
at operationUI.AddNeuronIDListener.constructor2Perform(AddNeuronIDListen
er.java:245)
at operationUI.AddNeuronIDListener.actionPerformed(AddNeuronIDListener.j
ava:85)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:19
95)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.jav
a:2318)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel
.java:387)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242
)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonL
istener.java:236)
at java.awt.Component.processMouseEvent(Component.java:6041)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3265)
at java.awt.Component.processEvent(Component.java:5806)
at java.awt.Container.processEvent(Container.java:2058)
at java.awt.Component.dispatchEventImpl(Component.java:4413)
at java.awt.Container.dispatchEventImpl(Container.java:2116)
at java.awt.Component.dispatchEvent(Component.java:4243)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4322
)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3986)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3916)
at java.awt.Container.dispatchEventImpl(Container.java:2102)
at java.awt.Window.dispatchEventImpl(Window.java:2440)
at java.awt.Component.dispatchEvent(Component.java:4243)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:599)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThre
ad.java:273)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.
java:183)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThre
ad.java:173)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:168)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:160)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:121)
Caused by: java.lang.NullPointerException
at com.sun.org.apache.xml.internal.serializer.ToUnknownStream.characters
(ToUnknownStream.java:317)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:240)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:132)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:94)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transfor
mIdentity(TransformerImpl.java:662)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transfor
m(TransformerImpl.java:708)
... 29 more
---------
java.lang.NullPointerException
at com.sun.org.apache.xml.internal.serializer.ToUnknownStream.characters
(ToUnknownStream.java:317)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:240)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:226)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:132)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java
:94)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transfor
mIdentity(TransformerImpl.java:662)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transfor
m(TransformerImpl.java:708)
at com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transfor
m(TransformerImpl.java:313)
at operation.AddNeuronID.addNeuronId(AddNeuronID.java:273)
at operationUI.AddNeuronIDListener.constructor2Perform(AddNeuronIDListen
er.java:245)
at operationUI.AddNeuronIDListener.actionPerformed(AddNeuronIDListener.j
ava:85)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:19
95)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.jav
a:2318)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel
.java:387)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242
)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonL
istener.java:236)
at java.awt.Component.processMouseEvent(Component.java:6041)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3265)
at java.awt.Component.processEvent(Component.java:5806)
at java.awt.Container.processEvent(Container.java:2058)
at java.awt.Component.dispatchEventImpl(Component.java:4413)
at java.awt.Container.dispatchEventImpl(Container.java:2116)
at java.awt.Component.dispatchEvent(Component.java:4243)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4322
)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3986)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3916)
at java.awt.Container.dispatchEventImpl(Container.java:2102)
at java.awt.Window.dispatchEventImpl(Window.java:2440)
at java.awt.Component.dispatchEvent(Component.java:4243)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:599)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThre
ad.java:273)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.
java:183)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThre
ad.java:173)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:168)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:160)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:121)
最初は私も不思議に思っていましたが、transform関数はメモリにあるXMLツリーをファイルに変換するだけで、なぜnullPointerエラーが発生したのでしょうか.インターネットで調べてみると、誰も答えを見つけられず、最後に(http://blog.awe.cz/post/english/beware-of-null-text-nodes/)というブログでかなり役に立つ答えを見つけました.
実はエラーの情報をよく見てみると、重要な情報があります.
java.lang.NullPointerException
at com.sun.org.apache.xml.internal.serializer.ToUnknownStream.characters(ToUnknownStream.java:317)
at com.sun.org.apache.xalan.internal.xsltc.trax.DOM2TO.parse(DOM2TO.java:240)
ここから分かるのは、com.sun.org.apache.xml.internal.serializer.ToUnknownStream.javaファイルのcharacters関数でエラーが発生しました.行数は317です.jdkインストールディレクトリに行き、srcを見つけ、対応するフォルダserializerにToUnknownStream.javaを見つけ、次の関数を見つけます.
/**
* Converts the String to a character array and calls the SAX method
* characters(char[],int,int);
*
* @see ExtendedContentHandler#characters(String)
*/
public void characters(String chars) throws SAXException
{
final int length = chars.length();
if (length > m_charsBuff.length)
{
m_charsBuff = new char[length*2 + 1];
}
chars.getChars(0, length, m_charsBuff, 0);
this.characters(m_charsBuff, 0, length);
}
明らかに、int length=chars.length()に注意してください.パラメータcharsがnullの場合、length関数を呼び出すとnullpoiterExceptionエラーが発生します.さらに、com.sun.org.apache.xalan.internal.xsltc.traxの下にあるDOM 2 TO.javaファイルのparse関数(240行):
case Node.TEXT_NODE:
_handler.characters(node.getNodeValue());
break;
ここではcharacters関数にnullパラメータがなぜ現れるのかを知ることができます.なぜなら、このノードがテキストノードTEXT_であるからです.NODEは、本ノードにコンテンツ(null)がないことを呼び出し、getNodeValueを呼び出すとnullを返す.
transform関数に上昇すると、ノードの内容がnullとなります.DOMSourceクラスでは、メモリに構築されたXMLツリーであるため、このXMLツリーの1つ以上の要素またはノードの内容がnullであるに違いありません.
OK、問題の原因が見つかりました.解決策は簡単で、DOMSourceには要素やノードがnullで、それはXMLを操作するとき、あるいは内容を修正したり、要素を追加したりして、内容をnullに変えます.したがって、エレメントの内容を変更または追加するコードを見つけてnullが発生する可能性がある場合を処理し、nullが検出された場合はXMLを変更しないか、追加しない必要があります.最も簡単な方法はif文を使うことです.すなわち、setNodeValue(String str)またはsetTextContent(String str)の前に、パラメータstrが空であるかどうかを確認し(if(str==null)、空である場合はこの関数を呼び出さない.
私のプログラムでは、確かに空の内容を要素に追加しています.コードは次のとおりです.deviceAndeIDMapはHashMapで、getを呼び出すとこのプライマリ・キーが存在しない場合nullが返されます.
String neuronIdStr = deviceAndIDMap.get(nameContent);
//
neuronIdElem.getFirstChild().setNodeValue(neuronIdStr);
したがってif文を追加すると、問題を解決できます.コード(このコードはforループにあるので、coninueで今回の変更をスキップします)は次のようになります.
String neuronIdStr = deviceAndIDMap.get(nameContent);
if(neuronIdStr == null)
{
continue;
}
//
neuronIdElem.getFirstChild().setNodeValue(neuronIdStr);
問題解決!
読書に感謝して、みんなを助けることができることを望んで、みんなの当駅に対する支持に感謝します!