java 里面XML组件有
DOM W3C标准
sax
JDOM 传说是集合了Sax与DOM的优点而成的
JAXB 这个是sun与apache合作的。java操作XML可以做soap,也就是web services,还可以读取配置文件啊。传递数据啊。。
DOM W3C标准
sax
JDOM 传说是集合了Sax与DOM的优点而成的
JAXB 这个是sun与apache合作的。java操作XML可以做soap,也就是web services,还可以读取配置文件啊。传递数据啊。。
调试欢乐多
另外还有SAX,DOM,DOM4J..
如果原来会JDOM的话,那就继续用JDOM
如果现在学的话就 学DOM4J 和SAX
具体用DOM4J还是SAX那就看你操作文件的大小
javax.xml.parsers.DocumentBuilderFactory=org.apache.xerces.jaxp.DocumentBuilderFactoryImpl
javax.xml.parsers.SAXParserFactory=org.apache.xerces.jaxp.SAXParserFactoryImpl这样就可以使用Xerces,当然你必须还是要把Xerces包放到CLASSPATH下。 二、JAXP的姗姗来迟 Sun在XML领域总是后知后觉,等到Sun重视XML的时候,XML的API早就满天 飞了,尤其是IBM具有非常大的领先优势。不过Sun是规范的制订者,于是参考W3C的标准制订了JAXP规范。JAXP不像Xerces和Crimon那样,它只是一个spec,本身是不做任何事情的,它的作用就是提出一个统一的接口,让其它的XML API都来遵循JAXP编程,那么用JAXP写出来的程序,底层的API可以任意切换。 具体来说JAXP包括了几个工厂类,这就是JDK1.4里面的javax.xml.parsers 包,用来寻找符合DOM标准的XML API实现类的位置;此外JAXP还包括一整套interface,这就是JDK1.4里面的org.w3c.dom那几个包。工厂类负责加载DOM的实现类。那么加载的规则是什么呢? 我是通过阅读JAXP的源代码知道的,工厂类首先会根据java命令行传入的参数进行寻找,然后在根据JRE\lib\jaxp.properties中定义的实现类寻找,最后什么都找不到的话,就用Crimson。注意Crimons是由Bootstrap Class Loader来load的,如果你不通过上面两个方法来改变工厂的寻找顺序,那么铁定用Crimson了 三、 DOM解析器和DOM API 当你严格采用JAXP编程的时候,是遵循W3C的DOm标准的,那么在JAXP底层你实际上可以任意切换不同的DOM实现,例如Xerces,或者Crimon,再或者其它,切换方法就是配置jaxp.properties。因此JAXP就是一些标准接口而已。 而Xerces和Crimon也不单单是一个DOM实现那么简单,他们本身实际上也包含SAX解析器和DOM解析器。所以一个JAXP程序下面有如下层次:
JAXP应用程序 -> JAXP接口 -> Xerces DOM实现 -> Xerces DOM/SAX 解析器
只要你用JAXP编程,那么你就可以切换到Crimson上来
JAXP应用程序 -> JAXP接口 -> Crimson DOM实现 -> Crimson DOM/SAX 解析器
另外你也可以这样来做:
JAXP应用程序 -> JAXP接口 -> Crimson DOM实现 -> Xerces DOM/SAX 解析器
不过如果你的程序不安装JAXP来写,那么就没有办法切换不同的DOM实现了。 四、不是标准的dom4j和jdom W3C的DOM标准API难用的让人想撞墙,于是有一帮人开发Java专用的XML API目的是为了便于使用,这就是jdom的由来,开发到一半的时候,另一部分人又分了出来,他们有自己的想法,于是他们就去开发dom4j,形成了今天这样两个API,至于他们之间的性能,功能之比较看看上面我推荐的文章就知道了,jdom全面惨败。 jdom 相当于上面的 JAXP接口 + Xerces DOM实现部分,它本身没有解析器,它可以使用Xerces或者Crimson的解析器,就是这样:
jdom应用程序 -> jdom API -> Xerces/Crimson解析器
dom4j 和jdom类似,不过他自己绑定了一个叫做Alfred2的解析器,功能不是很全,但是速度很快,当没有其它的解析器的时候,dom4j将使用Alfred2解析器,如下:
dom4j应用程序 -> dom4j API -> Xerces/Crimson解析器
或者
dom4j应用程序 -> dom4j API -> Alfred2解析器
你在SF上下载的dom4j.jar是不含 Alfred2解析器的,而dom4j-full.jar包含了 Alfred2解析器,在这种情况下,实际上你什么也不需要,光是一个dom4j-full.jar就全部都包括了。 因此可以看出采用dom4j/jdom编写的应用程序,已经不具备可移植性了。 五、小插曲 Sun是JAXP标准的制订者,甚至很执著的在JDK1.4里面绑定Crimson DOM实现和解析器,然后可笑的是,Sun自己的JAXM RI竟然不是用JAXP写出来的,而是dom4j,制订标准让大家遵守,自己却监守自盗,这未免太说不过去了吧! BTW: Hibernate也用的是dom4j来读取XML配置文件,如今已经越来越多的程序纷纷采用dom4j,如果你不是那么在乎可移植性,我强烈建议你采用dom4j。
另外还有SAX,DOM
JDOM_API: http://www.jdom.org/docs/apidocs/index.html
需要这几个jar: jdom.jar xercesImpl.jar xmlParserAPIs.jar
JDOM处理程序员用的XML够用了,以下为一段测试代码, 你看个差不多就行了,不会的再问,
good luck~
import org.jdom.*;
import org.jdom.input.*;
import org.jdom.output.*;
import java.io.*;
public class Test
{
public Test()
{
} public void ShowElement(Element e)
{
String value="";
String name="";
String text="";
text=e.getTextTrim();
name=e.getName();
System.out.print("<1"+name);
java.util.List list1= e.getAttributes();
for(int j=0;j<list1.size();j++)
{
Attribute att=(Attribute)list1.get(j);
//value=att.getValue();
System.out.print(" "+att.getName()+"=\""+att.getValue()+"\"");
} java.util.List list=e.getChildren();
if (list.size()<1)
{
text=e.getTextTrim();
if(text.equals(""))
{
System.out.println("/2>");
}
else
{ System.out.println("3>"+text+"<4/"+name+"5>");
}
return;
}
else
{
System.out.println("6>");
}
for (int i=0;i<list.size();i++)
{
Element el=(Element)list.get(i);
ShowElement(el);
}
System.out.println("<7/"+name+"8>");
}
public void TestXML()
{
SAXBuilder sb=new SAXBuilder();
try
{
Document doc = sb.build("d:\\XML\\workflow.xml");
// ProcessingInstruction pi=new ProcessingInstruction("");
//得到根元素
Element root=doc.getRootElement();
/*****
ShowElement(root);
if (true) return ;
/*****/ Element el=new Element("DingTest");
Comment comment=new Comment("This is a comment!");
el.addContent(comment);
el.addAttribute("myAttribute","AttributeValue");
// el.addContent("This is my Test!");
el.addContent(new Element("HAHHA").addContent("DDDDDDDDD"));
el.addContent(new Element("BBBBB").addContent("AAAAAAAAA"));
el.addContent(new CDATA("DDDD"));
DocType doctype=new DocType("AAA","dd.dtd");
// doctype.setPublicID("publicid");
doctype.setSystemID("SystemID");
doc.setDocType(doctype); ProcessingInstruction pi=new ProcessingInstruction("Target","data");
doc.addContent(pi);
root.addContent(el);
String indent=" ";
boolean bNewLine=true;
String encode="gb2312";
XMLOutputter out=new XMLOutputter(indent,bNewLine,encode);
out.output(doc,new FileOutputStream("d:\\xml\\testtest.xml")); }
catch(Exception e)
{
System.out.println(e);
} }
public static void main(String[] args)
{
Test test1 = new Test();
test1.TestXML();
}}