java课程设计报告-自动取款机模拟程序_第1页
java课程设计报告-自动取款机模拟程序_第2页
java课程设计报告-自动取款机模拟程序_第3页
java课程设计报告-自动取款机模拟程序_第4页
java课程设计报告-自动取款机模拟程序_第5页
已阅读5页,还剩49页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

学院计算机科学与技术系课程设计报告20142015学年第一学期课程 JAVA课程设计课程设计名称自动取款机模拟程序学生姓名 学号专业班级指导教师2014年9月自动取款机模拟程序一、 课程设计过程概述这次课程设计的主要目的是结合面向对象程序设计课程,培养我们面向对象软件开发的思维,初步了解软件开发的一般流程,提高用JAVA编程的实际动手能力并增强大家对面向对象的了解。这次课程设计的主要内容是独立用JAVA语言开发一个小的应用程序名称:自动取款机模拟程序内容:在PC机上设计一个自动取款机的模拟程序,实现现实中取款机的大部分功能。二、任务和要求1 程序分为两部分:管理端和客户端。2 管理端负责管理所有的银行卡,管理员可以增加和删除银行卡。(1) 每张银行卡由卡号唯一标识,卡号由9位阿拉伯数字组成;(2) 新增的银行卡密码均为“”,卡内金额均为0元;(3) 只有管理员增加的银行卡才能登陆客户端;(4) 删除后的银行卡将不能再登陆客户端。3 客户端负责常见的取款机操作。(1) 客户端需要登陆,用户输入正确的银行卡号和密码,系统核对无误后才能进行操作;(2) 登陆后,用户可以进行查询余额、取款、存款和修改密码的操作;(3) 修改密码时,用户需输入两次新密码,确定无误后方可更改;(4) 取款和存款操作,有操作结果提示,如“操作成功”或“余额不足,操作失败”等。三、数据库设计 程序中包括用户客户端和管理客户端,所以在数据库中需要设计用户信息表和管理员信息表分别来保存用户信息和管理员信息(数据库采用MySQL)。表1用户信息表(user)列名数据类型及长度是否为空主键默认值说明cardNumVarchar(12)NO主键用户帐号passwordInt(6)NO用户密码balanceInt(10)NO0余额表2管理员信息表(admin)列名数据类型及长度是否为空主键默认值说明adminNameVarchar(10)NO主键管理员帐号 passwordVarchar(10)NOadmin管理员密码四、系统设计1、设计框架图一 总体设计框架2、总体设计我所设计的ATM机主要是由登录页面模块还由选择服务模块组成,在登录时可选择用户登录或管理员登陆。其中用户的选择服务模块由取款模块、存款模块、查询余额模块、修改密码模块、退卡模块组成,管理员的选择服务模块由新建用户模块、删除用户模块、退出模块组成。其功能结构图如下所示:图二 用户模块设计框图图三 管理员模块设计框图3 、ATM取款机界面设计我觉得一个系统的界面应该要简单明了,当然样式美观就更好了。我设计的界面主要是由窗体组成,操作简单。而每一个窗口则执行相应的功能。一个系统界面的好坏直接影响到用户的操作,界面设计要求样式美观、简单明了、方便易操作。我设计的界面主要分为窗体、菜单、按钮和文本输入框几个部分,分别执行相应的操作。(1)窗体的设计窗体整个框架使用JFrame类构造,JFrame有自己的外边框和自己的标题,创建JFrame时可以指定其窗口标题,我创建的窗口标题是各个不同功能的模块的名字,比如说查询余额窗口,取款窗口等。(2)窗体的主要结构的设计我所设计的窗口的主要结构的特点就是每个窗口都对应着一个特定的功能。比如说报各种各样的错,还有各种查询余额、取款、选择服务等,所以它们都是由各种按钮和文本框,标签组成的,而联系各个窗体成为一个整体的就是各个按钮的监听事件,另外所有窗口布局均为网格布局。为了定义各个按钮所对应的命令和操作,首先需要将各个按钮注册给实现了动作事件的监听接口ActionListener的监听者,然后为监听者定义actionPerformed(ActionEvent e)方法,在这个方法中调用e.getSource()或e.getActionCommand()来判断用户点击的菜单子项,并完成这个菜单子项定义的操作。4 、各功能模块设计4.1 登录页面模块设计用户进入登录页面后要输入账号和密码,并选择相应的用户,点击确定后系统会通过连接数据库验证密码是否正确,在密码正确的情况下界面跳转到功能选择界面,否则弹出警告账号或密码错误窗口。图四 登录窗口/*用户登录 */private void generalUserLogon()String cardNum = userNameTxt.getText();String password = new String(passwordTxt.getPassword();if (StrUtil.isEmpty(cardNum) JOptionPane.showMessageDialog(null, 账号不能为空!);return;if (StrUtil.isEmpty(password) JOptionPane.showMessageDialog(null, 密码不能为空!);return;List users = new ArrayList();users = UserDao.select(select cardNum,password,balance from user where cardNum = ? and password = ? ;,cardNum, password);if (users.isEmpty() JOptionPane.showMessageDialog(null, 登录失败,账号或密码错误!);return; else this.dispose();SaveUserInfo.users = users;GeneralUserFrm generalUserFrm = new GeneralUserFrm();generalUserFrm.setVisible(true);界面我采用的是MyEclipse中的Swing插件所做,简单、方便、实用。文本区调用getText()方法,获取用户想要的字符串。因为要区分登录者是用户还是管理员,所以设置了两个JRadioButton来确定登录者的身份。当登录者选择的身份为用户时通过UserDao类驱动加载数据库,从用户表中获取相关信息并与用户输入信息比较,信息相符时登录成功,否则弹出警告窗口。部分源码如下;/* *管理员登录 */private void adminLogon()String adminName = userNameTxt.getText();String password = new String(passwordTxt.getPassword();if (StrUtil.isEmpty(adminName) JOptionPane.showMessageDialog(null, 账号不能为空!);return;if (StrUtil.isEmpty(password) JOptionPane.showMessageDialog(null, 密码不能为空!);return;List admins = new ArrayList();admins = UserDao.selectAdmin(select adminName,password from admin where adminName= ? and password = ? ;,adminName, password);if (admins.isEmpty() JOptionPane.showMessageDialog(null, 登录失败,账号或密码错误!);return; else this.dispose();SaveUserInfo.admins = admins;AdminFrm adminFrm = new AdminFrm();adminFrm.setVisible(true);4.2 选择服务模块设计在选择服务模块中,有各种ATM的服务功能,只要用户在该界面中选择按钮,它就会弹出各个相应的界面。每一个按钮都有监听器,在选择了按钮后,java.awt.event中的ActionEvent类创建一个事件对象,并将它传递给方法public void actionPerformed(ActionEvent e)中的参数e,监视器就会知道所发生的事件,对此事件进行处理。其中的部分源代码为:图五 主操作窗口/* * 查询余额 */private void b_queryBalanceActionPerformed(java.awt.event.ActionEvent evt) this.dispose();QueryBalanceFrm balanceFrm= new QueryBalanceFrm();balanceFrm.setVisible(true);/* * 存款 */private void jb_depositMoneyActionPerformed(java.awt.event.ActionEvent evt) this.dispose();DisposeMoneyFrm disposeMoneyFrm = new DisposeMoneyFrm();disposeMoneyFrm.setVisible(true);/* * 修改密码 */private void modifyPasswordActionPerformed(java.awt.event.ActionEvent evt) this.dispose();ModifyPasswordFrm modifyPasswordFrm = new ModifyPasswordFrm();modifyPasswordFrm.setVisible(true);/* * 取款 */private void jb_withdrawalMoneyActionPerformed(java.awt.event.ActionEvent evt) this.dispose();WithdrawMoneyFrm withdrawMoney = new WithdrawMoneyFrm();withdrawMoney.setVisible(true);/* * 退出系统 */private void jb_exitActionPerformed(java.awt.event.ActionEvent evt) int result = JOptionPane.showConfirmDialog(null, 是否要退出系统!);if (result = 0) this.dispose();4.3 取款模块设计当用户点击取款按钮时,可以输入取款金额进行取款,当用户输入的不是整百或者不是数字时,会提示用户重新输入正确的金额;该ATM只允许用取3W下金额,否则会提示用户到柜台去取。部分界面和源代码如下:图六 取款窗口/* * 确认取款事件 */private void jb_confirmActionPerformed(java.awt.event.ActionEvent evt) int balance = this.queryBalance();/调用取款方法,获得余额String cardNum = users.get(0).getCardNum();/获取用户卡号int withdrawMoney;if(StrUtil.isEmpty(jWithdrawMoneytxt.getText()/判断输入是否为空JOptionPane.showMessageDialog(null, 请输入金额!);return;else if(!InputJudge.isFigure(jWithdrawMoneytxt.getText()JOptionPane.showMessageDialog(null, 请输入金额!);setNull();/置空return;/ 获得取款金额withdrawMoney = Integer.parseInt(jWithdrawMoneytxt.getText()/将字符转换成数值/只能取面值100元int temp=withdrawMoney/100*100;if(tempbalance)JOptionPane.showMessageDialog(null, 余额不足!);this.setNull();elseif(temp=30000)JOptionPane.showMessageDialog(null, 请到柜台取款);setNull();else if(generalUser.withdrawingMoney(temp, balance, cardNum)/取款成功、更新数据库JOptionPane.showMessageDialog(null, 取款成功);this.setNull();elseJOptionPane.showMessageDialog(null, 取款失败!);this.setNull();/置空private void setNull() jWithdrawMoneytxt.setText();4.4 存款模块设计 当用户输入存款金额时,如果输入的不是正确的数字或者整百的金额,会提示用户重新输入;如果用户输入正确,则会提示用户存款成功。图七 存款窗口/* * 存款 * * param evt */private void jb_confirmActionPerformed(java.awt.event.ActionEvent evt) /存款金额int money;if (this.jDisposeMoneytxt.getText().isEmpty() money = 0;else if(!InputJudge.isFigure(jDisposeMoneytxt.getText()JOptionPane.showMessageDialog(null, 请输入正确的金额!);setNull();return; else money = Integer.parseInt(this.jDisposeMoneytxt.getText();int balance = this.queryBalance();String cardNum = users.get(0).getCardNum();int temp = money / 100 * 100;if (temp = 0) JOptionPane.showMessageDialog(null, 请输入正确的金额);setNull(); else if (generalUser.depositMoney(temp, balance, cardNum) JOptionPane.showMessageDialog(null, 存款成功);setNull(); else JOptionPane.showMessageDialog(null, 存款失败);setNull();private void setNull() this.jDisposeMoneytxt.setText();4.5修改密码模块设计考虑到银行卡密码为6为数字,用户输入的金额必须为6为数字,否则提示密码格式不正确;另外,用户需要两次输入新密码,且两次要匹配,否则会提示用户两次密码不一致,请重新输入,然后再重新回到修改密码的界面。在修改密码时用到的方法为:图八 用户修改密码窗口/* * 修改密码 */private void jb_confirmActionPerformed(java.awt.event.ActionEvent evt) /获取两次密码String passwordOne = new String(jPasswordOne.getPassword();String passwordTwo = new String(jPasswordTwo.getPassword();/获取卡号String cardNum = users.get(0).getCardNum();if (StrUtil.isEmpty(passwordOne) | StrUtil.isEmpty(passwordTwo) /判断两次密码是否为空JOptionPane.showMessageDialog(null, 密码不能为 空);setNull();return;/判断密码是否是六位数字 else if(!(InputJudge.isPassword(passwordOne)|!(InputJudge.isPassword(passwordTwo)JOptionPane.showMessageDialog(null, 密码由6位阿拉伯数字组成);setNull();return;/判断两次密码是否一致else if (!StrUtil.isEqual(passwordOne, passwordTwo) JOptionPane.showMessageDialog(null, 两次密码输入不一致!);setNull();return;/修改密码成功,更新数据库 else if (generalUser.changePassword(passwordOne, passwordTwo, cardNum) JOptionPane.showMessageDialog(null, 修改密码成功);setNull();this.dispose();/返回主窗口GeneralUserFrm generalUserFrm = new GeneralUserFrm();generalUserFrm.setVisible(true); else JOptionPane.showMessageDialog(null, 修改密码失败);setNull();return;private void setNull() jPasswordOne.setText();jPasswordTwo.setText();4.6查询余额模块设计查询余额功能是在主操作窗口中实现的,当用户点击查询余额按钮时在下面的文本框中显示出该账号的当前余额。图九 查询余额窗口public QueryBalanceFrm() this.users = SaveUserInfo.users;/获得卡号int balance = neralUser.QueryBalance(users.get(0).getCardNum();initComponents();this.setLocation(400, 200);this.jBalanceTxt.setText(balance + );4.7管理员操作模块设计管理员登录后可以进行的操作有开户、销户等功能。在开户操作时要先检查新的账户是否已经存在,同时检查新增用户的卡号(12为数字)、密码(6位数字)是否正确;如果密码和余额不填写,默认会添加密码为、余额0元。图十 管理员操作窗口图十一 新增用户/* * 修改密码 */private void jb_confirmActionPerformed(java.awt.event.ActionEvent evt) /获取两次密码String passwordOne = new String(jPasswordOne.getPassword();String passwordTwo = new String(jPasswordTwo.getPassword();/获取卡号String cardNum = users.get(0).getCardNum();if (StrUtil.isEmpty(passwordOne) | StrUtil.isEmpty(passwordTwo) /判断两次密码是否为空JOptionPane.showMessageDialog(null, 密码不能为 空);setNull();return;/判断密码是否是六位数字 else if(!(InputJudge.isPassword(passwordOne)|!(InputJudge.isPassword(passwordTwo)JOptionPane.showMessageDialog(null, 密码由6位阿拉伯数字组成);setNull();return;/判断两次密码是否一致else if (!StrUtil.isEqual(passwordOne, passwordTwo) JOptionPane.showMessageDialog(null, 两次密码输入不一致!);setNull();return;/修改密码成功,更新数据库 else if (generalUser.changePassword(passwordOne, passwordTwo, cardNum) JOptionPane.showMessageDialog(null, 修改密码成功);setNull();this.dispose();/返回主窗口GeneralUserFrm generalUserFrm = new GeneralUserFrm();generalUserFrm.setVisible(true); else JOptionPane.showMessageDialog(null, 修改密码失败);setNull();return;图十二 销户窗口/* * 刷新 * param evt */private void jb_refreshActionPerformed(java.awt.event.ActionEvent evt) this.fillTable();jcardNumTxt.setText();/* * 删除按响应 * * param evt */private void jb_deleteActionPerformed(java.awt.event.ActionEvent evt) String cardNum = jcardNumTxt.getText();if (StrUtil.isEmpty(cardNum) JOptionPane.showMessageDialog(null, 请输入要删除的卡号!);return; else if (admin.delete(cardNum) JOptionPane.showMessageDialog(null, 删除成功);this.fillTable();jcardNumTxt.setText(); else JOptionPane.showMessageDialog(null, 删除失败!请检查用户账号!);jcardNumTxt.setText();/* * 将数据现实在表格中 */private void fillTable() DefaultTableModel dtm = (DefaultTableModel) jt_userInfo.getModel();/获取模型dtm.setRowCount(0);String sql = select * from user;ResultSet rs = UserDao.selectAllUser(sql);/获取数据库中数据try /处理结果集while (rs.next() Vector v = new Vector();v.add(rs.getString(cardNum);v.add(rs.getInt(password);v.add(rs.getInt(balance);dtm.addRow(v);/添加行 catch (SQLException e) e.printStackTrace();五、设计中遇到的问题在此次课程设计中,我遇到了一些问题,如:对于面向对象的方法了解不够透彻,运用到实际的软件开发中存在着困难;对于Java语言,只学习到了一些最基本的知识,这导致编写程序时经常出现一些语法错误,而且要在短时间内用Java语言来设计一个具体的系统是一个较大的挑战;还有对于正规开发一个系统的流程不熟悉,适应起来比较慢,编写各个模块相对应的操作时,自己感觉难以动手,这表明所学的知识不能灵活运用到实际中。尤其是连接数据库的相关操作感觉更加困难,在此也花了很长时间。 对于以上的问题,自己有清楚的认识,解决办法是需要大量阅读相关的书籍,对于书上以及网站上下载的资料中的Java实例必须有清楚的理解,还有就是多跟精通此方面的老师和同学交流,取其精华。对于实际动手能力与系统开发的流程的适应,必须多进行实际的练习与操作,才能有大的进步。六、设计体会在这次的课程设计中,主要是运用JAVA语言来编写一个小的应用程序,当然还可以用其他的技术来辅助了。在这个小应用程序当中,我用了Java外还用了Swing控件。由于以前学的不是很扎实,而且还有些知识我们都是没有学过的,这就要求我们去查相关的书籍,还有就是和同学之间的交流。正因为这样,才锻炼了我的自学的能力,还有就是加深了我对各个知识点的认识,并且提高了我对专业的学习的兴趣,为我以后的学习打下了基础。此外,我还感受到了面向对象语言的类库的强大的功能,掌握了运用JAVA中的类实现某些基本功能,并学会了自己查询使用类的方法,也就是要会用API文档,为以后更好的学习面向对象语言奠定了基础。七、参考文献1 王桂彬、刘家兰,JAVA大学教程M.清华大学出版社 20082 印昊, JAVA与面向对象程序设计M.高等教育出版社 20043 李尊朝, JAVA语言程序设计M.中国铁道出版社 20044 丁诚.JAVA完全自学手册M.机械工业出版社 2010八、源代码clientpackage edu.hfuu.client;import erfacedesign.LogOnFrm;/* * 客户端 * * author Thunder-king * */public class Client public static void main(String args) LogOnFrm logOnFrm = new LogOnFrm();/登录logOnFrm.setVisible(true);Dao:package edu.hfuu.dao;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.util.ArrayList;import java.util.List;import edu.hfuu.domain.AdminDomain;import edu.hfuu.domain.UserDomain;import edu.hfuu.util.DbUtil;public class UserDao /* * 创建Preparestatment语句 * * param sql * return */public static PreparedStatement creatPreparedStatement(String sql) PreparedStatement st = null;try st = DbUtil.getConnection().prepareStatement(sql); catch (SQLException e) e.printStackTrace();return st;/* * 更新信息 包括增、删、改 * * param sql * param param * return 是否删除成功 */public static boolean update(String sql, Object. param) int affected = 0;PreparedStatement st = null;if (DbUtil.getConnection() != null) try st = creatPreparedStatement(sql);for (int i = 0; i 0) try DbUtil.getConnection().close(); catch (SQLException e) e.printStackTrace();return true;try DbUtil.getConnection().close(); catch (SQLException e) e.printStackTrace();return false;/* * 查询用户信息 * * param sql * param param */public static List select(String sql, Object. param) ResultSet rs = null;PreparedStatement st = null;List users = new ArrayList();if (DbUtil.getConnection() != null) st = creatPreparedStatement(sql);for (int i = 0; i param.length; i+) try st.setObject(i + 1, parami); catch (SQLException e) e.printStackTrace();try rs = st.executeQuery(); catch (SQLException e) e.printStackTrace();dealResult(rs, users);try rs.close(); catch (SQLException e) e.printStackTrace();try DbUtil.getConnection().close(); catch (SQLException e) e.printStackTrace();return users;/* * * 处理结果集 * * param rs */public static void dealResult(ResultSet rs, List users) try while (rs.next() UserDomain user = new UserDomain();user.setCardNum(rs.getString(cardNum);user.setPassword(rs.getInt(password);user.setBalance(rs.getInt(balance);users.add(user); catch (SQLException e) e.printStackTrace();/* * 查询用户信息 * * param sql * param param */public static List selectAdmin(String sql, Object. param) ResultSet rs = null;PreparedStatement st = null;List admins = new ArrayList();if (DbUtil.getConnection() != null) st = creatPreparedStatement(sql);for (int i = 0; i param.length; i+) try st.setObject(i + 1, parami); catch (SQLException e) e.printStackTrace();try rs = st.executeQuery(); catch (SQLException e) e.printStackTrace();dealAdminResult(rs, admins);try rs.close();DbUtil.getConnection().close(); catch (SQLException e) e.printStackTrace();return admins;/* * * 处理结果集 * * param rs */public static void dealAdminResult(ResultSet rs, List admins) try while (rs.next() AdminDomain admin = new AdminDomain();admin.setAdminName(rs.getString(adminName);admin.setPassword(rs.getString(password);admins.add(admin); catch (SQLException e) e.printStackTrace();/* * 查询所有用户信息 * * param sql * param param */public static ResultSet selectAllUser(String sql) ResultSet rs = null;PreparedStatement st = null;if (DbUtil.getConnection() != null) st = creatPreparedStatement(sql);try rs = st.executeQuery(); catch (SQLException e) e.printStackTrace();try DbUtil.getConnection().close(); catch (SQLException e) e.printStackTrace();return rs;AdminDomain:package edu.hfuu.domain;/* * 管理员 * * author Thunder-king * */public class AdminDomain private String adminName;private String password;public String getAdminName() return adminNa

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论