﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-阿海的blog-文章分类-Java技术</title><link>http://www.blogjava.net/coffee/category/883.html</link><description>记录我的成长，留下我的足迹</description><language>zh-cn</language><lastBuildDate>Thu, 01 Mar 2007 19:08:30 GMT</lastBuildDate><pubDate>Thu, 01 Mar 2007 19:08:30 GMT</pubDate><ttl>60</ttl><item><title>java使用sax对xml文档的解析</title><link>http://www.blogjava.net/coffee/articles/1829.html</link><dc:creator>coffee</dc:creator><author>coffee</author><pubDate>Tue, 08 Mar 2005 07:43:00 GMT</pubDate><guid>http://www.blogjava.net/coffee/articles/1829.html</guid><wfw:comment>http://www.blogjava.net/coffee/comments/1829.html</wfw:comment><comments>http://www.blogjava.net/coffee/articles/1829.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.blogjava.net/coffee/comments/commentRss/1829.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/coffee/services/trackbacks/1829.html</trackback:ping><description><![CDATA[<P>随着互联网技术的发展，XML技术变得越来越重要，从而出现了很多<BR>与XML的整合应用方面的技术，SAX就是其中之一。在这里，我就简要<BR>谈谈java怎样使用sax对xml文档的解析。</P>
<P>首先，让我们来谈谈SAX对XML文档的解析机制。一般情况下，SAX 处理器<BR>分析XML代码将生成以下事件：</P>
<P><BR>Start document<BR>Start element ()<BR>Characters (white space)<BR>Start element ()<BR>Characters ()<BR>End element ()<BR>............<BR>End element ()</P>
<P>具体解析步骤如下<BR>一、 创建事件处理程序，SAX 提供应用程序可扩展的类 DefaultHandler。<BR>创建的解析类config必须继承类 DefaultHandler。<BR>如：public class Config extends DefaultHandler{}<BR>二、使用 JAXP 来创建解析器：使用 JAXP 中的类 XMLReaderFactory <BR>来创建解析器。首先声明 XMLReader的一个对象 parser。然后使用<BR>XMLReaderFactory的createXMLReader方法来创建 SAXParser。<BR>XMLReader parser =<BR>XMLReaderFactory.createXMLReader(<BR>"org.apache.xerces.parsers.SAXParser"); <BR>三、一旦创建了解析器，则需要将 config 设置为内容处理程序，<BR>以便于其接收事件。<BR>parser.setContentHandler(this);</P>
<P>但是，当然总会有可能在试图进行解析时，数据有问题。这时应该创建<BR>ErrorHandler 在这样的情况下，有一个处理程序来处理错误和内容。<BR>parser.setErrorHandler(this);<BR>四、准备对文件进行实际解析。应用程序文件传递给 parse()，然后应用程序<BR>会继续运行。<BR>parser.parse(confFile);<BR>五、接下来就开始对文档进行解析了。前面说过SAX的处理机制，SAX在处理XML流<BR>的过程中，首先产生startDocument()事件，实际上该事件什么也没有发生，因为<BR>还没有定义任何解析的事件。使用 startDocument() 事件只是为了通知文档的开<BR>始。类似其它 SAX 事件，该事件抛出 SAXException。<BR>例如：<BR>public void startDocument()<BR>throws SAXException {<BR>System.out.println(<BR>"Tallying survey results...");<BR>}</P>
<P>六、跟下来，就正式开始对文件进行解析了。这时SAX会产生一个startElement()<BR>事件，对于每个元素，都会回送一个传递给 startElement() 事件的名称。不过<BR>解析器实际所传递是：该元素的名称空间信息；该元素的实际名称或 localName；<BR>名称空间别名和 localName 的组合（否则是限定名或 qname）；以及该元素任何<BR>属性。startElement() 事件还提供对元素属性的访问。将这些属性传递进称为 <BR>Attributes的数据结构。根据属性在数组中位置或属性的名称，可以检索该属性值。<BR>例如：<BR>public void startElement(<BR>String namespaceURI, <BR>String localName, <BR>String qName, <BR>Attributes atts) <BR>throws SAXException {<BR>String s = (!"".equals(localName)) ? localName : qName;</P>
<P>System.out.print("Start element: ");<BR>System.out.println(localName);<BR>tag = s;<BR>if (localName == "Connector") {<BR>System.out.println("name: "<BR>+ atts.getValue("name"));<BR>} else if (localName == "port") {<BR>thisQuestion = atts.getValue("servername");<BR>}else if (localName == "maxThreadPoolSize") {<BR>thisQuestion = atts.getValue("poolname");<BR>}<BR>if (localName == "Database") {<BR>System.out.println("name: "<BR>+ atts.getValue("name"));<BR>} else if (localName == "driverName") {<BR>thisQuestion = atts.getValue("dataname");<BR>}else if (localName == "encoding") {<BR>thisQuestion = atts.getValue("codename");<BR>}<BR>thisElement = localName;</P>
<P><BR>for (int att = 0;att &lt; atts.getLength(); att++) {<BR>String attName = atts.getLocalName(att);<BR>System.out.println(" "<BR>+ attName + ": "<BR>+ atts.getValue(attName)); <BR>}</P>
<P><BR>}<BR>七、有了元素，接下来用 characters() 来检索实际的数据。这时可以使用下面的<BR>方法获得实际的数据：<BR>可以用String s = new String(ch, start, length).trim();<BR>这个方法来获得数据。<BR>例如：<BR>public void characters(char[] ch,<BR>int start,<BR>int length)<BR>throws SAXException {</P>
<P>String s = new String(ch, start, length).trim();<BR>if (!"".equals(s)) {<BR>if ("port".equals(tag)) {<BR>System.out.println(Integer.parseInt(s));<BR>} else if ("maxThreadPoolSize".equals(tag)) {<BR>System.out.println(Integer.parseInt(s));<BR>}<BR>//System.out.println(tag+" = "+s);<BR>} </P>
<P>s = new String(ch, start, length).trim();<BR>if (!"".equals(s)) {<BR>if ("driverName".equals(tag)) {<BR>System.out.println(s);<BR>} else if ("encoding".equals(tag)) {<BR>System.out.println(s);<BR>}<BR>//System.out.println(tag+" = "+s);<BR>} <BR>}<BR>八、接下来的要做的就是用endElement()来结束对一个xml的 element的解析。<BR>例如：下面的方法<BR>public void endElement(String namespaceURI, <BR>String localName, <BR>String qName)<BR>throws SAXException {</P>
<P>printIndent(indent);<BR>System.out.println("End Element: "+localName);<BR>indent = indent - 4;<BR>thisQuestion = "";<BR>thisElement = "";<BR>九、最后就是告诉程序，xml文件解析完毕，此时，用endDocument()来结束程序。<BR>例如：<BR>public void endDocument() {}</P>
<P>总的来说，sax处理xml的方法还基本上是差不多的，只是一二步的方法相对多一点,<BR>那些其他的方法我这里就不多说了，由读者自己去查找资料。<BR><BR>[2年前写的东西,可能有点过时了~~~]</P><img src ="http://www.blogjava.net/coffee/aggbug/1829.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/coffee/" target="_blank">coffee</a> 2005-03-08 15:43 <a href="http://www.blogjava.net/coffee/articles/1829.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>java的安全性</title><link>http://www.blogjava.net/coffee/articles/504.html</link><dc:creator>coffee</dc:creator><author>coffee</author><pubDate>Thu, 20 Jan 2005 07:51:00 GMT</pubDate><guid>http://www.blogjava.net/coffee/articles/504.html</guid><wfw:comment>http://www.blogjava.net/coffee/comments/504.html</wfw:comment><comments>http://www.blogjava.net/coffee/articles/504.html#Feedback</comments><slash:comments>1</slash:comments><wfw:commentRss>http://www.blogjava.net/coffee/comments/commentRss/504.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/coffee/services/trackbacks/504.html</trackback:ping><description><![CDATA[<P>前天去一个公司面试，技术官问了我一个问题，java的安全性的特点主要体现在什么地方。我竟然哑然。</P>
<P>后来仔细一想，再查了一点资料，整理如下：</P>
<P>java的安全在语言级上提供了很好的安全措施，主要是：</P>
<P>1、严格遵循面向对象的规范。这样封装了数据细节，只提供接口给用户。增加了数据级的安全性。</P>
<P>2、无指针运算。java中的操作，除了基本类型都是引用的操作。引用是不能进行增减运算，不能被直接赋予内存地址的，从而增加了内存级的安全性。</P>
<P>3、数组边界检查。这样就不会出现C/C++中的缓存溢出等安全漏洞。</P>
<P>4、强制类型转换。非同类型的对象之间不能进行转换，否则会抛出ClassCastException</P>
<P>5、语言对线程安全的支持。java从语言级支持线程。从而从语法和语言本身做了很多对线程的控制和支持。</P>
<P>&nbsp;</P>
<P>此外，java的安全还通过编译器、检验器、类装载器、建立安全策略等方式保证了java程序的安全性。</P><img src ="http://www.blogjava.net/coffee/aggbug/504.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/coffee/" target="_blank">coffee</a> 2005-01-20 15:51 <a href="http://www.blogjava.net/coffee/articles/504.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>