首页 期权学习期权知识正文

java抽奖程序

xiaojiucai 期权知识 2020-08-17 663 0

一、项目介绍

题目要求

功能要求: 模拟福利彩票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,数据库创建





本文来源:https://www.cnblogs.com/lyq063/p/7072507.html

原文链接:https://www.qiquanji.com/post/8510.html

本站声明:网站内容来源于网络,如有侵权,请联系我们,我们将及时处理。

版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。