• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Servlet 和 XML:互为补充(二)(转)

servlet/jsp 搞代码 7年前 (2018-06-18) 270次浏览 已收录 0个评论

清单 5. printDOMTree

    if (requestedSubtree.equalsIgnoreCase("author"))      printDOMTree(author, out);    else if (requestedSubtree.equalsIgnoreCase("lines"))      printDOMTree(lines, out);    else if (requestedSubtree.equalsIgnoreCase("title"))      printDOMTree(title, out);    else       printDOMTree(doc, out);

如果 subtree 参数是 author,则结果是:

  <author>    <last-name>Shakespeare</last-name>    <first-name>William</first-name>    <nationality>British</nationality>    <year-of-birth>1564</year-of-birth>    <year-of-death>1616</year-of-death>  </author>

如果 subtree 参数是 title,则结果是:

<title>Sonnet 130</title>

您可以查看完整清单的 html 视图或直接查看 java 源文件。
数据库对接
我们的最后一个示例是根据数据库查询生成 xml。有许多方法可做到这一点(请参阅 developerWorks 的文章 Generating XML from a Data Store);对于本例而言,我们将使用 IBM 的 XML Extender for DB2(请参阅参考资料)。这个免费产品使您能够在 DB2 中存储 XML 文档。我们的查询从 DB2 中提取这些文档,然后将其传送给用户。

http://www.gaodaima.com/42553.htmlServlet 和 XML:互为补充(二)(转)

如果您使用 oracle 8i 代替 DB2,您将会发现它自称具有类似的功能(请参阅参考资料)。对于不理解 XML 的数据库,您可以将 XML 文档存储为字符大对象 (CLOB),并以文本块的方式检索文档。
但是,在安装数据库以后,您需要完成以下三件事情才能使此代码工作:

  1. 首先,将 DbOwner、DbUserid 和 DbPasswd 变量改为适合系统的适当值。
       /////////////////////////////////////////////////////////////////       // 一定要正确更改这三个字符串,否则                            //   // servlet 不会工作。                                          //   /////////////////////////////////////////////////////////////////       DbUserid = "xxxxxxxx";   DbPasswd = "xxxxxxxx";   DbOwner = "xxxxxxxx";   
  2. 下一步,使用适合您的系统的 JDBC 驱动程序。我们在使用 DB2。
        static String JDBCDriver = "COM.ibm.db2.jdbc.app.DB2Driver";    ...    try    {      Class.forName("COM.ibm.db2.jdbc.app.DB2Driver").newInstance();    }    catch (Exception e)    {      System.out.println("Can't get the driver!"); e.printStackTrace();    }
  3. 如果你愿意,可以改掉下面的 SQL 查询语句。为了简化示例,此处仅检索 sales_order_view 表的 order 列中的全部 XML 文档。
        // 我们在此处对 SQL 语句进行硬编码;如果根据用户输入    // 限制查询,则情况会更为复杂。    String query = "select order from " + DbOwner + ".sales_order_view";

在 service 方法中,我们的 servlet 连接 DB2,执行一个查询(其结果为一组 XML 文档),分析查询结果,并将分析过的数据写入输出流中。清单 6 显示了与此关系最密切的代码部分:
清单 6. xmlfromdb2.java

    // 我们在此处对 SQL 语句进行硬编码;如果根据用户输入    // 限制查询,则情况会更为复杂。    String query = "select order from " + DbOwner + ".sales_order_view";    res.setContentType("text/xml");    try      {        ConInfo index = new ConInfo();        Connection con = getCon(index);        Statement stmt = con.createStatement();        ResultSet rs = stmt.executeQuery(query);        ...        // 显示结果集。我们从每行取出 XML 文档,        // 对其进行分析,然后打印 DOM 树。当没有更多的行时,rs.next() 返回        // false。        while (rs.next())          {             String nextOrder = rs.getString(1).trim();            Document doc = null;            StringReader sr = new StringReader(nextOrder);            InputSource iSrc = new InputSource(sr);                        try              {                parser.parse(iSrc);                doc = parser.getDocument();              }            catch (Exception e)              {                System.err.println("Sorry, an error occurred: " + e);              }                        if (doc != null)              printDOMTree(doc, out);          }

要了解全部细节,您可以查看完整清单的 HTML 视图或直接查看Java 源文件。
小结
尽管这些 servlet 示例中没有一个可以改变世界,但它们确实展示了 XML 和 servlet 配合得有多么好。Servlet 是向客户发送内容的一种伟大机制,而 XML 是发送结构化数据的一种完美机制。您还可以使用 servlet 处理服务器上的 XML 文档,并将它们的内容发送给客户机。最重要的是,这两种技术都是跨平台技术,可为您的应用程序带来更大的灵活性和可移值性。
参考资料

  • 了解有关 DB2 XML Extender 的详细信息。产品附带的文档中有一个深入的教程,它可帮助您将 XML 文档带入关系数据库的世界中。
  • 了解有关 Oracle 数据库产品的详细信息。
  • 试用 webSphere 附带的免费 servlet 教程。
  • 通过 developerWorks 的 XML programming in Java 教程深入研究如何分析 XML 文件。
  • 下载作者为 City Java 用户组制作的演示文稿的 PDF 版本。
  • http://www.gnu.org 网站学习使用 Emacs 彩色编码代码清单。HTMLize 程序包可从网址 jagor.srce.hr 获得。

欢迎大家阅读《Servlet 和 XML:互为补充(二)(转)》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Servlet 和 XML:互为补充(二)(转)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址