基于JAVA超市账单管理系统毕业设计说明书(含源文件)1.doc
毕业设计说明书题 目:超市账单管理系统超市账单管理系统摘 要:随着科学技术的不断发展,计算机越来越普及,随之各种软件也相应而出。许许多多的企业也用上了相应的软件,来加快自身的发展。由于超市行业的不断壮大,也需要一套软件来相应的软件来管理。在这种情况下超市账单管理系统也应运而生。超市账单管理系统主要是对超市账单、供应商、用户的简单管理。本系统主要用java语言进行开发,mysql数据库和Eclipse开发工具;主要用的核心技术是Servlet,用来处理用户的请求和页面之间的跳转,JDBC(Java Data Base Connectivity)连接数据库实现处理与数据库的交互。主要用的美工技术是div+css,javaScript处理页面显示效果。本系统能更快,更方便的管理好整个工作流程中的各个模块,使工作效率达到最优化。关键词:java;Servlet;div+css;javaScript;mysql;超市账单管理系统;Title:Supermarket Bill Management SystemAbstract: Along with the science and technology unceasing development, the computer more and more popular, with a variety of software is out. Many companies also use the corresponding software, to accelerate the development of oneself. As a result of Supermarket has grown, also need a set of software to the software to management. In this case the supermarket bill management system also emerge as the times require. Supermarket bill management system is mainly the easy management of supermarket bills, suppliers, users. This system is mainly the use of Java language development, database mysql and Eclipse development tools; the main core technology is Servlet, It used to handle user requests and jump between pages. JDBC(Java Data Base Connectivity)used to handle the interaction with the database .Mainly using artist technical is div+css,javaScript, handling page display effect. This system can be faster, more convenient management of the whole working process of each module, so that the work efficiency is optimized.Keywords: java ,Servlet,div+css,javaScript,mysql,Supermarket bill management system目 录摘 要IAbstractII1 正文11.1研究背景分析11.2 超市账单管理系统的概述21.3所需软、硬件技术准备21.4可行性分析31.4.1 技术可行性31.4.2 经济可行性31.4.3 社会可行性32 需求分析42.1 需求分析的任务及主要内容42.2.1 具体业务的需求42.2 层次图42.3数据流图53 概要设计53.1 系统分析53.1.1 系统的总体分析63.2 数据库的设计与实现63.2.1 数据库系统分析73.2.2 数据库物理实现74 详细设计94.1 Servlet的详细应用94.2 特定模块的详细介绍94.2.1 登陆模块94.2.2 账单管理模块154.2.2 供应商管理模块214.2.3 用户管理模块265 系统测试32结 语33注 释34参考文献35致 谢37附录138 1 正文1.1研究背景分析超级市场是以顾客自选方式经营的大型综合性零售商场,又称自选商场。是许多国家特别是经济发达国家的主要商品零售组织形式。 超级市场于20世纪30年代初最先出现在美国东部地区 。我国超市市场形成于20世纪90年代初期,现在已经成为我国零售业的一种重要形态,为国民经济的发展发挥了重要的作用。随着超市行业的高速发展,最初的售货员站柜台的销售方式已不能满足现有的销售业的发展,因此迫切的需要引入新的管理技术。随着科学技术的高速发展,信息技术已经深深的影响着我国各行各业的发展。步入数字化时代,有巨大的数据信息等待着加工处理和传输,超市系统本就需要有一个强大的数据库支持,这就需要对数据库进一步的开发和利用,而对超市的销售管理,信息的存储和处理也显的尤其重要。要适应如今激烈的市场竞争,就需要有高效的处理方式和管理方法,因此加快超市的信息化进程是必不可少的。超市虽然具有各种优点,但当下,它仍存在零售企业所共有的落后的一面,例如:不能有效的管理每种商品、收款结算速度慢,容易出现营业差错,不易进行商品调价,盘库效率低,而且商品的进、销、存不能保证同步更新,缺乏实时分析功能,管理人员对及时传递资料的要求始终得不到满足。随着超市形态的高速发展,其经营管理也变的越为复杂,数据库的庞大支撑导致中间流通的数据量大增,中间的商业运转环节也越来越多,传统的管理模式已不能满足,而依靠现信息技术的超市管理系统管理超市,可以节省大量的人力物力,更重要的是能更快更稳的推动超市销售发展,协助管理者做出与时俱进适应市场变化的正确决策,加快超市经营管理效率。超市管理系统是超市对商品的信息化管理系统,本系统可以提高管理水平和工作效率,可以最大限度的减少人工操作带来的错误,使用此系统主要为了实现商品管理的稳定性、可维护性等,从而达到提高商品管理效率并指导经营方向的目的。1.2 超市账单管理系统的概述 本系统的主要功能就是完成对供应商往来账添加的功能,每一批到货情况,是否付款等情况在这个管理模块中进行记录,并且标有记账时间,似的数据有依可循,供随时查询。此外可以根据商品的名称查出是否记录过,是否已经付款的功能。实现供应商信息的添加查询功能。本项目设计主要包括需求分析、数据库设计、项目设计、界面设计、调试及运行等几个大的部分。工作在迭代中展开,通过不断的完善每个环节,最终完成超市管理的需求,实现自动化办公。经过调研的初步需求分析,得出要设计的主要模块包括:(1)账单管理模块,主要是管理超市账单,账单的编号、商品名称、商品数量、交易金额、是否付款、供应商名称、商品描述、账单时间。然后计算出顾客购买商品的总价,计算顾客实付金额和应付金额的差价。减少人工计算产生的错误。(2)供应商管理模块,主要管理与超市合作的供应商,有编号、供应商名称、供应商描述、联系人、电话、地址。(3)用户管理模块,主要管理管理超市的用户,有编号、用户名称、性别、年龄、电话、地址、权限。用户管理信息化,减少了人力资源的浪费。1.3所需软、硬件技术准备本系统的开发是面向数据库应用程序的开发。目前数据库技术发展日趋完善,可用于数据库开发的工具各种各样。本系统是采用mysql作为后台数据库,本系统是运行在Window XP平台上的,因此考虑到兼容性、开发成本以及开发的方便和简单,本系统使用免费的Eclipse开发平台。为了高效、快捷的采购出库入库管理系统的开发。采取如下开发环境:网络环境:局域网。硬件环境:内存1G,硬盘80G。软件环境:(1)操作系统:Windows XP版本。(2)数据库开发工具:mysql。(3)应用程序开发工具:Eclipse。技术准备:(1)java基础(2)jsp技术(3)Servlet技术(4) html,css(5)jquery的相关知识1.4可行性分析1.4.1 技术可行性 本系统戏是用java语言所编写的,java语言作为前导课程已经学过。重点学习了jsp,最后又系统的学习了Servlet,Servlet这同时又是本系统应用的重点。从设计,开发,测试到最后的维护,都综合了所学的java知识。本系统所实现的是超市账单管理,因此在给定的时间内完成是绝对可行。制作本系统的软件均可以在网上免费获得,同时也可以获得开源的代码和图片。本组的技术人员有开发此类项目的经验。综上所述,此系统开发有可靠的技术支持,技术上是完全可行的。1.4.2 经济可行性对本组的经济现状和投资能力进行分析,对系统建设运行和维护费用进行估算,对系统建成后可能取得的社会和经济效益进行估计。由于本系统是作为毕业设计由我们学生自己开发的,在经济上的投入甚微,系统建成之后将为超市行业提供很大的方便,因此在经济上是可行的。1.4.3 社会可行性本系统编程所使用的是网上的开源代码和图片,又不以获利为目的。因此不必承担任何法律责任2 需求分析2.1 需求分析的任务及主要内容 2.2.1 具体业务的需求主要模块包括:(1)账单管理模块,主要是管理超市账单,账单的编号、商品名称、商品数量、交易金额、是否付款、供应商名称、商品描述、账单时间。然后计算出顾客购买商品的总价,计算顾客实付金额和应付金额的差价。减少人工计算产生的错误。(2)供应商管理模块,主要管理与超市合作的供应商,有编号、供应商名称、供应商描述、联系人、电话、地址。(3)用户管理模块,主要管理管理超市的用户,有编号、用户名称、性别、年龄、电话、地址、权限。用户管理信息化,减少了人力资源的浪费。2.2 层次图软件账 单 管 理 模 块用 户 管 理 模 块供 应 商 管 理 模 块图2-1层次图2.3数据流图经 理登 陆账单管理供应商管理用户管理数据维护存入数据库图2-2普通用户 理登 陆账单管理供应商管理数据维护存入数据库图2-33 概要设计3.1 系统分析在本系统中,分为基本信息的账单管理模块,供应商管理模块,用户管理模块。有2个角色:经理、普通用户名。1用户所具有功能(1) 经理拥有所有的模块的操作权限,(2) 普通用户除了对用户管理模块的操作权限意外所有模块的操作权限:对账单表,供应商表增删改查。3.1.1 系统的总体分析在前面的系统功能分析中,将系统划分成4个模块,如图3-1:用户登录验证经理普通用户账单管理用户管理供应商管理图3-1 系统功能模块图 3.2 数据库的设计与实现数据库是此类系统的核心,系统中所有的信息都存储在数据库中,在所有jsp页面中通过JDBC与数据库连接,操作数据库中的数据,从而实现所有需要的功能。数据库软件有很多。本系统中数据库采用MySQL作为数据库工具。数据库是网站的核心,数据库设计的合理与否对网站的建设有着至关重要的影响。一个良好的数据库开发过程一般是先系统分析,再逻辑设计,然后物理实现。系统分析中分析数据库用户需求,并画出E-R图直观地表示出数据库系统的需求。逻辑设计中根据系统分析设计的一个关系模型。物理设计为逻辑设计中的数据模型选取一个最合理的应用环境的物理结构,通常选取一个常用数据库软件,用数据库软件创建与逻辑设计中数据模型对应的数据库。3.2.1 数据库系统分析本系统的数据库实体主要有“账单”、“供应商”、“用户”。其中“账单”中的物品与“供应商”存在着联系,一个账单必须对应一个供应商,但供应商不一定只有一份账单,即供应商和账单之间一多对多的关系。如图:3-1 账单拥有M1供应商图3-1 账单供应商E-R图3.2.2 数据库物理实现经过数据库系统分析后,数据库的结构已经非常清晰,剩下的就是用一种数据库软件实现这样的结构。本系统中数据库采用MySQL作为数据库。首先我们在MySQL中建一个数据库,命名为“supermarket”。 选中supermarket数据库,向数据库中添加3个表:gongyingshang,yonghu,zhangdan。下面是每个数据表中的属性。1) gongyingshang表。gongyingshang表用来存储供应商信息。 gongyingshang表字段名称数据类型gys_id数字gys_name文本gys_miaoshu文本gys_lianxiren文本gys_phone文本gys_chuanzhen数字gys_address数字表3-12) yonghu表。yonghu表用来存储领登陆用户明细。 yonghu表字段名称数据类型yh_id数字yh_username文本yh_password文本yh_sex文本yh_age数字yh_phone数字yh_address文本yh_quanxian文本表3-23) zhangdan表。zhangdan表用来存储账单的信息。 zhangdan表字段名称数据类型zd_id数字zd_spmingcheng文本zd_spshuliang数字zd_jymoney数字zd_sfzhifu文本zd_gysname文本zd_spmiaoshu文本zd_data文本zd_danwei文本表3-34 详细设计4.1 Servlet的详细应用在Servlet工作流程中,根据web.xml中的配置将拦截所有通过servlet的请求,并根据URI决定分发给doGet还是doPost处理请求,然后调用相应的业务逻辑方法,调用相应的页面去执行响应。利用JDBC(Java Data Base Connectivity)技术处理与数据库连接,利用其Servlet API所定义的接口和类来封装与数据库交互的相关操作,使对数据库的操作变得相当容易,减少开发时间,而且能对系统进行灵活的设计和实现,使系统的各模块容易维护和重用。4.2 特定模块的详细介绍 每个包都有其各自的作用,是杂乱的java文件分层,具有层次感,也可以很好地进行维护。4.2.1 登陆模块 输入不同的角色名就会进入不同的模块,并完成相应的功能;登陆模块如图4-1所示如图 4-1代码:public class HandelLogin extends HttpServletUserOper oper=new UserOper();public void init(ServletConfig config)throws ServletExceptionsuper.init(config);public void destroy() super.destroy(); public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException this.doPost(request, response);public void doPost(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOExceptionrequest.setCharacterEncoding("utf-8");response.setCharacterEncoding("utf-8");response.setContentType("text/html;charset=utf-8");HttpSession session=request.getSession(true);String op = request.getParameter("op");String opg= request.getParameter("opg");String opyh = request.getParameter("opyh");String zdgroup=request.getParameter("zdgroup");System.out.println(zdgroup);String gysgroup=request.getParameter("gysgroup");Login judgeLogin = (Login)(session.getAttribute("login");if ("doLogin".equals(op) doLogin(request, response);return;if (judgeLogin!=null&&!"".equals(judgeLogin)if("经理".equals(judgeLogin.getYh_quanxian()if ("ZD".equals(op)doLnquiresZD(request,response);else if("ZDAdd".equals(op)doZDAdd(request,response);else if("ZDXinXi".equals(op) doZDXinXi(request,response);else if("修 改".equals(op) doZDXiuGai(request,response);else if("删 除".equals(op) doZDDel(request,response);else if("组合查询".equals(zdgroup)doZDChaXun(request,response);else if("GYS".equals(op)doLnquiresGYS(request,response);else if("GYSAdd".equals(op) doGYSAdd(request,response);else if("GYSXinXi".equals(op) doGYSXinXi(request,response);else if("修 改".equals(opg)doGYSXiuGai(request,response);else if("删 除".equals(opg)doGYSDel(request,response);else if("组合查询".equals(gysgroup)doGYSChaXun(request,response);else if("YH".equals(op)doLnquiresYH(request,response);else if("YHAdd".equals(op) doYHAdd(request,response);else if("YHXinXi".equals(op) doYHXinXi(request,response);else if("修 改".equals(opyh)doYHXiuGai(request,response);else if("删 除".equals(opyh)doYHDel(request,response);else if ("查询".equals(opyh) doYhChaXun(request,response);else if("修改密码".equals(opyh) doYHMiMa(request,response);else if("修改密码".equals(op)doAdminMiMaXiuGai(request,response);if("普通用户".equals(judgeLogin.getYh_quanxian()if ("ZD".equals(op)doLnquiresZD(request,response);else if("ZDAdd".equals(op)doZDAdd(request,response);else if("ZDXinXi".equals(op) doZDXinXi(request,response);else if("修 改".equals(op) doZDXiuGai(request,response);else if("删 除".equals(op) doZDDel(request,response);else if("组合查询".equals(zdgroup)doZDChaXun(request,response);else if("GYS".equals(op)doLnquiresGYS(request,response);else if("GYSAdd".equals(op) doGYSAdd(request,response);else if("GYSXinXi".equals(op) doGYSXinXi(request,response);else if("修 改".equals(opg)doGYSXiuGai(request,response);else if("删 除".equals(opg)doGYSDel(request,response);else if("组合查询".equals(gysgroup)doGYSChaXun(request,response);else if("YH".equals(op)|"修改密码".equals(op)|"修改密码".equals(opyh)|"查询".equals(opyh)|"删 除".equals(opyh)|"修 改".equals(opyh)|"YHXinXi".equals(op)|"YHAdd".equals(op)Information info=new Information();String msg="对不起您没有那么高的权限"info.setMsg(msg);request.setAttribute("info", info);request.getRequestDispatcher("mainWindow.jsp").forward(request, response);elseresponse.sendRedirect("login.jsp");管理员(用户)登陆以后就会进入总页面如图:4-2所示:在左侧可以看到管理员进来后(普通用户)各自的权限。 管理员登陆:如图 4-2普通用户登陆:如图 4-34.2.2 账单管理模块 管理员权限下的功能操作及代码如图 4-4代码:private void doLnquiresZD(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException HttpSession session=request.getSession();List<ZDBean> list=oper.ZDLnquires();List<String> gysName=oper.ZDGongYiShang();if(list!=null)request.setAttribute("list", list);session.setAttribute("gysName", gysName);request.getRequestDispatcher("admin_bill_list.jsp").forward(request, response);return;else response.sendRedirect("admin_bill_list.jsp");private void doZDChaXun(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException String zd_spmingcheng=request.getParameter("commodityname"); String zd_sfzhifu=request.getParameter("payment"); System.out.println(zd_spmingcheng); System.out.println(zd_sfzhifu); List<ZDBean> list=oper.ZDChaXun(zd_spmingcheng,zd_sfzhifu);if(list!=null)request.setAttribute("list", list);request.getRequestDispatcher("admin_bill_list.jsp").forward(request, response);return;else response.sendRedirect("admin_bill_list.jsp");代码:private void doZDAdd(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException String zd_id=request.getParameter("zdid").trim();String zd_spmingcheng=request.getParameter("zdproductname").trim();String zd_spshuliang=request.getParameter("zdtransnunber").trim();String zd_jymoney=request.getParameter("zdtransmoney").trim();String zd_sfzhifu=request.getParameter("payment").trim();String zd_gysname=request.getParameter("zdproducmanufacture").trim();String zd_spmiaoshu=request.getParameter("zdproducdesc").trim();String zd_danwei=request.getParameter("zdtransunits").trim();String zd_data=new SimpleDateFormat("yyyy-MM-dd").format(new Date().getTime();List params = new ArrayList();params.add(zd_id);params.add(zd_spmingcheng);params.add(zd_spshuliang);params.add(zd_jymoney);params.add(zd_sfzhifu);params.add(zd_gysname);params.add(zd_spmiaoshu);params.add(zd_data);params.add(zd_danwei);Information info=oper.ZDAdd(params);request.setAttribute("info", info);request.getRequestDispatcher("admin_bill_add.jsp").forward(request, response);代码:private void doZDXinXi(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOExceptionString zd_id =request.getParameter("id");ZDBean zdbean = new ZDBean();zdbean=oper.ZDXinXi(zd_id);if(zdbean!=null)request.setAttribute("zdbean", zdbean);request.getRequestDispatcher("admin_bill_update.jsp").forward(request, response);如图 4-5代码:private void doZDXiuGai(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOExceptionString zd_id=request.getParameter("zdid").trim();String zd_spmingcheng=request.getParameter("zdproductname").trim();String zd_spshuliang=request.getParameter("zdtransnunber").trim();String zd_jymoney=request.getParameter("zdtransmoney").trim();String zd_sfzhifu=request.getParameter("payment").trim();String zd_gysname=request.getParameter("zdproducmanufacture").trim();String zd_spmiaoshu=request.getParameter("zdproducdesc").trim();String zd_danwei=request.getParameter("zdtransunits").trim();List params = new ArrayList();params.add(zd_id);params.add(zd_spshuliang);params.add(zd_jymoney);params.add(zd_sfzhifu);params.add(zd_gysname);params.add(zd_spmiaoshu);params.add(zd_danwei);params.add(zd_spmingcheng);Information info=oper.ZDXiuGai(params);request.setAttribute("info", info);request.getRequestDispatcher("admin_bill_update.jsp").forward(request, response);private void doZDDel(HttpServletRequest request,HttpServletResponse response)throws ServletExcept