比较简单的就不记录了。记一些容易忘的。
XML部分
1、特殊字符如何表示为纯文本
这些字符在xml中属于特殊字符,它代表的不是本身字符的意思。因此特殊字符表示成纯文本,就要通过特殊的办法来表示
方法一:实体引用
方法二:CDATA标记
<![CDATA[文本内容]]>
注意,实体引用放入这里,也会变成纯文本
2、注释规则
3、什么是DTD或者Schema约束
约束了在哪些根标签下会出现哪些子标签,形成一种规范,这样在解析xml的时候,就有了规范。
JAXP解析xml文档部分
解析的原理:
一行一行的扫描下来,当遇到标签开始时,就发送一个标签开始事件信号,当遇到标签结束时,就发送一个标签结束信号。我们在事件监听器中就能获得当前标签的信息了。
java代码:
Code: 在SAXPrase.class 中解析bean1.xml
public class SAXParse {
public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser parse = factory.newSAXParser();// 得到SAXPraser对象
parse.parse("src\\bean1.xml", new MyHandler());// 传入路径,监听器
}
}
Code: 在MyHandler.class 监听事件
public class MyHandler extends DefaultHandler {
private String currentTag;
// 每当处理文本数据时,触发该方法
@Override
public void characters(char[] ch, int start, int length) throws SAXException {
String content = new String(ch, start, length);
// 当元素间的文档存在时,打印
if (content.trim().length() > 0) {
System.out.println("<"+currentTag+">元素的值是:"+content.trim());
}
}
//解析文档结束时触发该方法
@Override
public void endDocument() throws SAXException {
System.out.println("解析文档结束");
}
//解析元素结束时触发该方法
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
System.out.println("处理元素结束:"+qName);
}
//每当解析文档开始时触发该方法
@Override
public void startDocument() throws SAXException {
System.out.println("解析文档开始");
}
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
System.out.println("开始处理元素:"+qName);
currentTag=qName;
if (attributes.getLength()>0) {
System.out.println("<"+currentTag+">元素的属性如下:");
for (int i = 0; i < attributes.getLength(); i++) {
System.out.println(attributes.getQName(i)+"--->"+attributes.getValue(i));
}
}
}
}
至此,就得到了XML文档的各个内容,再通过自己的需求,取出其中的数据即可
生成XML文档部分:
public class BuildXMLMain {
public static void main(String[] args) throws Exception {
//创建保存XML的结果流对象
Result resultXML=new StreamResult(new File("D://firstxml1.xml"));
//获取sax生成工厂实例
SAXTransformerFactory saxTransformerFactory=(SAXTransformerFactory) SAXTransformerFactory.newInstance();
//获取SAX生成处理者对象实例
TransformerHandler transformerHandler=saxTransformerFactory.newTransformerHandler();
transformerHandler.setResult(resultXML);
//获取SAX生成器
Transformer transformer=transformerHandler.getTransformer();
transformer.setOutputProperty(OutputKeys.INDENT, "yes");
//生成文档的开始
transformerHandler.startDocument();
AttributesImpl attrImpl=new AttributesImpl();
transformerHandler.startElement("", "", "书籍列表", attrImpl);
transformerHandler.startElement("", "", "计算机书籍", attrImpl);
transformerHandler.startElement("", "", "书名", attrImpl);
transformerHandler.characters("Java思想".toCharArray(), 0, "Java思想".length());
transformerHandler.endElement("", "", "书名");
transformerHandler.startElement("", "", "作者", attrImpl);
transformerHandler.characters("小王".toCharArray(), 0, "小王".length());
transformerHandler.endElement("", "", "作者");
transformerHandler.startElement("", "", "价格", attrImpl);
transformerHandler.characters("79.00".toCharArray(), 0, "79.00".length());
transformerHandler.endElement("", "", "价格");
transformerHandler.endElement("", "", "计算机书籍");
//第二本书
transformerHandler.startElement("", "", "计算机书籍", attrImpl);
transformerHandler.startElement("", "", "书名", attrImpl);
transformerHandler.characters("Spring指南".toCharArray(), 0, "Spring指南".length());
transformerHandler.endElement("", "", "书名");
transformerHandler.startElement("", "", "作者", attrImpl);
transformerHandler.characters("小李".toCharArray(), 0, "小李".length());
transformerHandler.endElement("", "", "作者");
transformerHandler.startElement("", "", "价格", attrImpl);
transformerHandler.characters("89.00".toCharArray(), 0, "89.00".length());
transformerHandler.endElement("", "", "价格");
transformerHandler.endElement("", "", "计算机书籍");
transformerHandler.endElement("", "", "书籍列表");
//告诉handler文档生成已结束
transformerHandler.endDocument();
System.out.println("XML文档生成成功!");
}
}