0

0

标题:Java Servlet 动态渲染 HTML 模板教程(基于占位符替换)

霞舞

霞舞

发布时间:2026-01-08 20:51:03

|

675人浏览过

|

来源于php中文网

原创

标题:Java Servlet 动态渲染 HTML 模板教程(基于占位符替换)

本文介绍如何使用 java servlet 读取 `.tpl` 模板文件,解析 url 参数(如 `id`),查询数据对象(如 pet),执行简单占位符替换(如 `{pet.name}`),并返回渲染后的 html 响应。无需第三方模板引擎,适合初学者快速上手。

要实现基于 .tpl 文件的轻量级服务端模板渲染,核心思路是:读取静态模板 → 提取请求参数 → 加载业务数据 → 替换占位符 → 输出 HTML 响应。下面以 index.tpl 为例,逐步构建一个完整、可运行的 Servlet 示例。

✅ 步骤一:准备模板文件与项目结构

将 index.tpl 放置于 Web 应用的 WEB-INF/templates/ 目录下(推荐,确保不被直接访问):

<!-- WEB-INF/templates/index.tpl -->
<html>
  <body>
    <h1>Pet profile - {pet.name}</h1>
    <p>Age: {pet.age}</p>
    <p>Type: {pet.type}</p>
  </body>
</html>
⚠️ 注意:切勿将模板放在 webapp/ 根目录下(如 webapp/index.tpl),否则用户可绕过 Servlet 直接访问原始模板,造成信息泄露或 XSS 风险。

✅ 步骤二:编写 Servlet(支持路径匹配与占位符替换)

假设你使用注解方式映射 /index.tpl 请求(Servlet 3.0+):

@WebServlet("/index.tpl")
public class TemplateServlet extends HttpServlet {
    private static final String TEMPLATE_BASE_PATH = "/WEB-INF/templates/";

    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        // 1. 解析请求参数
        String idParam = request.getParameter("id");
        if (idParam == null || idParam.trim().isEmpty()) {
            response.sendError(HttpServletResponse.SC_BAD_REQUEST, "Missing 'id' parameter");
            return;
        }

        long petId;
        try {
            petId = Long.parseLong(idParam.trim());
        } catch (NumberFormatException e) {
            response.sendError(HttpServletResponse.SC_BAD_REQUEST, "Invalid 'id'");
            return;
        }

        // 2. 查询宠物数据(此处模拟数据库查询)
        Pet pet = findPetById(petId);
        if (pet == null) {
            response.sendError(HttpServletResponse.SC_NOT_FOUND, "Pet not found");
            return;
        }

        // 3. 读取模板内容(使用 ServletContext 获取资源流,更安全可靠)
        ServletContext ctx = getServletContext();
        InputStream is = ctx.getResourceAsStream(TEMPLATE_BASE_PATH + "index.tpl");
        if (is == null) {
            throw new ServletException("Template not found: index.tpl");
        }
        String templateContent;
        try (Reader reader = new InputStreamReader(is, StandardCharsets.UTF_8)) {
            templateContent = IOUtils.toString(reader); // 使用 Apache Commons IO(推荐)
            // 若不用第三方库,可用 StringBuilder + BufferedReader 手动读取
        }

        // 4. 占位符替换(注意:生产环境建议用正则或专用模板引擎)
        String renderedHtml = templateContent
                .replace("{pet.name}", escapeHtml(pet.getName()))
                .replace("{pet.age}", String.valueOf(pet.getAge()))
                .replace("{pet.type}", escapeHtml(pet.getType()));

        // 5. 设置响应头并输出
        response.setContentType("text/html;charset=UTF-8");
        response.setCharacterEncoding("UTF-8");
        response.setStatus(HttpServletResponse.SC_OK);
        response.getWriter().write(renderedHtml);
        response.getWriter().flush();
    }

    // 模拟数据查询(实际中应调用 DAO 或 Service)
    private Pet findPetById(long id) {
        // 示例:返回硬编码数据,可根据需要对接数据库
        if (id == 1) return new Pet("Buddy", 3, "Dog");
        if (id == 2) return new Pet("Luna", 2, "Cat");
        return null;
    }

    // 简单 HTML 转义(防御 XSS)
    private String escapeHtml(String input) {
        if (input == null) return "";
        return input.replace("&", "&")
                    .replace("<", "<")
                    .replace(">", ">")
                    .replace("\"", """)
                    .replace("'", "&#x27;");
    }
}

? 关键说明

歌者PPT
歌者PPT

歌者PPT,AI 写 PPT 永久免费

下载

立即学习Java免费学习笔记(深入)”;

  • 使用 ServletContext.getResourceAsStream() 比 Files.readAllBytes(Paths.get(...)) 更规范,能正确处理 WAR 包内路径;
  • IOUtils.toString() 来自 commons-io(Maven 依赖 <groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.11.0</version>),若不想引入依赖,可用标准 BufferedReader 替代;
  • 所有动态插入的字段必须进行 HTML 转义(如 escapeHtml()),否则用户输入 <script>alert(1)</script> 将导致 XSS 漏洞;
  • 当前为线性字符串替换,仅适用于简单场景;复杂逻辑(条件、循环)请升级至 ThymeleafFreemarkerJSP

✅ 步骤三:定义 Pet 模型类(Java Bean)

public class Pet {
    private final String name;
    private final int age;
    private final String type;

    public Pet(String name, int age, String type) {
        this.name = name;
        this.age = age;
        this.type = type;
    }

    // getters only
    public String getName() { return name; }
    public int getAge() { return age; }
    public String getType() { return type; }
}

✅ 最终效果

访问:http://localhost:8080/your-app/index.tpl?id=1
→ Servlet 加载 index.tpl,查得 Pet("Buddy", 3, "Dog"),渲染后返回:

<html>
  <body>
    <h1>Pet profile - Buddy</h1>
    <p>Age: 3</p>
    <p>Type: Dog</p>
  </body>
</html>

✅ 总结:本方案以最小依赖实现模板驱动的动态页面,兼顾安全性(路径隔离 + HTML 转义)与可维护性。随着业务增长,建议平滑迁移至成熟模板引擎——但对学习 Servlet 生命周期与基础 I/O 处理而言,这是极佳的入门实践。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Java Maven专题
Java Maven专题

本专题聚焦 Java 主流构建工具 Maven 的学习与应用,系统讲解项目结构、依赖管理、插件使用、生命周期与多模块项目配置。通过企业管理系统、Web 应用与微服务项目实战,帮助学员全面掌握 Maven 在 Java 项目构建与团队协作中的核心技能。

0

2025.09.15

servlet生命周期
servlet生命周期

Servlet生命周期是指Servlet从创建到销毁的整个过程。本专题为大家提供servlet生命周期的各类文章,大家可以免费体验。

393

2023.08.08

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

651

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1204

2024.04.29

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.3万人学习

Java 教程
Java 教程

共578课时 | 81.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号