3

我正在开发应用程序需要生成用户特定电子邮件的功能。这将使用电子邮件模板在用户级别进行设置或配置,该模板基本上包含 SQL 查询、列模型、数据类型、主题、页眉、页脚等。该模板用作电子邮件的数据集和布局。

现在使用这个 XML 模板,我需要生成 HTML 电子邮件。应用程序将读取 XML,执行 SQL 查询,然后将结果集与列模型匹配。超出此; 是否有任何框架或 API 可以帮助从 Java 对象生成 HTML 响应(格式良好的 css 表),或者必须使用原始 HTML 标签(等)进行烹饪?

我也在研究 BIRT 或 Jasper 是否可以提供 HTML 响应,但它们似乎不是为此而设计的。如果有人有为此类用例构建解决方案的经验,请告诉我。

4

2 回答 2

11

看看百里香。它是一个 HTML 模板引擎。

就这么简单:

ClassLoaderTemplateResolver resolver = new ClassLoaderTemplateResolver();
resolver.setTemplateMode("HTML5");
resolver.setSuffix(".html");
TemplateEngine templateEngine = new TemplateEngine();
templateEngine.setTemplateResolver(resolver);
final Context context = new Context(Locale.CANADA);
String name = "John Doe";
context.setVariable("name", name); 
// add more objects from your ResultSet

final String html = templateEngine.process("myhtml", context);

使用 myhtml.html 文件:

<!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-3.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:th="http://www.thymeleaf.org">
<head>
    <title>My first template with Thymeleaf</title>
</head>
<body>
    <p th:text="${name}">A Random Name</p> 
</body>
</html>

在这里,占位符会将元素中的值${name}替换为您在.A Random Name<p>context

至于您读取和生成表格的要求,Thymeleaf提供构造以根据需要循环多次(即,只要您有剩余数据)。例子:

<tr th:each="prod : ${allProducts}">

将遍历allProducts,在每次迭代时将每个对象分配给变量prod。查看教程和文档了解更多信息。

请注意,您必须自己编写 HTML。

看看这个答案以通过生成 HTML 报告Jasper

于 2013-04-15T21:03:58.870 回答
-1

您可以使用 XSLT 将 XML 转换为 HTML。您的 SQL 查询结果必须预先作为 XML 插入。

于 2013-04-15T21:07:35.773 回答