java程序设计 彩票购买抽奖程序 团队博客

一、项目介绍

题目要求

功能要求: 模拟福利彩票36选7,实现彩票的抽奖与中奖通知功能。

1.允许注册用户,用户信息包括用户id,用户名,密码,账户金额,电话号码等属性。

2.允许注册用户购买彩票:手动选号、随机选号,并允许设置投注数。

3.抽奖功能:要求屏幕上能够显示抽奖的号码滚动过程,按“停止”按钮给出抽奖结果。特等奖,7个号码全中。一等奖,6个号码全中。抽出号码后,显示中奖用户id,中奖的倍数。

4.彩票抽奖通知功能:抽出号码后,当用户登录系统后,系统提示是否中奖。

5.设计一自动注册用户(注册10万个)、并自动买彩票为用户买彩票的程序。然后模拟抽奖。

二、团队名称、团队成员介绍(需要有照片)

团队成员:

  • 林羽晴 网络1513 学渣一枚

  • 郭炜埕 网络1513 团支书

三、项目git地址

https://git.oschina.net/vicheng/caipiaogoumaichoujiangchengxu.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<Integer> 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<Integer> list= new ArrayList<Integer>();
        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,数据库创建
posted @ 2017-06-24 09:39  Linyq  阅读(2240)  评论(6编辑  收藏  举报