原文: http://zetcode.com/articles/javaservletjquerylist/

在 Java Servlet JQuery 列表教程中,我们展示了如何使用 JQuery 从 Java servlet 中获取数据并将其显示在 HTML 列表中。 我们使用 Gson 库处理 JSON 数据格式。 该 Web 应用已部署在 Tomcat 服务器上。

Apache Tomcat 是由 Apache 软件基金会(ASF)开发的开源 Java Servlet 容器。 它是最流行的 Java Web 服务器。

Java Servlet

Servlet 是 Java 类,可响应特定类型的网络请求-最常见的是 HTTP 请求。 Java servlet 用于创建 Web 应用。 它们在 servlet 容器(例如 Tomcat 或 Jetty)中运行。 现代 Java Web 开发使用在 servlet 之上构建的框架。

JSON 格式

JSON(JavaScript 对象表示法)是一种轻量级的数据交换格式。 人类很容易读写,机器也很容易解析和生成。 与 XML 相比,它不那么冗长且更具可读性。 JSON 的官方 Internet 媒体类型为application/json。 JSON 文件扩展名是.json。 JSON 可直接由 JavaScript 使用。

Gson

Gson 是一个开放源代码 Java 库,用于将 Java 对象序列化和反序列化到 JSON 或从 JSON 反序列化。 Gson 由 Google 创建。

Java servlet JQuery 列表示例

以下 Web 应用使用 Java Servlet 将数据(城市列表)以 JSON 格式发送到客户端。 JQuery 用于执行请求并动态构建 HTML 列表。

  1. ├── pom.xml
  2. └── src
  3. ├── main
  4. ├── java
  5. └── com
  6. └── zetcode
  7. ├── bean
  8. └── City.java
  9. ├── service
  10. └── CityService.java
  11. └── web
  12. └── GetCities.java
  13. ├── resources
  14. └── webapp
  15. ├── index.html
  16. ├── META-INF
  17. └── context.xml
  18. └── WEB-INF
  19. └── test
  20. └── java

这是项目结构。

pom.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
  5. http://maven.apache.org/xsd/maven-4.0.0.xsd">
  6. <modelVersion>4.0.0</modelVersion>
  7. <groupId>com.zetcode</groupId>
  8. <artifactId>JavaServleJqueryList</artifactId>
  9. <version>1.0-SNAPSHOT</version>
  10. <packaging>war</packaging>
  11. <name>JavaServleJqueryList</name>
  12. <properties>
  13. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  14. <maven.compiler.source>1.8</maven.compiler.source>
  15. <maven.compiler.target>1.8</maven.compiler.target>
  16. </properties>
  17. <dependencies>
  18. <dependency>
  19. <groupId>javax.servlet</groupId>
  20. <artifactId>javax.servlet-api</artifactId>
  21. <version>3.1.0</version>
  22. <scope>provided</scope>
  23. </dependency>
  24. <dependency>
  25. <groupId>com.google.code.gson</groupId>
  26. <artifactId>gson</artifactId>
  27. <version>2.8.0</version>
  28. </dependency>
  29. </dependencies>
  30. <build>
  31. <plugins>
  32. <plugin>
  33. <groupId>org.apache.maven.plugins</groupId>
  34. <artifactId>maven-war-plugin</artifactId>
  35. <version>2.3</version>
  36. <configuration>
  37. <failOnMissingWebXml>false</failOnMissingWebXml>
  38. </configuration>
  39. </plugin>
  40. </plugins>
  41. </build>
  42. </project>

这是 Maven POM 文件。 我们有两个工件:用于 Java servlet 的javax.servlet-api和用于 Java JSON 处理的gsonmaven-war-plugin负责收集 Web 应用的所有工件依赖项,类和资源,并将它们打包到 Web 应用存档(WAR)中。

context.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <Context path="/JavaServleJqueryList"/>

在 Tomcat context.xml文件中,我们定义了上下文路径。 它是 Web 应用的名称。

City.java

  1. package com.zetcode.bean;
  2. import com.google.gson.annotations.Expose;
  3. public class City {
  4. private Long id;
  5. @Expose
  6. private String name;
  7. @Expose
  8. private int population;
  9. public City() {
  10. }
  11. public City(Long id, String name, int population) {
  12. this.id = id;
  13. this.name = name;
  14. this.population = population;
  15. }
  16. public Long getId() {
  17. return id;
  18. }
  19. public void setId(Long id) {
  20. this.id = id;
  21. }
  22. public String getName() {
  23. return name;
  24. }
  25. public void setName(String name) {
  26. this.name = name;
  27. }
  28. public int getPopulation() {
  29. return population;
  30. }
  31. public void setPopulation(int population) {
  32. this.population = population;
  33. }
  34. @Override
  35. public String toString() {
  36. return "City{" + "id=" + id + ", name=" + name +
  37. ", population=" + population + '}';
  38. }
  39. }

这是City bean。 它具有三个属性:id,名称和人口。 Gson 的@Expose批注指示应公开哪些成员以进行 JSON 序列化或反序列化。 在我们的例子中,我们忽略了 ID,因为它与客户无关。 这样我们可以节省一些带宽。

GetCities.java

  1. package com.zetcode.web;
  2. import com.google.gson.Gson;
  3. import com.google.gson.GsonBuilder;
  4. import com.zetcode.bean.City;
  5. import com.zetcode.service.CityService;
  6. import java.io.IOException;
  7. import java.io.PrintWriter;
  8. import java.util.List;
  9. import javax.servlet.ServletException;
  10. import javax.servlet.annotation.WebServlet;
  11. import javax.servlet.http.HttpServlet;
  12. import javax.servlet.http.HttpServletRequest;
  13. import javax.servlet.http.HttpServletResponse;
  14. @WebServlet(name = "GetCities", urlPatterns = {"/GetCities"})
  15. public class GetCities extends HttpServlet {
  16. @Override
  17. protected void doGet(HttpServletRequest request, HttpServletResponse response)
  18. throws ServletException, IOException {
  19. response.setContentType("application/json;charset=UTF-8");
  20. try (PrintWriter out = response.getWriter()) {
  21. List<City> cities = CityService.getCities();
  22. Gson gson = new GsonBuilder()
  23. .excludeFieldsWithoutExposeAnnotation()
  24. .create();
  25. out.print(gson.toJson(cities));
  26. }
  27. }
  28. }

这是GetCities servlet。 它从服务类检索数据,并将它们以 JSON 格式返回给客户端。

  1. response.setContentType("application/json;charset=UTF-8");

我们将响应对象的内容类型设置为application/json

  1. try (PrintWriter out = response.getWriter()) {

我们得到了PrintWriter,用于将字符文本发送到客户端。

  1. List<City> cities = CityService.getCities();

CityService中,我们可以获得城市列表。

  1. Gson gson = new GsonBuilder()
  2. .excludeFieldsWithoutExposeAnnotation()
  3. .create();

我们创建并配置Gson类,这是使用 Gson 的主要类。 excludeFieldsWithoutExposeAnnotation()启用@Expose批注。

  1. out.print(gson.toJson(cities));

使用toJson()方法,我们将 Java 列表转换为 JSON 数组。 数组被写入编写器。 数组未命名。

CityService.java

  1. package com.zetcode.service;
  2. import com.zetcode.bean.City;
  3. import java.util.ArrayList;
  4. import java.util.List;
  5. public class CityService {
  6. public static List<City> getCities() {
  7. List<City> cities = new ArrayList<>();
  8. cities.add(new City(1L, "Bratislava", 432000));
  9. cities.add(new City(2L, "Budapest", 1759000));
  10. cities.add(new City(3L, "Prague", 1280000));
  11. cities.add(new City(4L, "Warsaw", 1748000));
  12. cities.add(new City(5L, "Los Angeles", 3971000));
  13. cities.add(new City(6L, "New York", 8550000));
  14. cities.add(new City(7L, "Edinburgh", 464000));
  15. cities.add(new City(8L, "Berlin", 3671000));
  16. return cities;
  17. }
  18. }

CityServicegetCities()方法返回城市对象的列表。

index.html

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Start Page</title>
  5. <meta charset="UTF-8">
  6. <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
  7. </head>
  8. <body>
  9. <button id="mybtn">Get cities</button>
  10. <div>
  11. <ul id="output">
  12. </ul>
  13. </div>
  14. <script>
  15. $('#mybtn').click(function () {
  16. $.getJSON('GetCities', function (data) {
  17. $("ul#output > li").remove();
  18. $.each(data, function (key, value) {
  19. $("#output").append('<li>' + value['name'] + " " + value['population'] + '</li>');
  20. });
  21. });
  22. });
  23. </script>
  24. </body>
  25. </html>

这是主页。

  1. <script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>

我们包括 JQuery 库。

  1. <button id="mybtn">Get cities</button>

该按钮执行请求。

  1. <div>
  2. <ul id="output">
  3. </ul>
  4. </div>

返回的数据将被写入这些元素内。

  1. $('#mybtn').click(function () {
  2. $.getJSON('GetCities', function (data) {
  3. $("ul#output > li").remove();
  4. $.each(data, function (key, value) {
  5. $("#output").append('<li>' + value['name'] + " " + value['population'] + '</li>');
  6. });
  7. });
  8. });

我们为按钮添加一个点击事件处理器。 $.getJSON()方法使用 GET HTTP 请求从GetCities Servlet 加载 JSON 编码的数据。 使用remove()方法,我们删除以前的元素(如果存在)。 使用$.each(),我们遍历 JSON 数据并将其附加到<li>标签内部的输出中。

Java Servlet JQuery 列表教程 - 图1

图:Java Servlet JQuery 列表示例

在图中,我们可以看到 HTML 列表中的数据:城市及其人口。

在本教程中,我们使用了 JQuery 从 Java servlet 获取 JSON 数据并构建 HTML 列表。

您可能也对以下相关教程感兴趣: Gson 教程Java servlet JSON 教程从 Java Servlet 提供纯文本Java servlet 复选框教程Java servlet 图像教程Java Servlet HTTP 标头Java 教程