我有一个这样的xml文件:
<content:encoded>
<![CDATA[
<p>Some Data</p>
<p>
<img class="aligncenter size-large wp-image-4525" src="https://www.website.com/image1.jpg" alt="cover2" width="810" height="422" srcset="https://www.website.com/image2.jpg"/>
Some Data
</p>
]]> //end of CData
</content:encoded>
我有这个安卓代码:
private void ProcessXml(Document data) {
if(data!=null){
ArrayList<FeedItem>feedItems=new ArrayList<>();
Element root=data.getDocumentElement();
Node channel=root.getChildNodes().item(1);
NodeList items=channel.getChildNodes();
for(int i=0;i<items.getLength();i++)
{
Node currentchild=items.item(i);
if(currentchild.getNodeName().equalsIgnoreCase("item")){
FeedItem item=new FeedItem();
NodeList itemchilds=currentchild.getChildNodes();
for(int j=0;j<itemchilds.getLength();j++)
{
Node current=itemchilds.item(j);
if(current.getNodeName().equalsIgnoreCase("title")){
item.setTitle(current.getTextContent());
}else if (current.getNodeName().equalsIgnoreCase("description")) {
item.setDescription(current.getTextContent());
}else if (current.getNodeName().equalsIgnoreCase("pubDate")) {
item.setPubDate(current.getTextContent());
}else if (current.getNodeName().equalsIgnoreCase("link")) {
item.setLink(current.getTextContent());
}else if (current.getNodeName().equalsIgnoreCase("content:encoded")) {
//What code should I write here to get the image source/link of image.
}
}
}
feedItems.add(item);
}
}
}
}
我想获取 xml 文件中的第二个链接。其余代码工作正常,如何访问 CData 并仅提取 Java 中图像的链接?
CDATA 标记告知 XML 分析器将内容视为纯文本。因此,如果您不想将其视为文本,而是将其视为 XML,则必须将内容提取为文本,然后将其提交到另一轮 XML 解析中。