如何使用Java制作简单的在线投票应用

答案:Java通过Servlet处理请求、JSP展示页面、MySQL存储数据实现在线投票。1. 使用Maven搭建Web项目,配置web.xml并引入Servlet依赖;2. 设计votes表存储选项与票数,编写VoteDAO类通过JDBC操作数据库;3. 创建DisplayVoteServlet加载投票数据并转发至JSP页面,SubmitVoteServlet接收投票并更新数据库;4. JSP页面展示投票选项与实时结果,用户提交后重定向回展示页。部署至Tomcat即可访问,后续可扩展防重复投票、图表统计等功能。

要制作一个简单的在线投票应用,Java可以配合Servlet、JSP和数据库(如MySQL)来实现基本的前后端交互和数据存储。整个过程不复杂,重点在于理解用户请求处理、数据持久化和页面展示的流程。

1. 搭建基础项目结构

使用Java EE技术栈,推荐使用Maven项目管理工具创建Web应用。

  • 创建一个Dynamic Web Project或Maven Web App
  • WEB-INF目录下添加web.xml(Servlet配置文件)
  • 将Servlet API依赖加入项目(Tomcat自带或通过Maven引入)
  • 准备JSP页面用于展示投票选项和结果

2. 设计投票数据模型与数据库表

用MySQL存储投票选项和票数。例如创建一张votes表:

CREATE TABLE votes (
  id INT PRIMARY KEY AUTO_INCREMENT,
  option_name VARCHAR(50) NOT NULL,
  vote_count INT DEFAULT 0
);

插入几个初始选项:

INSERT INTO votes (option_name) VALUES ('Java'), ('Python'), ('JavaScript');

在Java中使用JDBC连接数据库,定义一个DAO类(如VoteDAO)来封装增删改查操作。

3. 编写Servlet处理投票逻辑

创建两个Servlet:

  • DisplayVoteServlet:从数据库读取选项和票数,转发到JSP页面展示
  • SubmitVoteServlet:接收用户提交的选项ID,更新对应票数

示例代码片段(SubmitVoteServlet部分):

protected void doPost(HttpServletRequest request, HttpServletResponse response)
    throws IOException {
  int optionId = Integer.parseInt(request.getParameter("option"));

  VoteDAO dao = new VoteDAO();
  dao.incrementVote(optionId); // 更新数据库中的票数

  response.sendRedirect("display"); // 重定向回展示页
}

4. 使用JSP展示投票界面

index.jsp或由Servlet转发的页面中显示投票表单和当前结果:

<% List options = (List) request.getAttribute("options"); for (VoteOption opt : options) { %> <%= opt.getName() %> (<%= opt.getVoteCount() %> 票)
<% } %>

确保在DisplayVoteServlet中查询数据并存入request域:

request.setAttribute("options", dao.getAllOptions());
request.getRequestDispatcher("vote.jsp").forward(request, response);

基本上就这些。部署到Tomcat后访问首页就能进行投票。功能可以后续扩展,比如防止重复投票(用Session或Cookie)、添加图表展示、支持多题投票等。核心是理清请求流转和数据同步的过程。