在Javaservlet中打印XSLT转换的XML文档
我正在尝试使用Javaservlet(GlassFish服务器)打印转换后的XML文档。我从外部网站获取xml,用XSLT转换它,然后尝试打印转换后的文档。我相信XSL文件的格式是正确的,并且正在执行有效的转换在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 *
/*
* 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’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’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’s Aam Aadmi Party Sweeps Elections in Delhi</li>
<li>World Briefing: New DNA Tests Ordered in Argentine Prosecutor’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’s Defense: He Didn’t Know Prostitutes Were at the Orgies</li>
<li>At War Blog: For Many Veterans, ‘American Sniper,’ 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 logbuffer.toString()
查看输出。
response.setContentType("text/xml");