返回顶部
首页 > 资讯 > 后端开发 > Python >javaweb实现投票系统
  • 527
分享到

javaweb实现投票系统

2024-04-02 19:04:59 527人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

本文实例为大家分享了javaweb实现投票系统的具体代码,供大家参考,具体内容如下 这次给大家带来一个课堂基础作业,简单的javaWEB投票系统。 当然也设计了添加投票人的接口,只

本文实例为大家分享了javaweb实现投票系统的具体代码,供大家参考,具体内容如下

这次给大家带来一个课堂基础作业,简单的javaWEB投票系统。

当然也设计了添加投票人的接口,只是list页面没有直接导航过去。
如页面显示,可以增加和减少相应的票数。同时id是利用数据库该字段作为主键自增的。 name 和头像都是上传的,由Mysql数据库存储照片名然后再自动寻找到。票数是直接由user_votes存储使用。

接下来带来关键代码。

//这是类User_list
package com.example.user_votes;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.Http.httpservletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Driver;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

@WebServlet("/list")
public class User_list extends HelloServlet{
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //连接数据库,获取所有的用户信息
        //创建一个用户对象
        List<User> userlist = new ArrayList<User>();
        try {
            //        1.加载驱动程序
//            DriverManager.reGISterDriver(new com.mysql.cj.jdbc.Driver());
            Class.forName("com.mysql.cj.jdbc.Driver");
//        2.创建数据库连接
            String url = "jdbc:mysql://localhost:3306/java_test?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC";
            String jdbcuser = "root";
            String jdbcpwd = "500400";
            Connection conn = DriverManager.getConnection(url, jdbcuser, jdbcpwd);
//        3.创建语句对象
            Statement stmt = conn.createStatement();
//        4.执行sql
//                被注释的代码是插入数据
            String  sql ="SELECT * from user_votes";
            //动态操作
            ResultSet rows = stmt.executeQuery(sql);
//        5.处理结果 rows.next() 用于遍历rows对象集
            while(rows.next()){
                User user = new User();
                user.setId(rows.getInt("id"));
                user.setName(rows.getString("user_name"));
                user.setUrl(rows.getString("url"));
                user.setVotes(Integer.parseInt(rows.getString("votes")));
                userlist.add(user);

            }
//        6.关闭语句对象,数据库连接rows.close()关闭row对象集
            rows.close();
            stmt.clearBatch();
            conn.close();

        } catch (Exception e) {
            System.out.println("获取用户列表失败" + e.getMessage());
            e.printStackTrace();
        }

        //返回响应,以表格的方式显示所有用户
        resp.setContentType("text/html");
        resp.setCharacterEncoding("utf-8");
        PrintWriter out =resp.getWriter();
        out.println("<html><head><title>投票系统</title></head><body>");
        if (userlist.size()>0){
            out.println("<table>");
            out.println("<caption></caption>");
            out.println("<tr>");
            out.println("<th>id</th>");
            out.println("<th style=\"\n" +
                    " padding-left: 10px; text-align: left;\n" +
                    "\">Name</th>");
            out.println("<th>照片</th>");
            out.println("<th>votes</th>");
            out.println("<th>操作</th>");
            out.println("</tr>");
            for (User user:userlist){
                out.println("<tr>");
                out.println("<td>"+user.getId()+"</td>");
                out.println("<td>"+"&nbsp&nbsp&nbsp"+user.getName()+"</td>");
                out.println("<td><img width = '30px' height = '30px' src="+"/photo/"+user.getUrl()+".jpg"+"></td>");
                out.println("<td>"+"&nbsp&nbsp&nbsp"+user.getVotes()+"</td>");
                out.println("<td><a href=add?id="+user.getId()+"&votes="+user.getVotes()+">add</a> <a href=delete?id="+user.getId()+"&votes="+user.getVotes()+">删除</a></td>");
                out.println("</tr>");
            }
            out.println("</table>");
            out.println("");
        }else{
            out.println("暂无用户");
        }
        out.println();

        out.println("</body></html>

    } 

}

这一段是用于list页面的展示代码。
同时以下是增减票数的代码。

//这个是增加票数add
package com.example.user_votes;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;

@WebServlet("/add")
public class AddUserVotes extends HttpServlet {
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //解析表单数据,获取要添加的用户信
        //        解析请求
        req.setCharacterEncoding("utf-8");
        PrintWriter out = resp.getWriter();
        //使用自己写的User类
        User user = new User();
        user.setId(Integer.parseInt(req.getParameter("id")));
        user.setVotes(Integer.parseInt(req.getParameter("votes")));
//        连接数据库的操作

        try {
            //        1.加载驱动程序
            String driver = "com.mysql.cj.jdbc.Driver";
            Class.forName(driver).newInstance();
//        2.创建数据库连接
            String url = "jdbc:mysql://localhost:3306/java_test?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC";
            String jdbcuser = "root";
            String jdbcpwd = "500400";
            Connection conn = DriverManager.getConnection(url,jdbcuser,jdbcpwd);

//        3.创建语句对象
            //静态的mysql操作语句
//            Statement stmt = conn.createStatement();
//        4.执行sql
            String sql = "UPDATE user_votes SET votes = ? WHERE id = ?";
            PreparedStatement pstmt = conn.prepareStatement(sql);
            //动态操作
            int uservotes = user.getVotes()+1;
            pstmt.setInt(1,uservotes);
            pstmt.setInt(2,user.getId());
            int rows = pstmt.executeUpdate();
//        5.处理结果
            if(rows == 1){
                System.out.println("add成功为:"+uservotes);
            }
            else {
                System.out.println("add失败!");
            }
//        6.关闭语句对象,数据库连接
            pstmt.clearBatch();
            conn.close();

        } catch (Exception e) {
            System.out.println("添加用户失败"+e.getMessage());
            e.printStackTrace();
        };
        resp.setContentType("text/html;charset=UTF-8");
        resp.getWriter().println("<script>alert('投票成功!');window.location.href='list';</script>");

        //跳转到用户列表界面
        resp.sendRedirect("list");

    }
}

减少票数

package com.example.user_votes;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
@WebServlet("/delete")
public class DeleteUserVotes extends HelloServlet{
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //解析表单数据,获取要添加的用户信
        //        解析请求
        req.setCharacterEncoding("utf-8");
        PrintWriter out = resp.getWriter();
        //使用自己写的User类
        User user = new User();
        user.setId(Integer.parseInt(req.getParameter("id")));
        user.setVotes(Integer.parseInt(req.getParameter("votes")));
//        连接数据库的操作

        try {
            //        1.加载驱动程序
            String driver = "com.mysql.cj.jdbc.Driver";
            Class.forName(driver).newInstance();
//        2.创建数据库连接
            String url = "jdbc:mysql://localhost:3306/java_test?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC";
            String jdbcuser = "root";
            String jdbcpwd = "500400";
            Connection conn = DriverManager.getConnection(url,jdbcuser,jdbcpwd);

//        3.创建语句对象
            //静态的mysql操作语句
//            Statement stmt = conn.createStatement();
//        4.执行sql
            String sql = "DELETE FROM user_votes WHERE id = ?";
            PreparedStatement pstmt = conn.prepareStatement(sql);
            //动态操作
            pstmt.setInt(1,user.getId());
            int rows = pstmt.executeUpdate();
//        5.处理结果
            if(rows == 1){
                System.out.println("delete成功为:"+user.getId());
            }
            else {
                System.out.println("delete失败!");
            }
//        6.关闭语句对象,数据库连接
            pstmt.clearBatch();
            conn.close();

        } catch (Exception e) {
            System.out.println("添加用户失败"+e.getMessage());
            e.printStackTrace();
        };
        //跳转到用户列表界面
        resp.sendRedirect("list");
    }
}

添加参与投票的

package com.example.user_votes;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;

public class AddUser extends HelloServlet{
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //解析表单数据,获取要添加的用户信
        //        解析请求
        req.setCharacterEncoding("utf-8");
        PrintWriter out = resp.getWriter();
        //使用自己写的User类
        User user = new User();
        user.setName(req.getParameter("name"));
        user.setUrl(req.getParameter("url"));
        user.setVotes(0);
//        连接数据库的操作

        try {
            //        1.加载驱动程序
            String driver = "com.mysql.cj.jdbc.Driver";
            Class.forName(driver).newInstance();
//        2.创建数据库连接
            String url = "jdbc:mysql://localhost:3306/java_test?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC";
            String jdbcuser = "root";
            String jdbcpwd = "500400";
            Connection conn = DriverManager.getConnection(url,jdbcuser,jdbcpwd);

//        3.创建语句对象
            //静态的mysql操作语句
//            Statement stmt = conn.createStatement();
//        4.执行sql
            String sql = "INSERT INTO user_votes(user_name,url,votes) VALUES(?,?,?)\n";
            PreparedStatement pstmt = conn.prepareStatement(sql);
            //动态操作
            pstmt.setString(1,user.getName());
            pstmt.setString(2,user.getUrl());
            pstmt.setInt(3,user.getVotes());
            int rows = pstmt.executeUpdate();
//        5.处理结果
            if(rows == 1){
                System.out.println("add成功为:"+user.getName());
            }
            else {
                System.out.println("add失败!");
            }
//        6.关闭语句对象,数据库连接
            pstmt.clearBatch();
            conn.close();

        } catch (Exception e) {
            System.out.println("添加用户失败"+e.getMessage());
            e.printStackTrace();
        };
        //跳转到用户列表界面
        resp.sendRedirect("list");


    }
}

项目没有使用mvc项目结构,就是因为比较简单,因此如果有刚刚学习到这里的可以来看看,参考学习

附上项目目录图,其他的就没有过多的去介绍了,毕竟比较简单。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: javaweb实现投票系统

本文链接: https://lsjlt.com/news/167724.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • javaweb实现投票系统
    本文实例为大家分享了javaweb实现投票系统的具体代码,供大家参考,具体内容如下 这次给大家带来一个课堂基础作业,简单的javaweb投票系统。 当然也设计了添加投票人的接口,只...
    99+
    2024-04-02
  • PHP怎么实现投票系统
    本篇内容介绍了“PHP怎么实现投票系统”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、实现代码1.sql-- phpMyAdmi...
    99+
    2023-06-30
  • PHP实战之投票系统的实现
    目录一、实现代码1.sql2.html3.admin.php(增删改查投票的页面)密码:admi4.index.php投票的页面二、效果图一、实现代码 1.sql -- phpMy...
    99+
    2024-04-02
  • asp简单投票系统怎么实现
    要实现一个简单的ASP投票系统,可以按照以下步骤进行:1. 创建一个数据库表来存储投票相关的数据,例如投票主题、选项、投票结果等。2...
    99+
    2023-09-22
    asp
  • 如何在PHP中实现在线投票系统?
    在现代社会,投票已成为一种非常重要的行为,它与民主、公正、公平等价值观息息相关,其重要性无需多言。对于许多网站和公司来说,为了收集用户群体的意见和决策,实现在线投票系统变得越来越必要。在这篇文章中,我们将会深入探讨如何在PHP中实现一个高效...
    99+
    2023-05-14
    PHP 实现 在线投票系统
  • 微信投票小程序系统设计与实现
         项目背景和意义 目的:本课题主要目标是设计并能够实现一个基于微信小程序评选投票系统,前台用户使用小程序,后台管理使用基PHP+MySql的B/S架构;通过后台添加资讯、管理上传投票信息、用户管理等;用户通过小程序登录,发起投...
    99+
    2023-10-01
    小程序 微信 微信小程序
  • SpringBoot结合Vue实现投票系统过程详解
    目录一、前言介绍二、需求分析2.1系统功能结构2.2功能模块设计三、系统详细设计3.1系统登录界面3.2用户首页模块3.3参与投票模块四、管理员功能模块4.1主界面如下图所示4.2用...
    99+
    2024-04-02
  • js脚本如何编写刷票投票系统
    这篇文章主要介绍js脚本如何编写刷票投票系统,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下<!DOCTYPE html PUBLIC ...
    99+
    2024-04-02
  • 基于PHP+MySQL的在线投票系统设计与实现
    随着时代的发展,人们需要获取更多的信息和用户的意见,这时候就会产生一个投票。转托管模式都是人工发传单,然后填写来进行。但是随着互联网的发展,这种模式已经逐渐被淘汰,人们越来越希望通过更加方便快捷的方式...
    99+
    2023-10-01
    php 数据库 投票
  • 如何使用Go语言和Redis实现在线投票系统
    如何使用Go语言和Redis实现在线投票系统概述:在线投票系统是一个常见的应用场景,它可以用于各种场合,如选举、问卷调查、评选等。本文将介绍如何使用Go语言和Redis来实现一个简单的在线投票系统。我们将使用Go语言作为后端开发语言,Red...
    99+
    2023-10-26
    Go语言 redis 在线投票
  • 如何使用MySQL和Ruby实现一个简单的投票系统
    如何使用MySQL和Ruby实现一个简单的投票系统投票系统是一种常见的在线应用程序,用于收集用户对某个问题或主题的意见。在本文中,将介绍如何使用MySQL数据库和Ruby编程语言来实现一个简单的投票系统。首先,我们需要准备环境。确保已经安装...
    99+
    2023-10-22
    MySQL Ruby 投票系统
  • 基于php微信小程序评选投票系统设计与实现
    开发概要 开发操作系统:windows10 + 4G内存 + 500G 小程序开发:微信开发者工具(MINA框架) 后台环境:IIS +PHP 后台开发语言:PHP 后台开发工具:Dreamweaver +PhpStor...
    99+
    2023-08-31
    php 微信小程序 前端 Powered by 金山文档
  • JavaWeb实现学生管理系统
    JavaWeb实现学生管理系统 一、项目介绍二、项目结构三、前期准备1.配置maven环境,在pom.xml配置文件中配置项目所依赖的jar包2.在MySql数据库中,创建登录注册表login和学生信息表student(1)登录注册...
    99+
    2023-08-16
    servlet java 数据库
  • C++实现车票管理系统
    本文实例为大家分享了C++实现车票管理系统的具体代码,供大家参考,具体内容如下 一车站每天有n个发车班次,每个班次都有一班次号(1、2、3…n),固定的发车时间,固定的...
    99+
    2024-04-02
  • C++实现飞机订票系统
    本文实例为大家分享了C++实现飞机订票系统的具体代码,供大家参考,具体内容如下 // 飞机订票系统.cpp : 定义控制台应用程序的入口点。 // #include "stdafx...
    99+
    2024-04-02
  • 微信小程序毕业设计作品成品(03)在线投票小程序投票评选小程序系统设计与实现
    博主介绍:《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;专注大学生毕业设计教育和辅导。 所有项目都配有从入门到精通的基础知识视频课程,免费 项目配有对应开发文档、开题...
    99+
    2023-10-20
    小程序 微信小程序 大学生 投票小程序 评选小程序
  • 电影院订票售票系统设计与实现
        项目背景和意义   目的:本课题主要目标是设计并能够实现一个基于java的电影院订票选座系统,系统整体使用了基于java+MySql的B/S架构,技术上使用了springboot框架;使用浏览器,管理员通过后台添加电影、场次...
    99+
    2023-10-07
    java 开发语言
  • Javaweb实战之实现蛋糕订购系统
    目录视频展示1实验的目的及要求2需求分析2.1问题陈述2.2功能需求分析3总体设计3.1功能结构图设计3.2模块简介4详细设计4.1主模块详细设计4.2子模块详细设计5编码和测试5....
    99+
    2024-04-02
  • 如何使用redis制作投票系统的计数器
    这篇文章主要为大家详细介绍了如何使用redis制作投票系统的计数器,文中示例代码介绍的非常详细,零基础也能参考此文章,感兴趣的小伙伴们可以参考一下。校验首先,要对每个用户的投票数进行校验。用户每天都有3次投...
    99+
    2024-04-02
  • 基于JS实现一个简单的投票demo
    目录演示说明源码body设置js实现投票的动画css设定演示 说明 今天没有什么好的内容分享,跟大家讲一个标签吧增长姿势。 line-height CSS 属性用于设置多行元素的空...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作