在Javaservlet中打印XSLT转换的XML文档

在Javaservlet中打印XSLT转换的XML文档,java,xml,servlets,xslt,glassfish,Java,Xml,Servlets,Xslt,Glassfish,我正在尝试使用Javaservlet(GlassFish服务器)打印转换后的XML文档。我从外部网站获取xml,用XSLT转换它,然后尝试打印转换后的文档。我相信XSL文件的格式是正确的,并且正在执行有效的转换 /* * To change this license header, choose License Headers in Project Properties. * To change this template file, choose Tools | Templates *

我正在尝试使用Javaservlet(GlassFish服务器)打印转换后的XML文档。我从外部网站获取xml,用XSLT转换它,然后尝试打印转换后的文档。我相信XSL文件的格式是正确的,并且正在执行有效的转换

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import java.io.*;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.servlet.*;

import javax.xml.transform.Source;
import javax.xml.transform.stream.StreamSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.transform.Result;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;

/**
 *
 * @author Kirie
 */
public class getArticles extends HttpServlet {

    /**
     * Processes requests for both HTTP <code>GET</code> and <code>POST</code>
     * methods.
     *
     * @param request servlet request
     * @param response servlet response
     * @throws ServletException if a servlet-specific error occurs
     * @throws IOException if an I/O error occurs
     */
    protected void processRequest(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException, TransformerConfigurationException, TransformerException {
        response.setContentType("text/html;charset=UTF-8");
        try (PrintWriter out = response.getWriter()) {


            // get the xsl stored in this project 
            ServletContext context = getServletContext();                       
            InputStream xsl = (InputStream)
                                (context.getResourceAsStream("/XSLTransformerCode.xsl"));

            // We need two source objects and one result
            // get an external xml document using a url in a 
            // string format
            String topic = request.getParameter("topic");
            String urlAsString = "";
            if(topic.equals("Business"))
                urlAsString = "http://rss.nytimes.com/services/xml/rss/nyt/Business.xml";
            else if(topic.equals("Technology"))
                urlAsString = "http://rss.nytimes.com/services/xml/rss/nyt/Technology.xml";
            else if(topic.equals("World"))
                urlAsString = "http://rss.nytimes.com/services/xml/rss/nyt/World.xml";

            Source xmlDoc =  new StreamSource(urlAsString);
            Source xslDoc =  new StreamSource(xsl);
            Result result =  new StreamResult(out);         

            // Prepare to transform 


            // The transformed document is returned to the browser.
           TransformerFactory factory = TransformerFactory.newInstance();
            Transformer trans = factory.newTransformer(xslDoc);
            trans.transform(xmlDoc,result);

            out.println(result.toString());

        }
    }

    // <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">
    /**
     * Handles the HTTP <code>GET</code> method.
     *
     * @param request servlet request
     * @param response servlet response
     * @throws ServletException if a servlet-specific error occurs
     * @throws IOException if an I/O error occurs
     */
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        try {
            processRequest(request, response);
        } catch (TransformerException ex) {
            Logger.getLogger(getArticles.class.getName()).log(Level.SEVERE, null, ex);
        }
    }

    /**
     * Handles the HTTP <code>POST</code> method.
     *
     * @param request servlet request
     * @param response servlet response
     * @throws ServletException if a servlet-specific error occurs
     * @throws IOException if an I/O error occurs
     */
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        try {
            processRequest(request, response);
        } catch (TransformerException ex) {
            Logger.getLogger(getArticles.class.getName()).log(Level.SEVERE, null, ex);
        }
    }

    /**
     * Returns a short description of the servlet.
     *
     * @return a String containing servlet description
     */
    @Override
    public String getServletInfo() {
        return "Short description";
    }// </editor-fold>

}
这是执行转换的servlet。您可以从上面指定的URL访问XML文档。它们是RSS提要

 <?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet  version="1.0"
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
>

  <xsl:output method="xml" 
        omit-xml-declaration="yes"
        doctype-system="http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"
        doctype-public="-//W3C//DTD XHTML 1.0 Strict//EN"/>

    <xsl:template match="/">
    <html><head></head>
    <body>
    <h1>News Articles</h1>
    <ul>
        <xsl:for-each select = "rss/channel/item">
        <li>
            <xsl:value-of select = "title"/>
        </li>
        </xsl:for-each>
    </ul>
    </body>
    </html>
</xsl:template>
</xsl:stylesheet>

新闻文章
这是我用来转换文件的XSL文件。不幸的是,我不知道问题出在哪里。我试图把事情弄清楚,但我似乎做不到。任何意见都会很有帮助,我们将不胜感激。我将在线一段时间,以便能够回答问题

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<META http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body>
<h1>News Articles</h1>
<ul>
<li>Obama to Seek War Power Bill From Congress, to Fight ISIS</li>
<li>Kayla Mueller&rsquo;s Parents Are Said to Receive Photos of Her Corpse From ISIS</li>
<li>Towers of Secrecy: Mexican Political Family Has Close PRI Ties, and Homes in the U.S.</li>
<li>Jordan and Emirates Carry Out Airstrikes in Syria Against Islamic State</li>
<li>Australia Holds 2 in Terrorism Case</li>
<li>Bangkok Journal: In Thailand, the Ghost Business Thrives</li>
<li>Open Source: On YouTube, Vivid Evidence of War&rsquo;s Horror in Ukraine</li>
<li>Terrorist Claims Return Sept. 11 Suit to Spotlight</li>
<li>Obama to Recall Military Personnel From Ebola Zone, Officials Say</li>
<li>Agreement on Ukraine Cease-Fire Deal Is Reported</li>
<li>Venezuela Announces Plan to Relax Currency Controls</li>
<li>India&rsquo;s Aam Aadmi Party Sweeps Elections in Delhi</li>
<li>World Briefing: New DNA Tests Ordered in Argentine Prosecutor&rsquo;s Death</li>
<li>Robert Herzstein, 74, Dies; Historian Linked a U.N. Leader to War Crimes</li>
<li>Niger Adds Its Troops to the War on Boko Haram</li>
<li>Yemeni Militant Leader Pledges to Share Power</li>
<li>Dominique Strauss-Kahn&rsquo;s Defense: He Didn&rsquo;t Know Prostitutes Were at the Orgies</li>
<li>At War Blog: For Many Veterans, &lsquo;American Sniper,&rsquo; Right or Wrong, Starts an Important Conversation</li>
<li>Battered Ukrainian City of Mariupol Braces for Worst as Rebels Close In</li>
<li>Sinosphere Blog: University President Sees Echoes of Cultural Revolution in New Campaign</li>
</ul>
</body>
</html>

新闻文章
  • 奥巴马将向国会寻求战争权力法案,以打击伊斯兰国
  • Kayla Mueller;据说她的父母从伊斯兰国那里收到了她的尸体照片
  • 秘密之塔:墨西哥政治家庭有着密切的关系,在美国有着自己的家
  • 约旦和阿联酋在叙利亚对伊斯兰国进行空袭
  • 澳大利亚对两起恐怖主义案件进行了调查
  • 曼谷日报:在泰国,鬼魂行业蓬勃发展
  • 开源:在YouTube上,战争的生动证据;乌克兰的恐怖
  • 恐怖分子声称9月11日诉讼再次成为焦点
  • 官员说,奥巴马将召回埃博拉地区的军事人员
  • 乌克兰停火协议被报道
  • 委内瑞拉宣布放宽货币管制计划
  • 印度;s Aam Aadmi党在德里横扫选举
  • 世界简报:阿根廷检察官下令进行新的DNA检测;死亡
  • 74岁的罗伯特·赫茨斯坦去世;历史学家将一位联合国领导人与战争罪行联系起来
  • 尼日尔向博科圣地增兵
  • 也门武装分子领袖承诺分享权力
  • 多米尼克·斯特劳斯·卡恩;s的辩护:他没有;我不知道妓女在狂欢
  • 在战争博客上:对于许多退伍军人而言,“战争博客”;美国狙击手;无论是对是错,开始一次重要的谈话
  • 当叛军逼近时,遭受重创的乌克兰城市马里乌波尔面临最坏的情况
  • Sinosphere博客:大学校长在新运动中看到文化大革命的回声
我在一个普通的java应用程序中运行XSLT,并将结果转储到一个文件中。上面的HTML代码就是给出的结果

提前谢谢!
Kirie

您需要设置正确的内容类型标题

目前,浏览器试图将XML解释为HTML,因此不呈现任何内容



尝试将最后一行从
out.println(result.toString())更改
out.flush()
我认为这是不必要的,因为
transform()
也会通过
StreamResult
打印到
out
。此外,还可以将内容类型改回html。

当前的行为是什么?您没有看到任何输出?正确。加载servlet时没有输出。XSLT创建一个正确的HTML文档。我上传了(在问题中)对来自世界新闻RSS提要的XML运行XLST代码时的结果。它试图将内容类型设置为text/xml,并向我发送了以下消息:“此xml文件似乎没有任何与之关联的样式信息。文档树如下所示。”下面没有显示任何内容。有什么想法吗?你能把最后一行从
out.println(result.toString())改过来吗
out.flush()?我认为这是不必要的,因为
transform()
也会通过
Result
打印到
out
。另外,我还想把内容类型改回html。out.flush()不会改变任何东西。我担心它没有正确地获取两个XSL文件或XML文件。您知道如何检查以确保正确检索这些资源吗?构造一个
StringWriter buffer=new StringWriter()
并将结果创建为
newstreamresult(buffer)
Post transformation log
buffer.toString()
查看输出。
response.setContentType("text/xml");