国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Java & XML基礎學習筆記 SAX篇

2019-11-18 12:48:01
字體:
來源:轉載
供稿:網友

  1、需要軟件
  java,解析器(例如Xerces),API(例如SAX,DOM)
  
  2、SAX機制
  1)解析
  String xmlURI = "c:/test.xml";
  String vendorParserClass = "org.apache.xerces.parsers.SAXParser";
  XMLReaer reader = XMLReaderFactory.createXMLReader(vendorParserClass);
  
  InputSource inputSource = new InputSource(xmlURI);
  reader.parse(inputSource);
  
  這樣一個xml文檔解析過程就完成了。因為SAX是采用時間處理機制來解析XML
  文檔的,在解析過程中會觸發一些事件,也就是執行特定的方法,你可以實現
  這些方法,就可以通過解析xml來做一些事情了
  2)處理
  SAX2.0定義的核心處理接口一共有
  org.xml.sax.ContentHandler
  org.xml.sax.ErrorHandler
  org.xml.sax.DTDHandler
  org.xml.sax.EntityResolver
  這些接口是通過
  org.xml.sax.XMLReader的setContentHandler(),setEroorHandler(),
  setDTDHandler(),setEntityHandler()注冊到解析器,這里面最重要的是
  org.xml.sax.ContentHandler接口,它具體如下
  public interface ContentHandler{
  public void setDocumentLocator(Locator locator);
  public void startDocument() throws SAXException;
  public void endDocument() throws SAXException;
  public void startPRefixMapping(String prefix,String uri)
  throws SAXException;
  public void endPrefixMapping(String prifix)
  throws SAXException;
  public void startElement(String namespaceURI,String localName,
  String qName,Attributes atts) throws SAXException;
  public void endElement(String namespaceURI,String localName,
  String qName) throws SAXException;
  public void characters(char ch[],int start,int length)
  throws SAXException;
  public void ignorableWhitespace(char ch[],int start,int length)
  throws SAXException;
  public void processingInstrUCtion(String target,String data)
  throws SAXException;
  public void skippedEntity(String name)
  throws SAXException;
  }
  通過setContentHandler()將你實現的ContentHandler注冊給XMLReader之后,
  在解析過程中,系統根據各種條件執行接口中的方法,下面簡單說明一下
  1)文檔定位器
  private Locator locator;
  
  public void setDocumentLocator(Locator locator){
  this.locator = locator;
  }
  
  通常情況下,你只要如此實現就可以了,這個主要是得到當前解析的位置,
  通過得到的locator,你可以使用它的getLineNumber(),getColumnName()等
  方法,可以得到文檔當前的位置,但要注重的是,這個locator不能保存,只
  針對當前的解析有效
  2)文檔的開頭和結尾
  public void startDocument() throws SAXException{
  //解析過程中僅位于setDocumentLocator()方法后調用
  }
  public void endDocument() throws SAXException{
  //解析過程中最后調用
  }
  
  大多數情況下你可以不用理他們,只要寫個空方法就可以了
  3)名字空間的開始和結束
  public void startPrefixMapping(String prefix,String uri)
  throws SAXException{
  }
  public void endPrefixMapping(String prifix)
  throws SAXException{
  }
  4)元素的開始和結束
  public void startElement(String namespaceURI,String localName,
  String qName,Attributes atts) throws SAXException{
  }
  public void endElement(String namespaceURI,String localName,
  String qName) throws SAXException{
  }
  5)元素的數據
  public void characters(char ch[],int start,int length)
  throws SAXException{
  String s = new String(ch,start,length);
  }
  這個是得到當前的元素的文本數據
  6)可以忽略的空白
  public void ignorableWhitespace(char ch[],int start,int length)
  throws SAXException{
  }
  7)實體
  public void skippedEntity(String name)
  throws SAXException{
  }
  8)指令處理
  public void processingInstruction(String target,String data)
  throws SAXException{
  }
  3)例子:這個是從Java & XML 中復制過來的,
  /*
  * Created on 2004-11-30
  *
  * TODO To change the template for this generated file go to
  * Window - Preferences - Java - Code Style - Code Templates
  */
  package javaxml2;
  
  /**
  * @author yuangfang
  *
  * TODO To change the template for this generated type comment go to
  * Window - Preferences - Java - Code Style - Code Templates
  */
  
  import java.io.*;
  import java.util.*;
  import org.xml.sax.*;
  import org.xml.sax.ext.LexicalHandler;
  import org.xml.sax.helpers.XMLReaderFactory;
  
  import java.awt.*;
  import javax.swing.*;
  import javax.swing.tree.*;
  
  public class SAXTreeViewer extends JFrame{
  
  private String vendorParserClass = "org.apache.xerces.parsers.SAXParser";
  
  private JTree jTree;
  DefaultTreeModel defaultTreeModel;
  
  public SAXTreeViewer(){
  super("SAX Tree Viewer");
  setSize(600,450);
  }
  
  public void init(String xmlURI) throws IOException,SAXException{
  DefaultMutableTreeNode base = new DefaultMutableTreeNode("XML Document:" + xmlURI);
  defaultTreeModel = new DefaultTreeModel(base);
  jTree = new JTree(defaultTreeModel);
  
  buildTree(defaultTreeModel,base,xmlURI);
  getContentPane().add(new JScrollPane(jTree),BorderLayout.CENTER);
  
  }
  
  public void buildTree(DefaultTreeModel treeModel,DefaultMutableTreeNode base,String xmlURI)
  throws IOException,SAXException{
  
  String featureURI = "";
  try{
  XMLReader reader = XMLReaderFactory.createXMLReader(vendorParserClass);
  
  ContentHandler jTreeContentHandler = new JTreeContentHandler(treeModel,base);
  ErrorHandler jTreeErrorHandler = new JTreeErrorHandler();
  
  reader.setContentHandler(jTreeContentHandler);
  reader.setErrorHandler(jTreeErrorHandler);
  reader.setEntityResolver(new SimpleEntityResolver());
  
  featureURI = "http://xml.org/sax/features/validation";
  reader.setFeature(featureURI,true);
  
  featureURI = "http://xml.org/sax/features/namespaces";
  setNamespaceProcessing(reader,true);
  
  featureURI = "http://xml.org/sax/features/string-interning";
  reader.setFeature(featureURI,true);
  
  featureURI = "http://apache.org/xml/features/validation/schema";
  reader.setFeature(featureURI,false);
  
  InputSource inputSource = new InputSource(xmlURI);
  reader.parse(inputSource);
  }
  catch(SAXNotRecognizedException e){
  System.out.println("The parse class " + vendorParserClass
  + " does not recognize the feature URI " + featureURI);
  System.exit(0);
  }
  catch(SAXNotSupportedException e){
  System.out.println("The parser class " + vendorParserClass +
  " does not support the feature URI " + featureURI);
  }
  }
  
  private void setNamespaceProcessing(XMLReader reader,boolean state)
  throws SAXNotSupportedException,SAXNotRecognizedException
  {
  reader.setFeature("http://xml.org/sax/features/namespaces",state);
  reader.setFeature("http://xml.org/sax/features/namespace-prefixes",!state);
  }
  public static void main(String[] args) {
  try{
  if(args.length != 1){
  System.out.println("Usage:Java javaxml2.SAXTreeViewer " + "[XML Document URI]");
  System.exit(0);
  }
  SAXTreeViewer viewer = new SAXTreeViewer();
  viewer.init(args[0]);
  viewer.setVisible(true);
  }catch(Exception e)
  {
  e.printStackTrace();
  }
  }
  }
  
  class JTreeContentHandler implements ContentHandler,LexicalHandler{
  private DefaultTreeModel treeModel;
  
  private DefaultMutableTreeNode current;
  
  private Locator locator;
  
  private Map namespaceMapp

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 金塔县| 平阴县| 濮阳县| 太和县| 兰溪市| 辰溪县| 汾阳市| 陆川县| 河北区| 务川| 孝义市| 繁昌县| 凤山县| 当雄县| 洛浦县| 田东县| 长海县| 张北县| 奉化市| 铜山县| 元氏县| 丹凤县| 河源市| 铜山县| 衡东县| 桃园市| 临沂市| 吴堡县| 克东县| 水富县| 乌鲁木齐县| 宜州市| 临桂县| 平阴县| 辉南县| 芮城县| 衡山县| 昭苏县| 鄱阳县| 遵义县| 哈巴河县|