1、课程设计报告课程名称 基于J2EE项目开发 设计题目 超市管理系统 专业班级 软件1231 姓 名 刘香弟 学 号 成 绩 评 定考核内容设计体现设计报告答辩综合评定成绩成 绩计算机技术与工程学院和谐 勤奋 求是 创新目 录1题目选取与系统分析31.1项目功能分析31.1.1顾客功能性需求31.1.2管理员功能性需求42 模块设计52.1系统总体设计52.2模块设计52.2.1登录模块72.2.2商品信息查看模块82.3.3购物车模块83数据库数据表设计与映射93.1数据库表设计94 系统详细设计与实现114.1综合描述114.2系统运营界面描述124.3重要Java类和其功能254.4系统测
2、试274.4.1测试目的与办法274.4.2测试用例27 1题目选取与系统分析1.1项目功能分析功能性需求是整个需求分析章节最为重要某些。它直接决定了系统模块划分,业务逻辑,明确了使用者对小型超市信息管理系统功能规定。一种完善,明确,详细功能性需求分析是开发一种系统核心。成功功能性需求分析可以避免后期对系统大范畴改动甚至是推倒重建,因而,本某些极为重要。1.1.1顾客功能性需求1不用输入顾客名,密码 ,直接登录超市管理系统商品页面;2查看商品基本信息,涉及 商品编号,单价,余量,厂家,生产日期,保质期;3在购物车中查看自己选中商品名称,价格,数量,并可以从购物车中移除某些商品,查看总价,并可以
3、选取结账或选取继续购物;4点击结账后显示结账成功并退出系统。有关用例图见图1-1。图1-1 顾客用例图顾客用例 “查看商品基本信息”用例描述见表1-1。其她用例类似于此,不再一一赘述。表1-1 用例描述-查看商品基本信息使用者顾客用例查看商品基本信息参加者顾客,小型超市信息管理系统数据顾客向超市信息管理系统发送商品有关信息,如商品名,商品类型,商品编号等勉励超市信息管理系统依照顾客发送字段,查询后台数据库响应超市信息管理系统返回查询商品成果备注无1.1.2管理员功能性需求1打开网站后,进入登录页面。输入顾客名,密码 登录系统。2登陆后,选取进入系统人员管理页面或者商品信息管理页面。在系统人员管
4、理页面中,查看其他管理员信息,并可以添加新管理员。在商品信息管理页面,可以查看所有商品信息,涉及商品编号,进价,单价,余量,厂家,生产日期,保质期。3进入商品信息管理页面进货管理页面,可以填写进货单,实现有关产品数量增长。4进入商品信息管理页面销售查看页面,可以查看近期各项商品销售状况。5点击页面右上角退出按钮,直接退出系统并跳转到登录页面。有关用例图见图1-2 管理员功能性需求用例图。图1-2 管理员功能性需求用例2 模块设计2.1系统总体设计系统总体设计图如图4-1所示。当使用人员登录系统后,按身份不同进入各自页面,并使用系统提供功能。管理员人员信息管理属于操作者所有,在此本系统默认管理员
5、可以操作其她管理员信息。图2-1 系统总体设计图2.2模块设计本处将对小型超市信息管理系统进行分模块设计,明确各个模块操作流程,功能如何使用等问题。1 登录模块超市信息管理系统使用者重要有两种:普通顾客和管理员。按照寻常生活中超市运作流程,普通顾客不需要为其设立专门数据表,因此只需要实现管理员登录模块。使用者进入系统后,一方面进入欢迎界面。普通顾客点击“开始购物路程”超链接,直接进入购物界面。管理员点击“进入后台系统”超链接,进入管理员登陆界面。由于管理员对系统有操作,查看等权限,因而不容许在登陆页面注册新管理员。登陆成功后跳转至管理员管理页面,否则显示“Login fail”登陆失败。当输入
6、对的姓名,密码后,界面自动跳转到管理员管理欢迎界面。2 商品信息管理模块管理员进入后台管理界面后,点击“商品信息管理页面”超链接,进入商品信息管理页面。页面查询后台数据库数据,将所有商品信息展示在右侧页面上。若管理员需要对有关商品信息作出修改,或者删除某项商品信息。则点击相应超链接进行操作。删除成功后系统会提示“删除成功”。点击“更新”,系统会进入商品信息更新页面。在页面中,已经预先填好了所选商品信息。这容许管理员仅对需要修改字段内容修改,避免了全盘输入麻烦。若管理员需要添加新商品,则点击“添加新商品”链接。系统跳转到 商品信息添加页面。在此页面填入相应商品信息,点击“添加”按钮。若各个字段值
7、都符合规定,则系统提示“添加成功”。再点击左侧“商品信息管理页面”,则可以看到刚才插入商品信息。3 进货单管理模块进货是超市正常运营,及时跟进市场最新动态,调节售货方向最重要手段。进货单管理模块用来实现进货功能,管理员可以填写进货单实现对商品表及进货单表更新。在 管理员管理欢迎界面 点击“进货单管理页面”,系统跳转到进货单管理页面。由于进货操作是管理员对超市经营状况收集信息重要途径,因而不容许对进货单进行修改操作,以便进行对账,共计等操作。点击“增长进货单”链接,系统跳转至进货信息添加页面。在进货信息添加页面中,当管理员填写好相应字段后,点击“添加”按钮。系统在后台会自动查找填入商品名。如果此
8、前存在同名商品,则在本来商品基本上,对数量作出修改。如果查不到填入商品名,则在商品表中新建一条记录。最后,在进货单表中生成相应进货记录。4 管理员信息管理模块在管理员管理欢迎界面,点击“管理员信息管理页面”。系统跳转至管理员信息管理界面。在此界面上,可以实现对管理员信息增删改,在此不再一一赘述。5 交易信息查看模块顾客每次在超市消费都会有相应记录。由于小型超市规模限制,不也许大量保存每笔交易详细信息,因而系统以交易流水号形式表达每笔交易。此模块就是供管理员查看交易信息记录。由于交易信息是对超市中已存在交易行为记录,因而不容许管理员对交易信息进行修改,只能在记录较多时删除某条记录。6 退出模块管
9、理员在左侧菜单点击“退出”链接,进入“确认退出页面”。7购物模块在开始页面点击“开始购物路程”链接,跳转到购物页面。点击一项商品后添加至购物车链接,会提示添加成功,并选取查看购物车或继续购物。点击“查看购物车”进入购物车管理页面。可以实现对购物车中商品数量修改,查看当前已购买商品价格总计,或者选取删除购物车中某项商品,甚至清空购物车。点击“结账”链接,系统在新页面中会生成一种交易流水号,继续点击“结账”,如果后台保存成功,则提示交易完毕,点击链接离开。2.2.1登录模块登录流程如图2-3。管理员在登录表单填写顾客名,密码,将表单与Flag标志提交至Servlet。系统依照XML文献配备,调用有
10、关Servlet类(MemberController.java)。Servlet依照Flag值,调用相应函数,查询数据库表(member)并进行判断,如果顾客名与密码匹配,则跳转到管理页面(manage.jsp),否则,输出登录失败页面。图2-2 登录模块流程图2.2.2商品信息查看模块在Left.jsp 中点击“商品信息管理页面”,链接为”Goods.do?flag=1” 。系统依照XML配备文献,调用GoodsController.java 。接受到Flag=1 ,调用FindAll()办法,查询MysqL数据库中goods表,查询所有商品信息,返回一种List 集合,名为list。运用r
11、eq.setAttribute(goods,list) 将集合存入request范畴内,然后跳转至商品信息展示页面(Goodsmanage.jsp)。在商品信息展示页面,创立一种Table.列名分别为商品各项属性名。新建一种List list.。将request 范畴内“goods”接受并进行强制类型转换。循环list,将商品输出。在每一行商品背面,加上“删除”“更新”两个链接,分别为:“Goods.do?flag=2&id=”,“Goods.do?flag=5&id=”。点击链接,可以调用GoodsController.java 中相应函数,传递参数为ID,进行删除或更新操作。有关流程见图2
12、-3。图2-3 商品信息查看模块流程图2.3.3购物车模块添加商品至购物车时,会对购物车中商品进行校验,若商品已在购物车中,则不在购物车中添加新项目,而是只修改商品数量。顾客可以在购物车中编辑商品信息,涉及修改商品数量,删除某些不想要商品,或者清空购物车。每点击有关链接就调用servlet相应函数对session中ShoppingCart进行操作。如果点击“结账”,则进入生成流水号页面。结账成功后,则对数据库中商品余量进行修改,自动减去顾客购买商品数量。购物车流程图如图5-11所示。图5-11 购物车模块流程图3数据库数据表设计与映射3.1数据库表设计商品基本信息表见表3-1。表3-1 商品基
13、本信息表名称含义类型约束备注GoodsID商品IDInt 20主键自动增长GoodsName商品名称Varchar 10唯一值GoodsType商品类型Int 20不为空GoodsPrice单价Int 10不为空GoodsPurchasePrice进价Int 10不为空GoodsAmount商品数量Int 10不为空GoodsGetTime进货日期Date不为空GoodsMaintainTime保质期Int 10不为空单位为(天)GoodsFactory生产厂家Varchar 50不为空员工信息表见表 3-2。表3-2 员工信息表名称含义类型约束备注MemberID员工IDInt 20主键自动
14、增长MemberName员工姓名Varchar 10不为空MemberPassword员工密码Varchar 6不为空MemberSex员工性别Int 1不为空1:男 2:女MemberAge员工年龄Int 10可为空进货单表见表3-3。表3-3 进货单表名称含义类型约束备注Input_ID进货单IDInt 50主键自动增长Input_GoodsID商品IDInt 20不为空Input_GoodsName商品名称Varchar 10唯一值Input_GoodsType商品类型Int 20不为空Input_GoodsPrice单价Int 10不为空Input_GoodsPurchasePrice
15、进价Int 10不为空Input_GoodsAmount商品数量Int 10不为空Input_GoodsGetTime进货日期Date不为空Input_GoodsMaintainTime保质期Int 10不为空单位为(天)Input_GoodsFactory生产厂家Varchar 50不为空订单表见表3-4。表3-4 订单表名称含义类型约束备注Account_ID订单IDInt 20主键自动增长Account_GoodsID商品IDInt 20不为空Account_Code交易流水号Varchar 50外键 参照Sale表code不为空Account_GoodsCount购买商品数量Int 1
16、0不为空交易单表见表3-5。表3-5 交易单表名称含义类型约束备注Sale_ID交易单IDVarchar 20主键自动增长Sale_Date交易日期Date不为空Sale_Accountcode交易流水号Varchar 50不为空4 系统详细设计与实现4.1综合描述由于小型超市信息管理系统构造比较简朴,相对大型,成熟超市采用管理系统来说,无论在系统性能,构造复杂度,安全性上面都无法与之相比。因而在进行系统设计时,应尽量做到构造清晰,编码方式合理,代码与系统可维护性较高。在本章节中,选用小型超市信息管理系统核心模块进行设计阐述。重要模块有登录模块,商品信息查看模块,购物车模块三某些。关于本系统文
17、献构造如下:4.2系统运营界面描述此处为小型超市信息管理系统核心模块详细描述,并附上有关代码以及截图。在代码核心处加以阐明,以以便读者阅读。有关代码如下:Login.jsp:base href=My JSP login.jsp starting page!- function clearInfo(onePart)document.getElementById(onePart).innerHTML = ; 顾客名: 密 码:登录失败!请重新登陆阐明:登录表单中,将姓名与密码字段 “name”属性分别设立为“userName”,“userPassword”,向后台进行参数传递。点击submit按钮
18、,按照action半途径调用办法,传递办法类型为“post”,将提交至servletdopost办法。public interface UserService / 判断顾客登录与否成功public User ifLogin(String name,String password);/ 依照顾客名查询顾客表中数据public List findUserInfoByName(String userName);/ 获取数据库中顾客表中数据并封装在集合中public List getAllUserInfo();/ 向顾客管理中添加顾客信息public boolean add(User user);/
19、依照顾客编号修改顾客管理页面中顾客信息public int updateUserInfo(User user,int userId);/ 依照顾客名编号查询顾客表中数据public User findUserInfoById(int userId);/ 依照顾客编号删除顾客管理页面中相应顾客信息public int deleteUserInfoById(int userId);/ 分页获取顾客信息public PageSize getUserInfoByPage(int currPage);/ 修改顾客密码public int updateUserPwdInfo(int userId,Stri
20、ng userNewPwd);阐明:login办法,接受前台页面传递过来顾客名与密码,并运用编码转换类将顾客名转换为UTF-8编码类型,解决了乱码问题。实例化一种MemberDao类,调用其Login办法,返回实体类Member。如果返回值为空,则输出登录失败页面。否则,跳转至管理员管理页面manage.jsp。public interface UserDao / 判断顾客登录与否成功public User ifLogin(String name,String password);/ 依照顾客名查询顾客表中数据public List findUserInfoByName(String user
21、Name);/ 获取数据库中顾客表中数据并封装在集合中public List getAllUserInfo();/ 向顾客管理中添加顾客信息public boolean add(User user);/ 依照顾客编号修改顾客管理页面中顾客信息public int updateUserInfo(User user,int userId);/ 依照顾客名编号查询顾客表中数据public User findUserInfoById(int userId);/ 依照顾客编号删除顾客管理页面中相应顾客信息public int deleteUserInfoById(int userId);/分页获取顾客信
22、息public PageSize getUserInfoByPage(int currPage);/修改顾客密码public int updateUserPwdInfo(int userId,String userNewPwd);阐明:Login办法对数据库进行操作。一方面连接至数据库,运用前台传来顾客名,密码字段对数据库进行查询,以成果集形式进行返回。并实例化user类,将成果集中数据输出,返回user类型。有关界面设计见图4-1,图4-2,图4-3。图4-1 超市信息管理系统欢迎界面图4-2 超市管理员登陆界面有关代码如下:base href=My JSP login.jsp starti
23、ng page!- function clearInfo(onePart)document.getElementById(onePart).innerHTML = ; 顾客名: 密 码:登录失败!请重新登陆阐明:FindAll办法调用gooddaoselectGoods办法,将所有商品信息读出,以集合形式存入变量“goods”中,在中进行调用。有关页面设计见图。 图4-3商品添加页面base href=My JSP BillModify.jsp starting page!- function checkNum() var txtId=document.getElementById(billN
24、um).value;if(txtId.length=0) document.getElementById(idMsg).innerHTML=账单编号不能为空!; if(flag=false) document.getElementById(idMsg).innerHTML=账单编号已经存在 !; var reg=/0-9*$/;if(!reg.test(txtId) document.getElementById(idMsg).innerHTML=账单编号必要为数字!; document.getElementById(billNum).value=; function clearInfo(on
25、ePart,twoPart)document.getElementById(onePart).value=;document.getElementById(twoPart).innerHTML = ; function checkMoney() var txtMoney=document.getElementById(money).value;if(txtMoney.length=0)document.getElementById(moneyMsg).innerHTML=请输入交易金额!; var reg=/0-9*$/;if(!reg.test(txtMoney)document.getEl
26、ementById(moneyMsg).innerHTML=非法字符,请输入数字!;document.getElementById(money).value=; function checkUnit()var txtUnit=document.getElementById(unit).value;if(txtUnit.length=0)document.getElementById(unitMsg).innerHTML=请输入交易单位!; function checkAmount()var txtAmount=document.getElementById(amount).value;if(t
27、xtAmount.length=0)document.getElementById(amountMsg).innerHTML=交易数量不能为空!; var reg=/0-9*$/; if(!reg.test(txtAmount)document.getElementById(moneyMsg).innerHTML=非法字符,请输入数字!;document.getElementById(money).value=; function checkComName() var txtComName=document.getElementById(comName).value;if(txtComName
28、.length=0)document.getElementById(comNameMsg).innerHTML=商品名称不能为空!; var reg=/u4e00-u9fa50,$/; if(!reg.test(txtComName)document.getElementById(comNameMsg).innerHTML=非法字符,请输入中文!;document.getElementById(comNameMsg).value=; function checkDiscription()var txtDiscription=document.getElementById(discription
29、).value;if(txtDiscription.length=0)document.getElementById(discriptionMsg).innerHTML=商品描述不能为空!;document.getElementById(discriptionMsg).value=; function submitYesNo()var allSpan = document.getElementsByTagName(span);for(var i=0;iallSpan.length;i+)if(allSpani.innerHTML.length!=0)return false;break;ret
30、urn true; function checkReModify() var ifModify=confirm(确认修改吗?); if(ifModify) alert(恭喜您!修改成功!); document.getElementById(myForm).submit(); function checkReDele() var ifModify=confirm(确认删除吗?); if(ifModify) location.href=DoDeleBillInfoByIdServlet?billId=$bill.billId; else return false; 图4-4商品信息页面% page lang