个人财务管理系统设计与实现Word下载.docx
《个人财务管理系统设计与实现Word下载.docx》由会员分享,可在线阅读,更多相关《个人财务管理系统设计与实现Word下载.docx(23页珍藏版)》请在冰豆网上搜索。
测试环境及方法23
测试环境23
测试方法23
系统测试结果24
注册测试24
登录测试25
密码修改测试25
总结27
1个人财务管理系统需求分析
系统需求分析的任务与步骤
任务:
调查用户需求,该“用户”主要指系统的后台管理员以及前台用户,分析用户对系统功能、性能、硬件等的具体要求,然后以文本形式作成报告。
本阶段主要是利用图表与文字来表示系统的逻辑模型,旨在从逻辑上描述系统的功能和性能。
步骤:
1.利用图表和文字全面描述系统。
2.根据用户提出的新需求,适当地对系统模型进行改进。
3.编写系统分析文档。
可行性分析
可行性分析是一个系统开发的初始阶段,其意义在于:
在尽可能短的时间里,花费尽量小的代价确定问题是否可以解决。
因此,我们就必须探究清楚原定的各种可能的方案是否可行,以及完成的该系统之后系统所能带来的效益是否足够大于投资的成本。
所以,可行性研究是必要的,它的主要作用是简化系统分析与设计的过程,从而以更合理的方式来进行系统分析与设计,以保证系统的开发成功。
所以说,开发本系统的成本少,开发周期短,从经济方面看开发此系统是可行的。
技术可行性
本系统开发采用的是B/S模式[1]。
系统包括客户端和服务器端,对应前台和后台。
在服务器端采用的是SQLServer2005数据库,该数据库具有数据的完整行、一致行以及安全性的特点,并提供了相当安全可靠的存储功能,因而比较适合处理中小型系统。
它在处理大量数据的同时,也能够保证系统的完整管理功能。
开发过程中所使用的开发软件为MyEclipse,MyEclipse是在Eclipse的基础上加入了许多功能强大的插件,它继承了Eclipse独特图形API,美化了Java界面,并且提高了界面的响应速度。
因此,它比Eclipse更具有实用性。
在硬件方面,用户计算机的硬件配置只需满足以下条件即可:
计算机处理器P4及以上,计算机RAM满足512M或以上,硬盘存储满足40G或以上,该硬件环境要求明显低于市面上的普通电脑配置。
所以,从技术方面来看开发此系统是可行的。
操作可行性
由于本系统是基于B/S模式开发的,用户可以通过浏览网页的方式进入本系统的操作界面,使得用户无论在世界哪个角落,无论在什么时候,只需能连上互联网,就能登录本系统进行相关记录的插入、修改、删除等操作。
操作简单直接,一切操作都可以在浏览器上完成。
客户端不需要额外安装软件,用户使用不需要提前培训,所以,该系统是简单可操作的。
功能需求分析
在生活中,我们每个人都有理财需求。
而最传统的理财方式就是准备一本记账簿,然后对其进行账目的手工记录。
甚至多数人没有记账习惯,也就没有理财规划,导致账目混乱。
所以,设计个人财务管理系统是非常有必要的,它实现的功能有以下几个方面:
前台页面模块:
1)个人收支管理:
它的功能包含对收入支出记录的增添(除现金外,只能对现有卡进行增加操作)、更改、删除、筛选查询(分为按日期查询和按账号查询)、金额统计和以Excel文件形式导出数据(只能导出当前的筛选查询结果)。
一条完整的收支记录包含记录名称、说明、金额数量、收支选择、日期。
2)收支报表:
它主要负责将收支数据分别以柱状图、饼状图展现给用户,给用户提供以不同角度分析数据的条件。
3)卡信息管理:
用户可以对自己的银行卡、基金卡进行增加、修改、删除,在编辑的同时保持与所编辑卡的记录相关联。
4)留言管理:
用户在登录后可以在本系统留言板发表自己的意见与建议。
5)账号管理:
用户可以进行注册操作(不能出现用户名重名的现象)以及对自己账户的密码进行修改。
后台界面模块:
分为管理员角色与超级管理员角色:
1)管理员:
查看当前系统的参数的功能,修改网站简介信息。
对用户信息进行维护(增加、删除、修改、查询)的权限,但不能编辑用户密码。
对留言板进行查看和管理,有权限删除不合理的留言。
2)超级管理员:
在管理员的基础上额外增加管理普通管理员和管理用户密码的功能。
数据流分析
数据流分析指对系统的数据流动方向的进行动态分析,本阶段的主要任务就是找出并解决数据流动过程中的问题。
而目前来说比较常用的方式是分层数据流程图,即DataFlowDiagram,简称DFD。
数据流分析的主要工作是分析系统的数据流程,然后将该流程中所涉及的数据抽象出来,用数据流程图的方式来描述该系统的数据流程。
经过以上的步骤来分析本系统的数据流程,初步确定了系统数据的流动方向,以及系统的主要模块和功能划分,本系统模块大致分为:
收入管理模块、支出管理模块、卡管理模块、财务统计模块、留言管理模块、用户管理模块,分析后得出以下流程图:
图1-1个人财务管理系统顶层DFD图
图1-2个人财务管理系统数据流图(0层图)
图1-3用户注册数据流图
图1-4管理员登录数据流图
数据字典
在本章的前面几个阶段已经分析出了系统的数据流动方向,而本阶段的目的是设计数据,从而得到设计结果:
数据字典。
数据字典就是指某些数据的集合,而这些数据必须包含于数据流图中,即数据字典详细记录了数据流图中的数据的信息。
经过详细的设计后得出如下数据字典:
表1-1管理员信息的数据字典表
数据项名
内容举例
类型
取值范围
备注
管理员编号
1001
int
唯一
账户名
杨天高
nvarchar
150
密码
ytg123
是否为超级管理员
是
char
2
表1-2留言信息的数据字典表
留言编号
留言信息
系统还行
62
留言人
张三
外键
日期
2016/4/221:
35
50
表1-3财务资金信息的数据字典表
财务编号
财务分类
买东西
账户
现金
金额
float
时间
2016/4/1318:
用于投资
收支
shou
4
会员名
李四
表1-4用户信息的数据字典表
用户编号
用户名
王五
wg456
性别
男
1
年龄
23
表1-5网站信息的数据字典表
信息编号
信息名称
网站简介
具体信息
随手理财好帮手
300
2个人财务管理系统的总体设计与实现
系统功能设计
系统功能模块设计
本系统分为账户管理、收支管理、卡管理、留言管理模块,其系统功能模块如图2-1所示:
图2-1个人财务管理系统的功能模块图
功能模块简介
在上一节的图2-1中已经说明了个人财务管理系统的总体功能,以下是每个功能的简介:
由于本系统属于管理系统,许多功能都是通过管理模块实现。
所以,在这里首先介绍管理模块。
管理模块内容要比客户模块更多,因为存在许多对信息的维护工作,包含有查询、添加、更改和删除等操作。
页面的命名采用“模块名+功能名”的方式,见名知意。
总体来说,用户用例图2-2管理员用户图2-3所示管理模块具有如下功能:
系统前台:
1.账户管理模块:
1)注册:
用于前台用户的注册。
2)登录:
用于前台用户的系统登录。
3)修改密码:
用户登录后可以选择修改本账户密码。
2.收支管理模块:
1)收支分析:
显示年/月收支总额。
2)收入管理:
收入记录的录入,查询,编辑,添加。
3)支出管理:
支出记录的录入,查询,编辑,添加。
4)统计分析:
以报表形式展示用户的财务数据,方便用户进行统计分析。
3.卡管理模块:
用户对自己的信用卡,储蓄卡,基金卡等进行管理维护。
4.留言管理模块:
发表对网站使用问题,建议,意见等;
删除本人留言。
图2-2用户用例图
系统后台:
1)系统参数:
管理员可以查看系统运行环境,编辑网站前台简介信息。
2)管理员维护:
对后台管理员的信息进行维护。
3)用户管理:
对前台用户的信息进行维护。
对留言板信息进行维护。
图2-3管理员用户图
数据库设计
数据库概念结构设计
本系统采用ER图方法描述数据对象之间的关系。
采用该方法设计数据库,大致分成三步:
1.设计局部ER模式。
2.综合局部ER模式,然后将之整合为一个整体,得到全局ER模式。
3.优化全局ER模式。
从而得到逻辑结构模型。
设计规划出的实体有:
管理员、用户实体、收支记录、卡、留言、网站信息,ER图如下所示:
图2-4管理员信息实体E-R图
图2-5用户对象实体E-R图
图2-6收支对象实体图E-R图
图2-7卡对象实体E-R图
图2-8留言相对实体E-R图
图2-9网站信息相对实体E-R图
通过整合上述局部ER图,得到如下全局ER图,。
其中每个用户可以同时拥有N张卡、N条收支记录以及管理N条本人留言;
每张卡可以拥有M条收支记录;
多个管理员管理一条网站信息;
管理员与用户的管理关系为M:
N;
管理员与留言的管理管理为M:
N。
详情如图2-10所示:
图2-10整体E-R图
数据库逻辑结构设计
此阶段就是根据本章第一节的设计好E-R图设计相对应的逻辑结构,则设计好的逻辑结构如下:
1.管理员:
管理员编号(主键),管理员账户名,管理员密码
2.用户:
用户编号(主键),账户名,密码,性别,年龄
3.收支:
收支编号(主键),收支类别,分类,备注,账户,添加时间,用户名(外键),金额
4.卡:
卡编号(主键),用户名(外键),卡账号,备注,卡名字,卡类型
5.留言:
留言编号(主键),留言人(外键),留言内容,留言日期
6.网站信息:
信息编号(主键),信息名称,信息内容
数据库物理结构设计
本系统在数据库中的表设计如下所示(每个表对应数据库一张表):
表2-1管理员表admin
列名
字段名
数据类型
长度
允许空
adno
主键
adName
notnull
adPw
isS
表2-2会员表student
id
姓名
name
pwd
sex
null
age
表2-3财务资金表money
资金编号
分类
fenlei
zhanghu
jine
shijian
info
收支类型
shouzhi
会员姓名
username
表2-4网站信息表introd
允许空列名
introdNo
introdName
introdMsg
表2-5卡信息表card
卡编号
卡名
类别
style
100
卡账号
code
表2-6留言信息表message
mid
内容
msg
发布者
appuser
date
datetime
系统实现
在管理员登录系统前需经过用户名、密码和验证码的验证,验证成功后方可进入后台界面。
可以登录后台界面的人员包括普通管理员和超级管理员,超级管理员不能被删除,可以被修改权限为普通管理员,超级管理员在拥有普通管理员权限的基础上,额外拥有管理普通管理员信息和管理用户密码的权限。
普通管理员没有编辑其他管理员信息和用户密码的权限,但是可以对网站简介、用户信息及留言信息进行管理。
由上所建立的系统流程图如下所示:
1.前台界面模块:
图2-11前台界面系统流程图
2.后台界面模块:
图2-12后台界面系统流程图
本章以下几节详细将说明前台界面各模块的具体实现。
账户管理模块
当用户第一次进入系统时,在系统首页面板上具有登录、注册模块,用户必须首先选择注册,注册成功后用户重新进入首页选择登录,在用户登录成功后,可以选择修改密码,修改成功后必须重新登录系统。
以上功能组成过了账户管理模块,其具体工作流程图如下图2-13所示:
图2-13账户管理模块工作流程图
收支管理模块
用户在登录系统之后,可以在收支管理模块中进行收支记录的添加、修改、删除、查询操作,以及导出收支记录文件、查看收支记录动态柱状图。
本模块的工作流程图如图2-17所示:
卡管理模块
用户在登录系统之后,可以在卡管理模块中进行卡信息记录的添加、修改、删除操作,查看卡信息的饼状图。
本模块的工作流程图如图2-22所示:
图2-22卡管理模块工作流程图
留言管理模块
网站留言板。
用户可以发表对网站的建议,意见等以及管理本人留言,本模块的工作流程图如图2-24所示:
图2-24留言管理模块工作流程图
3系统测试
软件测试是软件开发过程中的重要一步,本阶段的目标是测试一个程序的品质和性能,然后对比开发前的规范是否一致,以确保是否符合要求。
软件测试的目的是发现错误,这一步是软件质量保证的关键。
测试内容:
在软件投入运行前,对软件需求分析、设计规格说明和编码的最终复审。
测试目的:
保证软件的质量符合规定;
给风险评估提供依据。
测试原则:
1.从用户角度出发:
在软件测试中发现的某些问题是否可以修复,或者客户是否能够接受。
2.从开发者的角度出发:
就是希望通过测试表明本软件不存在错误,能够正确满足用户需求。
测试环境及方法
测试环境
本次软件测试需要的软件环境为:
在操作系统Windows7下,安装了MyEclipse,Chrome浏览器,Office2010,SQLServer2005等软件。
软件测试需要的硬件配置为:
计算机处理器P4及以上,计算机RAM满足512M或以上(客户端128M或以上),硬盘存储满足40G或以上,总体来说低于市面上普通电脑的配置。
测试方法
一般来说,软件测试的方法从原理上来说大致分为两类:
白盒测试与黑盒测试。
1.黑盒测试:
顾名思义,黑盒测试就是把我们所测试的系统看做是一个不透明的黑盒子,我们不知道盒子里面的结构,即不知道系统的底层工作原理,黑盒测试只针对系统是否能够实现某一功能进行测试,它检验系统是否能够按照说明书的规定正常被使用,系统是否能够正常接收、产生数据,并保持数据的完整性[3]。
2.白盒测试:
白盒测试就是把系统当做是一个透明盒子,我们能够完全了解系统的结构和工作流程,白盒测试主要是为了测试系统的内部逻辑是否符合预定的要求[3]。
由于本系统结构相对简单,对逻辑性要求不高,并且,我们只要求系统在功能上达到要求,而对系统的工作流程、处理逻辑没有严格规定。
因此,为了节约成本,本节主要运用了黑盒测试对系统部分功能进行测试。
总结
在这短短几个星期中,我充分认识到自身的许多不足,所以,接下来的时间,我还需要不断的努力来充实自己和完善自己,这样才能突破自身,提升自己的能力。
本系统是采用Java+SQLServer的模式订制的个人财务管理系统。
系统功能比较完善,用户通过操作Web界面来操作系统,系统通过Web界面来为用户展现数据,同时通过数据库来存储交互的信息数据。
本系统实现了对数据的查询、编辑和管理等基本数据库操作。
本系统基本满足了客户在个人财务管理方面的需要,实现了用户所要求的功能。
在界面的风格上尽可能做到美观,在操作方面尽量做到简单明了,尽可能避免由于员工操作不正确带来的系统出错现象。
但由于时间紧张,本系统还存在某些不足之处:
界面不够友好,需要进一步完善;
数据库性能有待进一步优化,虽然有过改善,但难以达到理想状态,部分数据库表的设计存在一定的冗余,有待进一步完善。
为了使界面更加美观,可以选择利用不同界面之间共享的函数和变量来简化程序代码,而对于界面之间功能相同的模块可以将其提取出来作成一个公共的模块,这样就能够整体提高系统的运行速率;
此外,可以选择使用数据库连接池技术提高数据库操作的性能;
数据库的关系模式也可以进一步规范化,降低冗余[4]。