一、项目介绍
题目要求
功能要求: 模拟福利彩票36选7,实现彩票的抽奖与中奖通知功能。
1.允许注册用户,用户信息包括用户id,用户名,密码,账户金额,电话号码等属性。
2.允许注册用户购买彩票:手动选号、随机选号,并允许设置投注数。
3.抽奖功能:要求屏幕上能够显示抽奖的号码滚动过程,按“停止”按钮给出抽奖结果。特等奖,7个号码全中。一等奖,6个号码全中。抽出号码后,显示中奖用户id,中奖的倍数。
4.彩票抽奖通知功能:抽出号码后,当用户登录系统后,系统提示是否中奖。
5.设计一自动注册用户(注册10万个)、并自动买彩票为用户买彩票的程序。然后模拟抽奖。
二、团队名称、团队成员介绍(需要有照片)
团队成员:
林羽晴 网络1513 学渣一枚
郭炜埕 网络1513 团支书
三、项目git地址
四、项目git提交记录截图(要体现出每个人的提交记录、提交说明),老师将点击进去重点考核。
五、项目功能架构图与主要功能流程图
思维导图
六、项目运行截图
登录账号密
随机选号或手动选号
显示用户信息
滚动抽奖并存入数据库
模拟注册和查看中奖用户的功能
七、项目关键代码(不能太多)
User.setPassword(NewPasswordField.getPassword());
User.setMoney(NewMoneyField.getText());
User.setTelnum(NewTelnumField.getText());
if(User.getUsername().length()==0){
JOptionPane.showMessageDialog(null, "请输入用户名!");
}else if(Arrays.toString(User.getPassword()).length()==0){
JOptionPane.showMessageDialog(null, "请输入密码!");
}else if(User.getMoney().length()==0){
JOptionPane.showMessageDialog(null, "请输入账户金额!");
}else if(User.getTelnum().length()==0){
JOptionPane.showMessageDialog(null, "请输入电话号码!");
}else{
JOptionPane.showMessageDialog(null, "新用户" + NewUserField.getText() + "注册成功!");
}
String strSql = "insert into userreserve(username,password,money,telnum) values(?,?,?,?)";
PreparedStatement prepare = null;
try {
Class.forName(driverName);
connection = DriverManager.getConnection(url, userName, password);
connection.setAutoCommit(false);
prepare = connection .prepareStatement(strSql);
prepare.setString(1,User.getUsername());
prepare.setString(2, Arrays.toString(User.getPassword()));
prepare.setString(3, User.getMoney());
prepare.setString(4, User.getTelnum());
prepare.addBatch();
prepare.executeBatch();
connection.commit();
}catch (SQLException sqlE) {
sqlE.printStackTrace();
}
}
private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {
ArrayList list = new ArrayList<>();
Random random = new Random();
int i = 0, num = 0;
while (i < 7) { //产生不重复的随机数并存入arraylist中
num = random.nextInt(35) + 1;
if (!list.contains(num)) {
list.add(num);
} else continue;
i++;
}
Num1Field.setText(list.remove(0) + "");
Num2Field.setText(list.remove(0) + "");
Num3Field.setText(list.remove(0) + "");
Num4Field.setText(list.remove(0) + "");
Num5Field.setText(list.remove(0) + "");
Num6Field.setText(list.remove(0) + "");
Num7Field.setText(list.remove(0) + "");
}
public void update() throws SQLException{
String strSql = "insert into userreserve(username,password,times,money,telnum,num1,num2,num3,num4,num5,num6,num7) values(?,?,?,?,?,?,?,?,?,?,?,?)";
Connection con = null;
PreparedStatement prepare = null;
ResultSet rs = null;
ArrayList list= new ArrayList();
try {
Class.forName(driverName); // 加载MySql的驱动程序
con = DriverManager.getConnection(url, userName, password);
con.setAutoCommit(false);
prepare = con.prepareStatement(strSql);
Statement statement=con.createStatement();
statement.executeUpdate("truncate table userreserve");//每次都要先清空
for (long i = 0; i < usernumber; i++) {
for (int k = 1; k <= 36; k++) {
list.add(k);
}
prepare.setString(1,(i+1)+"aaa");
prepare.setString(2, "[1, 2, 3]");
prepare.setInt(3,new Random().nextInt(10)+1);//设置随机倍数1-10
prepare.setString(4,"100");
prepare.setString(5,"1300");
for (int j = 0; j < 7; j++) {
int locat=new Random().nextInt(list.size());
prepare.setInt(j+6,list.remove(locat));//将随机产生的号码放入数据库
}
list.clear();
prepare.addBatch();
}
prepare.executeBatch();
con.commit();
} catch...
八、尚待改进或者新的想法
**由于测试自动注册10万的数据,所以每次注册都要先删除原先的数据库,则容易导致手动注册的用户信息丢失,要将抽奖和自动注册功能连接起来,注册用户时遇到相同账户时应如何解决;每个用户可购买多张彩票 **
九、团队成员任务分配,团队成员课程设计博客链接(以表格形式呈现),标明组长。
任务分配:
郭炜埕
用户端图形界面设计,创建User类、实现手动选号、随机选号、设置倍数及属性,买彩票消费金额和中奖奖金计算,数据库信息更新
header 1 | header 2
林羽晴
用户注册信息的存储,登录的匹配,通知中奖的功能,管理员界面设计,要求4和要求5,数据库创建