您的当前位置:首页正文

简易银行卡管理系统的开发

来源:汇意旅游网


学生学号

0120710340502 实验课成绩

武汉理工大学

学 生 实 验 报 告 书

实验课程名称 软件工程 开 课 学 院 计算机科学与技术学院 指导老师姓名 顾志华 学 生 姓 名 穆忙涛 学生专业班级 计算机0705

2009 — 2010 学年 第 二 学期

简易银行卡管理系统的开发

1题目

简易银行卡管理系统

2功能描述

分析、设计并实现一个银行卡管理系统,系统中有两类用户,普通用户和管理员用户,普通用户可以对自己的信息管理,而管理员用户则对所有的用户都可以进行管理。

对于普通用户,需要实现以下功能:

(1) 开户 (2) 存款 (3) 取款 (4) 挂失 (5) 消户

(6) 转帐

(7) 查询操作历史

对于管理员账户,需要实现的功能是:

(1) 创建用户 (2) 删除用户 (3) 查看用户信息 (4) 更改用户信息

要实现对用户账户的管理,就要用数据库保存用户的信息,登录时通过对用户账户和用户密码的验证,使用户获得相应的权限。登陆后,用户可以根据提示选择相应的操作,以实现对账户的管理操作。

对账户的管理实际上是对用户信息数据的操作,数据的信息保存在数据库中,所以用户的操作实际上是对数据库的操作。可以将用户的操作映射成以下的数据库操作

普通用户操作:

开户:向数据库中添加一条新纪录

存款、取款、挂失:修改数据库中的某些字段值 销户:删除一条记录

查询操作历史:对数据库的查询 管理员操作:

创建用户:添加一条记录 删除用户:删除一条记录 查询用户信息:查询数据库 更改用户信息:修改记录字段值

3数据定义

系统有两种用户,并且要保存用户的账户信息以及操作记录,所以用四个表来存储所有的信息,分别为guest,guest_log,admin,admin_log。

guest:用来存储普通客户的账户信息

guest_log:用来保存用户的操作记录,以便于查询操作历史 admin:是管理员表,记录管理员的账户信息

admin_log:用来记录管理员操作的历史,以防管理员的错误操作

普通用户的操作仅能涉及guest,guest_log两个表,而管理员可是管理所有的表。

各个表的定义如下:

guest: 字段名 数据类型 作用 guest_id int 客户的唯一标识符,逐渐 guest_num char(5) 用户登录的银行卡号,统一使用5位 password varchar(10) 登录密码,不大于10位,可变长 g_name varchar(10) 客户相关信息,客户姓名, g_sex char(1) 客户性别,x表示男,y表示女 reg_date datatime 账户注册时间 money Int 当前用户金额 Debt char(1) 用户账户状态,0正常,1挂失,2注销

guest_log: 字段名 log_id 数据类型 int log_time g_id motion entity remark

datetime Int varchar(20) int text 作用 操作记录id,唯一标识一个操作事件 事件发生的时间 发生操作事件的用户id' 所执行的操作类型 操作涉及的金额 对操作的备注 管理员账户表和普通客户表的内容很类似,所以简化了一些,并且管理员账户没有账户金额等字段,所以相对较小。

admin: 字段名 admin_id admin_logName password sex reg_data

admin_log: Int 数据类型 varchar(10) varchar(10) char(1) datatime 作用 管理员唯一的标志符 管理员登录用户名 登录密码 性别,x为男,y为女 注册日期 字段名 log_id 数据类型 int log_time admin_loginName motion guest_num entity remark

datetime Varchar(10) varchar(20) Char(10) int text 作用 操作记录id,唯一标识一个操作事件 事件发生的时间 执行操作的管理员账户名 所执行的操作类型 操作涉及到的用户 操作涉及的金额 对操作的备注 以上是四个表的数据定义,在此基础上,通过对数据库的操作,实现对用户信息的操作。

4总体设计和各模块接口说明

系统总体可以分为三个模块:

1.Main主调用模块 2.Guest管理模块 3.Admin管理模块

这单个模块的简单关系为: Main

Guest

Admin Main模块是程序的入口,用户通过Main的操作,引导用户进入Guest模块或Admin模块,直到用户退出。

(1)Main模块

Main模块是程序的入口,程序的初始化都在此模块,包括数据库的连接,数据库的初始化,全局变量的初始化等。该模块定义了两个出口,即 Guest 和Admin,用户在该模块选择入口,已决定想要进行的操作,直到退出。

Main模块的数据库连接,将应用程序同DBMS连接起来,以使应用程序能够对数据库进行操作。

Main模块的数据库初始化,包括创建表,对表中数据的初始操作。使应用程序在执行时可以获得必要的信息。

全局变量的初始化,包括登录状态、当前用户名等信息,使应用程序可以在操作时可以得到相应的环境变量。

Main模块提供了两个出口,分别指向Guest和Admin。

数据库链接

数据库初始化

全局变量初始化

输入用户类

Guest模块 Admin模块

Main的盒形图

(2)Guest模块

Guest模块包含了对普通用户的所有操作,开户、存款、取款、挂失、消户、转帐和查询操作历史。根据选择,执行不同的操作,每一个操作都是对数据库的操作。

选择操作 1 4 5 7 2 3 6

存开取 挂转查询销款户 款 失 账 历史 户

guest guest_log

Guest盒形图(包括对数据库的操作)

(3)Admin模块

Admin模块的内容同Guest模块的内容类似,不过Admin模块的操作涉及到更多的数据表,admin和admin_log。

5程序设计的说明

程序设计包括两个部分的设计:数据库设计和功能设计。 (1)数据库设计

本程序采用MySQL数据库,为实现以上数据库设计,使用如下语句创建数据库:

//创建guest表

char guest[] = \"create table guest\\ (g_id INT,\\ guest_num CHAR(5),\\ password VARCHAR(10),\\ g_name VARCHAR(10),\\ g_sex CHAR(1),\\ reg_date DATETIME,\\ money SMALLINT,\\ debt CHAR(1),\\ PRIMARY KEY(g_id,guest_num)\\ )\";

//创建guest_log表

char guest_log[] = \"create table guest_log\\ (log_id INT,\\ log_time DATETIME,\\ g_id INT,\\ motion VARCHAR(20),\\ entry SMALLINT,\\ remark TEXT,\\ PRIMARY KEY(log_id)\\ )\";

//创建admin表

char admin[] = \"create table admin\\ (admin_id INT,\\ admin_loginName VARCHAR(10),\\ password VARCHAR(10),\\

sex CHAR(1),\\

reg_date DATETIME,\\

PRIMARY KEY(admin_id)\\ )\";

//创建admin_log表

char admin_log[] = \"create table admin_log\\ (log_id INT,\\ admin_loginName VARCHAR(10),\\ log_time DATETIME,\\ motion VARCHAR(20),\\ user_num CHAR(5),\\ entry SMALLINT,\\ remark TEXT,\\ PRIMARY KEY(log_id)\\ )\";

在MySQL查看新建表,用 describe tablename;结果如下:

表guest:

表guest_log:

表admin:

表admin_log:

为了给每一个新注册的用户分配号码,并且给每一条新的记录分配唯一的id值,因此需要一个计数的变量用来存储,表中记录的总量,所以在创建表的时候,初始添加一条记录,用来充当计数器的作用,添加记录的语句如下。

char first_record_guest[] = \"insert into\\ guest(g_id,guest_num)\\ value(0,\\\"00000\\\")\"; char first_record_guest_log[] = \"insert into\\ guest_log(log_id,g_id)\\ value(0,0)\"; char first_record_admin[] = \"insert into\\ admin(admin_id,admin_loginName)\\ value(0,\\\"admin\\\")\"; char first_record_admin_log[] = \"insert into\\ admin_log(log_id,admin_loginName)\\

value(0,\\\"admin\\\")\";

各个表在添加了初始记录后的内容如下: Guest:

Guest_log:

Admin:

Admin_log:

(2)代码设计

总共代码有10个文件,

头文件有admin.h、common.h、global.h、guest.h、stdafx.h .c文件有admin.c、common.c、global.c、guest.c、main.c Stdafx.h,文件包含着整个工程所需要的资源文件 global.h global.c 中声明并定义了全局变量 common.h,common.c中定义了常用的函数

admin.h admin.c实现了所有Admin模块的操作 guest.h guest.c 实现了所有Guest模块的操作 main.c实现了Main模块的内容

0))

Global.h

#ifndef _GLOBAL_H /* please insure _GLOBAL_H unique */ #define _GLOBAL_H /* avoid quotation iterativly */ extern int LOGIN ;

//LOGIN 为表示登陆,为表示未登陆 extern int USER;

//USER 表示用户类型,表示ADMIN,表示GUEST #endif

声明了两个环境变量,LOGIN 和USER。

Guest.h //注册用户

int Register_guest(MYSQL *lpmysql,char *cardnum); //登陆系统

int Login_guest(MYSQL *lpmysql,char *cardnum); //计数器加一

int Increase_guest(MYSQL *lpmysql,int guest_table); //存款

int Deposit(MYSQL *lpmysql,char *cardnum); //取款

int Draw(MYSQL *lpmsql,char *cardnum); //挂失

int Loss(MYSQL *lpmysql,char *cardnum); //注销

int Close(MYSQL *lpmsql,char *cardnum); //转账

int Tranfer(MYSQL *lpmysql,char *cardnum); //获得当前的记录总数

int GetCurrentNum(MYSQL *lpmysql,int guest_table);

声明了guest.c的函数,这些函数都是通过用的输入操作数据库。

Mian.c

mysql_init (&mysql);

if(!mysql_real_connect(&mysql,\"localhost\",\"root\",\"123456\",\"bank\",3306,NULL,{//bank为你所创建的数据库,为端口号,可自行设定 printf(\"数据库连接失败\\n\"); return FALSE; } else { printf(\"数据库连接成功\\n\"); }

用来连接数据库的语句。

6测试和结果说明

1.初始化数据库

2.注册用户

3.用户登录操作

4.数据库变化 Guest 表

Guest_log表:

7实验的体会

这次实验,通过软件工程的方法分析设计了简易银行卡管理系统,在此期间,不仅在技术上实践了数据库编程,更重要的是学会以一种严格的方法去管理软件开发的理念,模块化的编程思想以及高内聚低耦合的编程要点,不仅在系统分析时使系统的设计变得简单,在编码时,代码的设计、调试都变得十分清晰。通过软件工程这门课,我学会了更好的编写代码、

因篇幅问题不能全部显示,请点此查看更多更全内容