基于JSP小型超市管理系统的设计与开发.doc_第1页
基于JSP小型超市管理系统的设计与开发.doc_第2页
基于JSP小型超市管理系统的设计与开发.doc_第3页
基于JSP小型超市管理系统的设计与开发.doc_第4页
基于JSP小型超市管理系统的设计与开发.doc_第5页
已阅读5页,还剩21页未读 继续免费阅读

下载本文档

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

文档简介

课程设计报告课程名称 基于J2EE的项目开发 设计题目 超市管理系统 专业班级 软件1231 姓 名 刘香弟 学 号 1204311106 成 绩 评 定考核内容设计表现设计报告答辩综合评定成绩成 绩计算机技术与工程学院和谐 勤奋 求是 创新目 录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系统测试274.4.1测试的目标与方法274.4.2测试用例27 1题目选择与系统分析1.1项目的功能分析功能性需求是整个需求分析章节最为重要的部分。它直接决定了系统的模块划分,业务逻辑,明确了使用者对小型超市信息管理系统功能的要求。一个完善的,明确的,详细的功能性需求分析是开发一个系统的关键。成功的功能性需求分析可以避免后期对系统的大范围改动甚至是推倒重建,因此,本部分极为重要。1.1.1顾客功能性需求1不用输入用户名,密码 ,直接登录超市管理系统的商品页面;2查看商品的基本信息,包括 商品编号,单价,余量,厂家,生产日期,保质期;3在购物车中查看自己选中的商品名称,价格,数量,并可以从购物车中移除某些商品,查看总价,并可以选择结账或选择继续购物;4点击结账后显示结账成功并退出系统。相关用例图见图1-1。图1-1 顾客用例图顾客用例 “查看商品基本信息”的用例描述见表1-1。其他用例类似于此,不再一一赘述。表1-1 用例描述-查看商品基本信息使用者顾客用例查看商品基本信息参与者顾客,小型超市信息管理系统数据顾客向超市信息管理系统发送商品相关信息,如商品名,商品类型,商品编号等激励超市信息管理系统根据用户发送的字段,查询后台数据库响应超市信息管理系统返回查询商品结果备注无1.1.2管理员功能性需求1打开网站后,进入登录页面。输入用户名,密码 登录系统。2登陆后,选择进入系统人员管理页面或者商品信息管理页面。在系统人员管理页面中,查看其它管理员的信息,并可以添加新的管理员。在商品信息管理页面,可以查看全部商品的信息,包括商品编号,进价,单价,余量,厂家,生产日期,保质期。3进入商品信息管理页面的进货管理页面,可以填写进货单,实现相关产品数量的增加。4进入商品信息管理页面的销售查看页面,可以查看近期各项商品的销售情况。5点击页面右上角的退出按钮,直接退出系统并跳转到登录页面。相关用例图见图1-2 管理员功能性需求用例图。图1-2 管理员功能性需求用例2 模块设计2.1系统总体设计系统总体设计图如图4-1所示。当使用人员登录系统后,按身份的不同进入各自的页面,并使用系统提供的功能。管理员的人员信息管理属于操作者所有,在此本系统默认管理员可以操作其他管理员的信息。图2-1 系统总体设计图2.2模块设计本处将对小型超市信息管理系统进行分模块设计,明确各个模块的操作流程,功能如何使用等问题。1 登录模块超市信息管理系统的使用者主要有两种:普通的顾客和管理员。按照日常生活中超市的运作流程,普通顾客不需要为其设立专门的数据表,所以只需要实现管理员的登录模块。使用者进入系统后,首先进入欢迎界面。普通顾客点击“开始购物旅程”超链接,直接进入购物界面。管理员点击“进入后台系统”超链接,进入管理员登陆界面。由于管理员对系统有操作,查看等权限,因此不允许在登陆页面注册新的管理员。登陆成功后跳转至管理员管理页面,否则显示“Login fail”登陆失败。当输入正确的姓名,密码后,界面自动跳转到管理员管理欢迎界面。2 商品信息管理模块管理员进入后台管理界面后,点击“商品信息管理页面”超链接,进入商品信息管理页面。页面查询后台数据库数据,将所有商品信息展示在右侧页面上。若管理员需要对相关商品信息作出修改,或者删除某项商品信息。则点击相应的超链接进行操作。删除成功后系统会提示“删除成功”。点击“更新”,系统会进入商品信息更新页面。在页面中,已经预先填好了所选商品信息。这允许管理员仅对需要修改的字段内容修改,避免了全盘输入的麻烦。若管理员需要添加新商品,则点击“添加新商品”链接。系统跳转到 商品信息添加页面。在此页面填入相应的商品信息,点击“添加”按钮。若各个字段的值都符合要求,则系统提示“添加成功”。再点击左侧“商品信息管理页面”,则可以看到刚才插入的商品信息。3 进货单管理模块进货是超市正常运营,及时跟进市场最新动态,调整售货方向的最重要的手段。进货单管理模块用来实现进货功能,管理员可以填写进货单实现对商品表及进货单表的更新。在 管理员管理欢迎界面 点击“进货单管理页面”,系统跳转到进货单管理页面。由于进货操作是管理员对超市经营情况收集信息的重要途径,因此不允许对进货单进行修改操作,以便进行对账,合计等操作。点击“增加进货单”链接,系统跳转至进货信息添加页面。在进货信息添加页面中,当管理员填写好相应的字段后,点击“添加”按钮。系统在后台会自动查找填入的商品名。如果以前存在同名的商品,则在原来的商品的基础上,对数量作出修改。如果查不到填入的商品名,则在商品表中新建一条记录。最后,在进货单表中生成相应的进货记录。4 管理员信息管理模块在管理员管理欢迎界面,点击“管理员信息管理页面”。系统跳转至管理员信息管理界面。在此界面上,可以实现对管理员信息的增删改,在此不再一一赘述。5 交易信息查看模块顾客每次在超市的消费都会有相应的记录。由于小型超市规模的限制,不可能大量保存每笔交易的详细信息,因此系统以交易流水号的形式表示每笔交易。此模块就是供管理员查看交易信息的记录。由于交易信息是对超市中已存在的交易行为的记录,因此不允许管理员对交易信息进行修改,只能在记录较多时删除某条记录。6 退出模块管理员在左侧菜单点击“退出”链接,进入“确认退出页面”。7购物模块在开始页面点击“开始购物旅程”链接,跳转到购物页面。点击一项商品后的添加至购物车链接,会提示添加成功,并选择查看购物车或继续购物。点击“查看购物车”进入购物车管理页面。可以实现对购物车中商品数量的修改,查看目前已购买商品的价格总计,或者选择删除购物车中的某项商品,甚至清空购物车。点击“结账”链接,系统在新页面中会生成一个交易流水号,继续点击“结账”,如果后台保存成功,则提示交易完成,点击链接离开。2.2.1登录模块登录流程如图2-3。管理员在登录表单填写用户名,密码,将表单与Flag标志提交至Servlet。系统根据XML文件的配置,调用相关的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。利用req.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-3。图2-3 商品信息查看模块流程图2.3.3购物车模块添加商品至购物车时,会对购物车中的商品进行校验,若商品已在购物车中,则不在购物车中添加新项目,而是只修改商品数量。顾客可以在购物车中编辑商品信息,包括修改商品数量,删除某些不想要的商品,或者清空购物车。每点击相关链接就调用servlet的对应函数对session中的ShoppingCart进行操作。如果点击“结账”,则进入生成流水号页面。结账成功后,则对数据库中的商品余量进行修改,自动减去顾客购买的商品数量。购物车流程图如图5-11所示。图5-11 购物车模块流程图3数据库的数据表设计与映射3.1数据库表设计商品基本信息表见表3-1。表3-1 商品基本信息表名称含义类型约束备注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主键自动增长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进价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 10不为空交易单表见表3-5。表3-5 交易单表名称含义类型约束备注Sale_ID交易单IDVarchar 20主键自动增长Sale_Date交易日期Date不为空Sale_Accountcode交易流水号Varchar 50不为空4 系统详细设计与实现4.1综合描述由于小型超市信息管理系统结构比较简单,相对大型的,成熟的超市采用的管理系统来说,无论在系统的性能,结构复杂度,安全性上面都无法与之相比。因此在进行系统设计时,应尽量做到结构清晰,编码方式合理,代码与系统的可维护性较高。在本章节中,选取小型超市信息管理系统关键模块进行设计阐述。主要模块有登录模块,商品信息查看模块,购物车模块三部分。有关本系统的文件结构如下:4.2系统运行界面描述此处为小型超市信息管理系统关键模块的详细描述,并附上相关代码以及截图。在代码的关键处加以说明,以方便读者阅读。相关代码如下:Login.jsp:base href=My JSP login.jsp starting page!- function clearInfo(onePart)document.getElementById(onePart).innerHTML = ; 用户名: 密 码:登录失败!请重新登陆说明:登录表单中,将姓名与密码字段 “name”属性分别设置为“userName”,“userPassword”,向后台进行参数传递。点击submit按钮,按照action中的路径调用方法,传递方法的类型为“post”,将提交至servlet的dopost方法。public interface UserService / 判断用户登录是否成功public User ifLogin(String name, String password);/ 根据用户名查询用户表中的数据public List findUserInfoByName(String userName);/ 获取数据库中用户表中的数据并封装在集合中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);/ 分页获取用户信息public PageSize getUserInfoByPage(int currPage);/ 修改用户密码public int updateUserPwdInfo(int userId, String userNewPwd);说明:login方法,接受前台页面传递过来的用户名与密码,并利用编码转换类将用户名转换为UTF-8编码类型,解决了乱码问题。实例化一个MemberDao类,调用其Login方法,返回实体类Member。如果返回值为空,则输出登录失败页面。否则,跳转至管理员管理页面manage.jsp。public interface UserDao / 判断用户登录是否成功public User ifLogin(String name, String password);/ 根据用户名查询用户表中的数据public List findUserInfoByName(String userName);/ 获取数据库中用户表中的数据并封装在集合中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);/分页获取用户信息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 starting page!- function clearInfo(onePart)document.getElementById(onePart).innerHTML = ; 用户名: 密 码:登录失败!请重新登陆说明:FindAll方法调用gooddao的selectGoods方法,将所有商品信息读出,以集合的形式存入变量“goods”中,在中进行调用。相关页面设计见图。 图4-3商品添加页面base href=My JSP BillModify.jsp starting page!- function checkNum() var txtId=document.getElementById(billNum).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(onePart,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.getElementById(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(txtAmount.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.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).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;return 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商品信息页面base href=My JSP admin_bill_list.jsp starting page!- function goPage()var goPageNo = document.getElementById(inputPage).value;var goUrl = DoFindBillInfoByPageServlet?pageNo=+goPageNo;location.href = goUrl;商品名称:     是否付款:请选择已付款未付款     账单管理>>账单编号商品名称商品数量交易金是否付款供应商品描述账单时间$bi.billId$Name$bi.tranAmount $bi.tranMoney $bi.ifPayment $bi.belongSupply $Discription $bi.tranDate 共条记录  /页跳转至:  页GO 图4-5用户订单显示页面4.3主要的Java类和其功能DoAddBillServlet.java类:public class DoAddBillServlet extends HttpServlet public void doGet(HttpServletRequest request, HttpServ

温馨提示

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

评论

0/150

提交评论