需求分析
(1)制作一个投票系统,让学生给自己喜爱的老师投票。该系统由投票界面组成,系统运行,投票界面出现,标题为“欢迎给老师投票”;在界面上有一个表格,显示了各位老师的编号、姓名、得票数;其中,得票数显示为一个红色的进度条,并显示得票的数值;表格的第四列是投票链接,单击链接,该教师的票数加1,并显示在界面上。
(2)实现上述功能后,可考虑进一步改进。如对数据库的封装以及重用代码等;
(3)进一步思考,考虑系统是否存在刷票的隐患,如何防止刷票。
项目源码:
https://download.youkuaiyun.com/download/qq_43299503/12037158
实验结果
投票界面:
第一次点击提交投票,界面会自动刷新票数:
第二次点击提交投票:投票失败界面——用于防止刷票(一个小时内只能投一票)
对数据库的封装以及重用代码
package db;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import com.mysql.jdbc.Connection;
import com.mysql.jdbc.Statement;
import dao.User;
import dao.Vote;
public class DB {
private String className;
private String url;
private String username;
private String password;
private Connection con;
private Statement st;
private ResultSet res;
public DB() {
className="com.mysql.jdbc.Driver";
url="jdbc:mysql://localhost:3306/votedb";
username = &#