我正在开发一个应用程序需要生成特定于用户的电子邮件的功能。这将在用户级别使用电子邮件模板进行设置或配置,该电子邮件模板基本上包含SQL查询,列模型,数据类型,主题,页眉,页脚等。模板用作电子邮件的数据集和布局。
现在使用这个XML模板我需要生成HTML电子邮件。应用程序将读取XML,执行SQL查询,然后将结果集与列模型匹配。超出此;是否有任何框架或API可以帮助从Java对象生成HTML响应(格式良好的css表),或者必须使用原始HTML标记(等)来烹饪?
我还在研究BIRT或Jasper是否可以提供HTML响应,但似乎并非它们的意思。如果有人有为这种用例构建解决方案的经验,请告诉我。
答案 0 :(得分:11)
看看Thymeleaf。它是一个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。
通过Jasper
答案 1 :(得分:-1)
您可以使用XSLT将XML转换为HTML。 SQL查询的结果必须事先作为XML插入。