XML ドキュメントのコンテンツへのアクセスに問題があります。私の目標は次のとおりです。XML ソースを取得し、連想配列と同等のものに解析してから、永続化可能なオブジェクトとして保存します。
xml は非常に単純です。
<root>
<element>
<category_id>1</category_id>
<name>Cars</name>
</element>
<element>
<category_id>2</category_id>
<name>Boats</name>
</element>
</root>
以下の基本的な Java クラス。上記の http 応答の後に save(xml) を呼び出すだけです。はい、xml は適切にフォーマットされています。
import java.io.IOException;
import java.util.Hashtable;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import java.util.Vector;
import net.rim.device.api.system.PersistentObject;
import net.rim.device.api.system.PersistentStore;
import net.rim.device.api.xml.parsers.DocumentBuilder;
import net.rim.device.api.xml.parsers.DocumentBuilderFactory;
public class database{
private static PersistentObject storeVenue;
static final long key = 0x2ba5f8081f7ef332L;
public Hashtable hashtable;
public Vector venue_list;
String _node,_element;
public database()
{
storeVenue = PersistentStore.getPersistentObject(key);
}
public void save(Document xml)
{
venue_list = new Vector();
storeVenue.setContents(venue_list);
Hashtable categories = new Hashtable();
try{
DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory. newInstance();
DocumentBuilder docBuilder = docBuilderFactory.newDocumentBuilder();
docBuilder.isValidating();
xml.getDocumentElement ().normalize ();
NodeList list=xml.getElementsByTagName("*");
_node=new String();
_element = new String();
for (int i=0;i<list.getLength();i++){
Node value=list.item(i).getChildNodes().item(0);
_node=list.item(i).getNodeName();
_element=value.getNodeValue();
categories.put(_element, _node);
}
}
catch (Exception e){
System.out.println(e.toString());
}
venue_list.addElement(categories);
storeVenue.commit();
}
上記のコードは進行中の作業であり、おそらく重大な欠陥があります。しかし、私は何日もこれに取り組んでいます。すべての子ノード、または名前と値のペアを取得できないようです。ベクトルを文字列として出力すると、通常は [{ = root, = element}] のような結果になります。「category_id」も「name」もありません
理想的には、[{1 = 車、2 = ボート}] のような結果になるでしょう。
どんな助けでも大歓迎です。
ありがとう