Java网络程序设计 教学课件 ppt 作者 房晓溪 第15章 用Servlet与XSL结合开发WEB应用程序

上传人:E**** 文档编号:89396723 上传时间:2019-05-24 格式:PPT 页数:19 大小:183.50KB
返回 下载 相关 举报
Java网络程序设计 教学课件 ppt 作者 房晓溪 第15章  用Servlet与XSL结合开发WEB应用程序_第1页
第1页 / 共19页
Java网络程序设计 教学课件 ppt 作者 房晓溪 第15章  用Servlet与XSL结合开发WEB应用程序_第2页
第2页 / 共19页
Java网络程序设计 教学课件 ppt 作者 房晓溪 第15章  用Servlet与XSL结合开发WEB应用程序_第3页
第3页 / 共19页
Java网络程序设计 教学课件 ppt 作者 房晓溪 第15章  用Servlet与XSL结合开发WEB应用程序_第4页
第4页 / 共19页
Java网络程序设计 教学课件 ppt 作者 房晓溪 第15章  用Servlet与XSL结合开发WEB应用程序_第5页
第5页 / 共19页
点击查看更多>>
资源描述

《Java网络程序设计 教学课件 ppt 作者 房晓溪 第15章 用Servlet与XSL结合开发WEB应用程序》由会员分享,可在线阅读,更多相关《Java网络程序设计 教学课件 ppt 作者 房晓溪 第15章 用Servlet与XSL结合开发WEB应用程序(19页珍藏版)》请在金锄头文库上搜索。

1、第1页,第15章,用Servlet与XSL结合开发WEB应用程序,第2页,主要内容,什么是JAXP XML解析器 Servlet 与XSL 配合机制,第3页,15-1 什么是JAXP,JAXP是Java API for XML Processing的英文字头缩写,中文含义是:用于XML文档处理的使用Java语言编写的编程接口。 JAXP支持DOM、SAX、XSLT等标准。,第4页,15-2 XML解析器,直接读写XML文档 使用XmlDocument类 使用TransformerFactory和Transformer类 OutputKeys类 使用Xalan XML Serializer,第5

2、页,15-2-1 直接读写XML文档,当程序获取DOM Tree之后,应用DOM模型的Node接口的各个方法对DOM Tree进行更新,下一步应该对原始的XML文档进行更新了。我们可以运用递归的办法或者是应用TreeWalker类,遍历整个DOM Tree,与此同时,将DOM Tree的每一个节点/元素依次写入到预先打开的原始XML文档中,当DOM Tree被遍历完全之后,DOM Tree和原始的XML文档就实现了同步更新。实际中,这个方法极少使用,不过如果你要编程实现自己的XML解析器,这种方法还是有可能用得上的。,第6页,15-2-2 使用XmlDocument类,在XmlDocument

3、类中提供了下面三个write()方法(根据Crimson最新的版本-Apache Crimson 1.1.3): public void write (OutputStream out) throws IOException public void write (Writer out) throws IOException public void write (Writer out, String encoding) throws IOException,第7页,Java程序代码片断,String name=“fancy“; DocumentBuilder parser; DocumentBu

4、ilderFactory factory = DocumentBuilderFactory.newInstance(); try parser = factory.newDocumentBuilder(); Document doc = parser.parse(“user.xml“); Element newlink=doc.createElement(name); doc.getDocumentElement().appendChild(newlink); (XmlDocument)doc).write(new FileOutputStream(new File(“xuser1.xml“)

5、; catch (Exception e) /to log it ,第8页,15-2-2 使用XmlDocument类,注意:Apache Crimson的前身是Sun Project X Parser,后来不知何故,由X Parser演变为Apache Crimson,至今Apache Crimson的很多代码都是从X Parser中直接移植过来的。比如上文用到的XmlDocument类,它在X Parser中是com.sun.xml.XmlDocument,到了Apache Crimson中摇身一变,就变成了org.apache.crimson.tree.XmlDocument类,其实它们

6、的绝大部分代码是一样的,可能就package语句和import语句以及文件开头的一段lience有所不同而已。早期的JAXP是和X Parser捆绑在一起的,因此一些老的程序使用了com.sun.xml包,如果你现在重新编译它们,有可能不能通过,肯定就是因为这个原因。后来的JAXP和Apache Crimson捆绑在一起,比如JAXP 1.1,如果你使用JAXP 1.1,那么不需要额外下载Apache Crimson,也能够正常编译运行上面的例子(AddRecord.java)。最新的JAXP 1.2 EA(Early Access)改弦更张,采用性能更好的Apache Xalan和Apach

7、e Xerces分别作为XSLT处理器和XML解析器,不能直接支持Apache Crimson了,所以如果你的开发环境采用了JAXP 1.2 EA或者是Java XML Pack(内含JAXP 1.2 EA),那么将无法直接编译运行上面的例子(AddRecord.java),你需要额外下载并安装Apache Crimson。,第9页,15-2-3 使用TransformerFactory和Transformer类,/首先创建一个DOMSource对象,该构造函数的参数可以是一个Document对象 /doc代表更改后的DOM Tree。 DOMSource doms = new DOMSour

8、ce (doc); /创建一个File对象,代表DOM Tree所包含的数据的输出介质,这是一个XML文件。 File f = new File (“XMLOutput.xml“); /创建一个StreamResult对象,该构造函数的参数可以取为File对象。 StreamResult sr = new StreamResult (f); /下面调用JAXP中的XSLT引擎来实现输出DOM Tree中的数据到XML文件中的功能。 /XSLT引擎的输入为DOMSource对象,输出为StreamResut对象。 Try /首先创建一个TransformerFactory对象,再由此创建Tran

9、sformer对象。Transformer /类相当于一个XSLT引擎。通常我们使用它来处理XSL文件,但是在这里我们使 /用它来输出XML文档。,第10页,接上,TransformerFactory tf=TransformerFactory.newInstance(); Transformer t=tf.newTransformer (); /关键的一步, 调用Transformer对象 (XSLT引擎)的transform()方法,该方法的第一 /个参数是DOMSource对象,第二个参数是StreamResult对象。 t.transform(doms,sr); catch (Tran

10、sformerConfigurationException tce) System.out.println(“Transformer Configuration Exceptionn-“); tce.printStackTrace(); catch (TransformerException te) System.out.println (“Transformer Exceptionn-“); te.printStackTrace (); ,第11页,15-2-4 OutputKeys类,/首先创建一个TransformerFactory对象,再由此创建Transformer对象。 Trans

11、formerFactory tf=TransformerFactory.newInstance(); Transformer t=tf.newTransformer (); /获取Transformser对象的输出属性,亦即XSLT引擎的缺省输出属性,这是一个 /java.util.Properties对象。 Properties properties = t.getOutputProperties(); /设置新的输出属性:输出字符编码为GB2312,这样可以支持中文字符,XSLT引擎所输出 /的XML文档如果包含了中文字符,可以正常显示,不会出现所谓的“汉字问题“。 /请留意OutputK

12、eys类的字符串常数OutputKeys.ENCODING。 properties.setProperty(OutputKeys.ENCODING,“GB2312“); /更新XSLT引擎的输出属性。 t.setOutputProperties(properties); /调用XSLT引擎,按照输出属性中的设置,输出DOM Tree中的内容到输出介质中。 t.transform(DOMSource_Object,StreamResult_Object);,第12页,常用的输出属性,ublic static final java.lang.String METHOD 可以设为“xml“、“htm

13、l“、“text“等值。 public static final java.lang.String VERSION 所遵循规范的版本号,如果METHOD设为“xml“,那么它的值应该设为“1.0“,如果METHOD设为“html“,那么它的值应该设为“4.0“,如果METHOD设为“text“,那么这个输出属性会被忽略。 public static final java.lang.String ENCODING 设置输出时所采用的编码方式,比如“GB2312“、“UTF-8“等等,如果将其设置为“GB2312“,可以解决所谓的“汉字问题“。 public static final java.l

14、ang.String OMIT_XML_DECLARATION 设置输出到XML文档中时是否忽略XML声明,亦即类似于: 这样的代码。它可选的值有“yes“、“no“。 public static final java.lang.String INDENT IDENT设定XSLT引擎在输出XML文档时,是否自动添加额外的空格,它可选的值为“yes“、“no“。 public static final java.lang.String MEDIA_TYPE MEDIA_TYPE设定输出文档的MIME类型。,第13页,15-2-4 OutputKeys类,首先是获取XSLT引擎(Transform

15、er类)的缺省输出属性的集合,这需要使用Transformer类的getOutputProperties()方法,返回值是一个java.util.Properties对象。 Properties properties = transformer.getOutputProperties(); 然后是设定新的输出属性,比如: properties.setProperty(OutputKeys.ENCODING,“GB2312“); properties.setProperty(OutputKeys.METHOD,“html“); properties.setProperty(OutputKeys.

16、VERSION,“4.0“); 最后是更新XSLT引擎(Transformer类)的缺省输出属性的集合,这需要使用Transformer类的setOutputProperties()方法,参数是一个java.util.Properties对象。,第14页,15-2-5 使用Xalan XML Serializer,/首先创建一个DOMSource对象,该构造函数的参数可以是一个Document对象 /doc代表更改后的DOM Tree。 DOMSource domSource = new DOMSource (doc); /创建一个DOMResult对象,临时保存XSLT引擎的输出结果。 DOMResult domResult = new DOMResult(); /下面调用JAXP中的XSLT引擎来实现输出DOM Tree中的数据到XML文件中的功能。 /XSLT引擎的输入为DOMSource对象,输出为DOM

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号