javaATM机银行存取款系统的方案与实现Word下载.docx

上传人:b****5 文档编号:20608987 上传时间:2023-01-24 格式:DOCX 页数:54 大小:62.80KB
下载 相关 举报
javaATM机银行存取款系统的方案与实现Word下载.docx_第1页
第1页 / 共54页
javaATM机银行存取款系统的方案与实现Word下载.docx_第2页
第2页 / 共54页
javaATM机银行存取款系统的方案与实现Word下载.docx_第3页
第3页 / 共54页
javaATM机银行存取款系统的方案与实现Word下载.docx_第4页
第4页 / 共54页
javaATM机银行存取款系统的方案与实现Word下载.docx_第5页
第5页 / 共54页
点击查看更多>>
下载资源
资源描述

javaATM机银行存取款系统的方案与实现Word下载.docx

《javaATM机银行存取款系统的方案与实现Word下载.docx》由会员分享,可在线阅读,更多相关《javaATM机银行存取款系统的方案与实现Word下载.docx(54页珍藏版)》请在冰豆网上搜索。

javaATM机银行存取款系统的方案与实现Word下载.docx

Thedevelopmentofcomputerscienceandtechnologynotonlygreatlypromotedthedevelopmentofscienceasawhole,andsignificantlyspeeduptheprocessofeconomicandsocialinformation.Thevastmajorityofthecompany'

sday-to-dayofficecannotdowithoutthecomputertechnologyandsoftwaretechnology.DomesticbanksMostvigorouslydevelopmentBankautomatedtellermachine(ATM),inordertoenhanceefficiencyandreducecosts.文档来自于网络搜索

EclipscThesystemusesasadevelopmenttooloftousingtheJavalanguage,andconnecttoanOracledatabase,setupthemostcommonandanalogbankdepositwithdrawalstransferoperation.Userregistration,userlogin,theuserdepositstheuserwithdrawal,checkalloperatingrecordoftheuser.文档来自于网络搜索

Keywords

Registration;

Login;

Deposit;

Transfer;

History

引论

随着市场经济地发展,经济信息化程度地不断深入,银行地传统业务己愈来愈不能满足银行客户地需要.同时,随着国内银行机构地大量增加,我国地银行业面临更加激烈地同业竞争,如何提供更多地金融产品和更优质地服务,如何吸引更多地客户,如何利用计算机技术加强银行帐户信息管理,提高银行地工作效率和业务竟争能力是摆在各家银行面前地一个迫切需要解诀地问题.文档来自于网络搜索

Java是一个广泛使用地编程语言,是一种新地计算概念.1995年Java地诞生让全世界地程序员为之疯狂.与以往地任何一种语言相比Java都有着无可比拟地优势.首先,Java是一种简单、面向对象、分布式、解释、健壮、安全、结构中立、可移植、高效能、动态地语言.目前,Java已得到了全世界主要计算机软硬件厂商地支持,在计算机领域中得到了广泛应用.文档来自于网络搜索

本系统选题为基于Java程序设计地银行存取款系统,是模拟银行存取款地管理.设计地指导思想是一切为使用者着想,界面要美观大方,操作尽量简单明了,而且作为一个实用地管理系统要有要有良好地容错性,在出现误操作时能尽量及时地给出警告,以便用户及时地改正.鉴于本系统地特殊性,还需要本程序有良好地保密性.文档来自于网络搜索

1银行存取款系统概述

1.1背景

随着我国金融电子化建设地深入发展和银行客户对金融服务质量要求地提高,自动柜员(ATM机)在金融行业地应用越来越广泛,自动柜员机(ATM机)在拉近客户与银行之间地距离,扩展营业网点,改善用卡环境,提供全天候、全方位地金融服务,降低经营成本,提高金融行业地服务质量和综合竞争实力等方面正发挥着不可替代地作用.文档来自于网络搜索

1.2意义

对用户来说,自动柜员机(ATM机)地诞生,使原来必须到银行柜台办理地账务查询、转账等业务,可以在大街小巷地固定取款机前进行办理.对银行来说,自动柜员机(ATM机)地开通,将大大提高工作效率,在方便用户地同时可以节省大量地柜台服务为人员,从而降低生产经营成本.文档来自于网络搜索

2银行存取款系统需求分析

2.1系统需求

本系统是一套类似于ATM机地模拟银行系统存取款管理软件,其采用C/S结构来实现,当用户在界面进行存取款操作后,其数据信息会存入数据库,用户也可以选择查询这些信息.文档来自于网络搜索

2.2功能需求

根据系统地需求分析,本系统地功能要求如下:

2.2.1用户注册和登陆功能

新用户必须先注册,注册需要填写用户名和密码;

老用户可以输入户名和密码直接登陆,通过读取数据库,获取该用户地信息,如果用户不存在则会提示错误.文档来自于网络搜索

2.2.2用户存取款转账和查询历史功能

用户登录成功后,可以选择存款、取款、转账或者查询历史记录四项业务,系统会自动进行各种计算,然后将结果返回给用户并将信息存入数据库.文档来自于网络搜索

2.3软件属性需求

本系统为银行存取款管理系统,要求程序具有一定地可移植,可扩展,安全性、保密性!

启动程序

2.4业务流程描述

图1-1业务流程

3.银行存取款系统总体设计

3.1系统设计概述

本系统使用Eclipse作为开发工具,采用Oracle作为后台数据库,使用swing界面,用户所有地操作信息会自动记录在数据库中,用户界面简单明了,功能严谨合理,务求使用户有好地体验.文档来自于网络搜索

3.2注册帐户

填写注册信息,注册成功后,把用户信息存进数据库,并自动获得10000元存款.

3.3登录

输入帐户名和密码,读取数据库内容进行验证,如果存在,登录成功,否则提示无此账户,请确认后重新输入!

登录成功后可进行存款取款转账查询历史操作;

3.4存款

输入地存款金额进行验证,如输入负数或字母,提示金额错误,否则提示存款成功,存储被修改地余额信息!

3.5取款

输入地取款金额进行验证,如输入负数或字母,提示金额错误.取款成功后,存入数据库!

当取款金额大于余额,要有提示,并操作不成功.文档来自于网络搜索

3.6转账

输入对方户名可以进行转账,转账后自己余额减少,对方余额增加.

3.7查询历史

显示用户从注册开始地所有操作时间和操作记录.

3.8退出

退出系统.

4Oracle数据库地设计

4.1Oracle数据库设计概论

OracleDatabase,简称Oracle.是甲骨文公司地一款关系数据库管理系统.到目前仍然是全球最流行地数据库.文档来自于网络搜索

在银行存取款系统地设计中,多次使用了Oracle作为存储信息和读取信息地工具.

4.2表地结构设计

在银行存取款系统地设计中,我们建立了用户表和历史表用于存储信息;

4.2.1用户表

用户表用于存储用户地户名密码余额注册时间信息,当用户注册成功后这些信息会自动记录在数据库中,以便用户查询.文档来自于网络搜索

表3-1用户表

字段名

数值类型

说明

HUMING

VARCHAR2(15)

用户户名(主键)

MIMA

用户密码

YUE

MUMBER

用户余额

SHIJIAN

DATE

用户注册时间

4.2.2历史表

历史表用于存储用户从注册开始地所有用户操作,历史表中地字段HUMING与用户表中地字段HUMING是外键关系,以实现2个表之间地关联.文档来自于网络搜索

表3-2历史表

用户执行当前操作地时间(主键)

用户户名

CAOZUO

VARCHAR2(100)

当前操作

MUNBER

操作后用户余额

4.3PL/SQL存储过程地设计

存储极大地方便了对数据库地增删改查等操作,因此创建与用户表对应地存储过程P_YH和与历史表对应地存储过程P_LS.文档来自于网络搜索

4.3.1用户表存储过程地设计

针对用户表地特点和JDBC连接地需要,现设计P_YH代码如下:

createorreplaceprocedurep_yh(

--pl/sql存储过程-用于对用户表--进行更新密码和余额操作

v_rmarkinnumber,--判定操作

v_huminginvarchar2,--户名

v_mimainvarchar2,--用户密码

v_yueinnumber--剩余金额

is

begin

if(v_rmark=1)then

insertintoyonghuvalues(v_huming,v_mima,v_yue,sysdate);

文档来自于网络搜索

elsif(v_rmark=2)then

updateyonghusetmima=v_mimawherehuming=v_huming;

else

updateyonghusetyue=yue+v_yuewherehuming=v_huming;

endif;

commit;

end;

4.3.2历史表存储过程地设计

针对历史表地特点和JDBC连接地需要,现设计P_LS代码如下:

createorreplaceprocedurep_ls(

--pl/sql存储过程--用于对历史表--进行存储删除操作

v_caozuoinvarchar2,--用户操作

v_yueinnumber--操作金额

if(v_rmark=1)then--存储

insertintolishivalues(to_char(systimestamp,'

yyyy-mm-ddhh24:

mi:

ss'

),v_huming,v_caozuo,v_yue);

else

deletefromlishiwherehuming=v_huming;

5银行存取款系统地实现

5.1用户登陆模块地实现

5.1.1界面样式

图3-1用户登陆界面

5.1.2功能实现

程序启动后调用Dlact类,显示用户登陆界面.

新用户需要点击注册按钮调转到用户注册界面进行注册,老用户输入户名和密码点击登陆按钮,程序将跳转到用户操作界面.户名和密码错误或者不存在会提示登录失败.该模块主要代码如下:

publicclassDlactextendsJFrameimplementsActionListener{文档来自于网络搜索

publicvoidff(){

f.setLayout(null);

addWindowListener(newWindowAdapter(){

publicvoidwindowClosing(WindowEvente){

System.exit(0);

}

});

f.setVisible(true);

}

publicstaticvoidmain(String[]agrs){

Dlactd=newDlact();

d.ff();

}

@Override

publicvoidactionPerformed(ActionEvente){

Strings1=t1.getText();

Strings2=String.valueOf(p1.getPassword());

if(e.getSource()==JB2){

//调用注册界面

Zcactz=newZcact();

z.ff();

}

else{

//登陆成功进入用户操作界面

Xzactx=newXzact();

x.ff(s1,s2);

5.2新用户注册模块地实现

新用户在登陆界面点击注册按钮后调转到注册界面,在程序中调用Zcact类;

5.2.1界面样式

图3-2新用户注册界面

5.2.2功能实现

新用户输入户名、密码及确认密码.输入两次密码必须一致,不一致提示输入不一致需要重新输入.在程序中定义两个变量s1和s2,判断两个变量地值是否相等.文档来自于网络搜索

新用户注册成功后,系统将自动存储信息,并有余额10000元.该部分主要代码如下:

publicclassZcactextendsJFrameimplementsActionListener{文档来自于网络搜索

publicvoidff(){

@Override

publicvoidactionPerformed(ActionEvente){

Strings1=t1.getText();

Strings2=String.valueOf(p1.getPassword());

Strings3=String.valueOf(p2.getPassword());

System.out.println(s2);

if(!

s2.equals(s3)){

//判断2次密码是否一致

JOptionPane.showMessageDialog(null,"

密码输入不一致"

);

return;

}

else{

注册成功"

Yhvoyvo=newYhvo();

//调用Yhvo将数据存入用户表

Lsvolvo=newLsvo();

//调用Lsvo将数据存入历史表

yvo.setHuming(s1);

yvo.setMima(s2);

yvo.setYue(10000);

lvo.setHuming(s1);

lvo.setCaozuo("

注册账号获得10000"

lvo.setYue(10000);

yvo.setShijian(newDate());

try{

Yhdao.ff2(yvo,1);

Lsdao.ff2(lvo,1);

}catch(ClassNotFoundExceptione1){

e1.printStackTrace();

}catch(SQLExceptione1){

e1.printStackTrace();

5.3用户操作模块地实现

用户登陆成功后,进入操作选择界面.在程序中应用Xzact类.

5.3.1界面样式

图3-3用户主界面

5.3.2功能实现

用户登陆成功后,用户可以选择存款、取款、转账、查询历史操作;

选择不同地操作会跳转到对应地界面;

该部分主要代码如下:

publicclassXzactextendsJFrameimplementsActionListener{文档来自于网络搜索

Stringhm=null;

Stringmm=null;

publicvoidff(Stringhm,Stringmm){

this.hm=hm;

this.mm=mm;

}

if(e.getSource()==JB1){

//跳转到存款界面

Ckactc=newCkact();

c.ff(hm,mm);

}

elseif(e.getSource()==JB2){

//跳转到取款界面

Qkactc=newQkact();

elseif(e.getSource()==JB3){

//跳转到转账界面

Zzactz=newZzact();

z.ff(hm);

elseif(e.getSource()=JB4){

//跳转到查询历史界面

Lsactl=newLsact();

l.ff(hm);

5.4存款模块地实现

用户登录成功后,可进入存取款系统.在程序中应用Xzact类.

5.4.1界面样式

图3-4用户存款

5.4.2功能实现

用户输入地存款金额,金额不能为负数或字母.然后单击存款按钮,会提示存款成功和当前余额;

该模块主要代码如下:

publicclassCkactextendsJFrameimplementsActionListener{文档来自于网络搜索

Stringhm;

Stringmm;

publicvoidff(Stringhm,Stringmm){

this.hm=hm;

this.mm=mm;

//传递户名和密码

publicvoidactionPerformed(ActionEvente){

Yhvoyvo=newYhvo();

//更新用户表

yvo.setHuming(hm);

yvo.setMima(mm);

yvo.setYue(Integer.parseInt(t1.getText()));

try{

Yhdao.ff2(yvo,3);

}catch(ClassNotFoundExceptione1){

}catch(SQLExceptione1){

e1.printStackTrace();

Lsvolvo=newLsvo();

//更新历史表

lvo.setHuming(hm);

lvo.setCaozuo("

存款"

+Integer.parseInt(t1.getText()));

List<

Yhvo>

list=null;

list=newYhdao().ff();

}catch(ClassNotFoundExceptione2){

e2.printStackTrace();

}catch(SQLExceptione2){

e2.printStackTrace();

for(inti=0;

i<

list.size();

i++){

if(list.get(i).getHuming().equals(hm)){

lvo.setYue(list.get(i).getYue());

}

Lsdao.ff2(lvo,1);

5.5取款模块地实现

用户点击取款按钮,可进行取款操作.在程序中应用Qkact类.

5.5.1界面样式

图3-5用户取款

5.5.2功能实现

用户输入取款金额,金额不能为负数或字母.然后单击取款按钮,如果取款数不大于余额,读取取款数额,将信息写入数据库,提示取款成功和当前余额,否则,提示取款错误.该模块主要代码如下:

publicclassQkactextendsJFrameimplementsActionListener{文档来自于网络搜索

this.hm=hm;

addWindowListener(newWindowAdapter(

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育 > 学科竞赛

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1