基于java web的超市管理系统
威仔聊技术 2024-07-08 08:33:01 阅读 55
摘要
随着社会经济的不断发展,人们的生活水平不断提高。越来越多的零售行业得到了快速的发展,以最常见的超市最为明显。零售行业繁荣的背后也随之带来了许多行业隐患,越来越激烈的行业竞争不断的要求经营者更加高要求的管理超市内部的整个供应链系统。在国外,信息化建设起步比较早。尤其是对于零售行业或者制造业来说,它们在各自的领域都有相对完善的信息化建设。其零售行业当中超市实体经营当中信息系统也比较完备。
互联网技术的快速发展,网络早已经成为现代人日常生活中不可或缺的部分,它已经渗透到我们社会和经济生活中的各个领域。在我国数量众多的超市中,中小超市占了绝大多数。这些超市也不可避免地要加入国际化超市的竞争行列,而实现超市信息化是参与挑战的必要条件。但是中小超市的多样性及其灵活多变的经营方式,加上相关投入量的限制,使得很多中小超市没有进行信息化建设。实际上大部分中小超市需要的只是能解决进销存管理、财务管理等的基础软件。因此,开发基于中小超市应用的管理系统尤为重要。
本文主要是基于JSP技术开发采用B/S架构的模式,通过对当下超市内部需求进行整理,开发出一款能够通过信息化的管理工具来帮助超市经营者减少超市库存、同时还能够降低超市所面临的资金风险。在保证员工高效、快捷的完成工作的同时还能够为经营者提供有效的决策。
关键词:超市管理,JSP,信息技术
系统实现
首页
后台管理登录页面
采购查询管理
采购员登录
后台管理
入库添加商品信息管理
随着经济的全球化以及中国经济改革的逐渐深化,零售业面临着越来越激烈的竞争,改善超市内部以及整个供应链各个环节的管理、调度及资源配置,迅速适应客户的新需求和市场新机遇的能力,是超市赢得竞争胜利的决定性因素。
开发本系统的难点主要在于系统要应对大量的访问流量进入,对于这些数据的处理要选择一个功能强大并且安全的数据,还有就是现在人们上网一般都是实用的手机,所以本系统对于运行环境的要求要特别低,可以在普通的手机上运行。不同的研究难点和思路会对应出不一样的解决办法的方式,如果仅仅从解决办法的角度来看的话还是有不同的方向的,正如我们平常所做事情一样,可能同一件事情每个人的解决思路却是大不相同的。此次的设计也是一样的,纵观整个系统的实现过程和整个业务过程研究的难点无非就是技术架构的选型和数据库的考量。在技术架构选型当中此次设计还是考虑了大学当中所学习的所有语言,以成熟、稳定且功能强大做为一个标准,那我们这次就选择了java语言进行业务实现。数据库考虑到经济性还是使用了开源、免费的MYSQL数据库。
开发介绍
相对浏览器来说,C/S模式算是曾经非常不错的模式,但是自从B/S模式出现以来,受到了用户的一致好评,再也不需要一个一个的更新了。不同的架构会影响着不同的语言选型,同时后面的开发模式、部署方式等等都是受架构所影响的。此次设计主要是针对我们所开发的应用而考虑,而且还得是当下行业内主流的开发方式,所以采用了B/S的设计模式。当然这也并不是一定绝对的说B/S模式就是好,C/S模式就是不行。只是针对我们的应用而言B/S模式更加主流和方便。这样的模式有很大的一个好处就是可以通过浏览器就能访问到应用了,而且在后续的系统更新或者其它方面来说都不用有过多的考虑,不像C/S架构的应用还得考虑兼容客户端旧版本的情况,而且客户端旧版本如果不更新使用的话会不会冲突等等问题。这使得B/S模式开发的系统在视觉效果和用户体验方面得到了很大的提升,可以带给用户非常愉悦的上网体验。
市面上目前拥有的非关系型数据库无非就是那几种?Oracle数据库、SQL server数据库。对于一些国产的,还有达梦、易鲸捷等,其实他们的本质功能需求上是一样的,只不过在不同的限定场景之下,会有不同的使用使用需求,如果是在信创的环境下,当然首推国产数据库,如果是在一些大型应用或者集团应用的层面上,肯定是会使用Oracle数据库。对于我们毕业设计而言,那么SQL数据库其实是最合适不过的。应用程序在其开发过程当中绕不开的就是数据的存储,一般情况下会将数据分为两种;一种是关系型数据库,另外一种那就是非关系型的了。今天我们所要介绍的就是关系数据库当中的一种——MySQL数据库。MySQL数据库经过了N多年的发展,已经成为了世界上主流数据库的一种。它的简单易学让每一位开发人员深深的喜欢上了它。当然仅仅只是这样还不够,它的强大功能也是一方面的体现。能够让每一位开发者喜欢的原因。如果仅仅他简单而言实现不了太多功能,其实在日常的开发中也是不够的,MySQL数据库正是拥有这两方面的特点:简单以及功能强大,所以他给开发者带来的感触是非常深的。
我们都知道,对于一个超市管理系统来说,不仅系统功能和非常重要,高性能的网络安全环境也是非常重要,网络安全的环境是直接影响应用系统是否安全的关键因素,但网络安全的保证是要从软件、硬件等各个方面进行一个有效性的综合提升。在专业的应用服务器中所必要的防火墙以及网络设备是必须要存在的,且在应用服务器当中与应用无关的所有端口号都要进行一定的屏蔽。对于内外网之间也要进行一个有效的隔离。在应用服务器中,所有的操作日志需定期进行一个有效的记录,具备应用审计、审查等功能。同时,在应用服务器当中应该有足够大的存储空间来为应用服务器进行一个灾备。防止意外发生时,能够及时有效地将应用服务器当中的所有内容进行一个恢复。所以说,那么基于JAVAWEB的超市管理系统等网络环境安全方面,我们一定要有一个保障,才能安安心心的做系统的开发。
部分代码
<code>package com.controller;
import java.io.File;
import java.io.IOException;
import java.sql.Timestamp;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.io.PrintWriter;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;
import com.entity.Yonghuzhuce;
import com.server.YonghuzhuceServer;
import com.util.PageBean;
import net.sf.json.JSONObject;
import com.util.db;
import java.sql.SQLException;
import java.sql.*;
@Controller
public class YonghuzhuceController {
@Resource
private YonghuzhuceServer yonghuzhuceService;
@RequestMapping("addYonghuzhuce.do")
public String addYonghuzhuce(HttpServletRequest request,Yonghuzhuce yonghuzhuce,HttpSession session) throws SQLException{
Timestamp time=new Timestamp(System.currentTimeMillis());
yonghuzhuce.setAddtime(time.toString().substring(0, 19));
yonghuzhuceService.add(yonghuzhuce);
session.setAttribute("backxx", "添加成功");
session.setAttribute("backurl", request.getHeader("Referer"));
//session.setAttribute("backurl", "yonghuzhuceList.do");
return "redirect:postback.jsp";
//return "redirect:yonghuzhuceList.do";
}
//处理编辑
@RequestMapping("doUpdateYonghuzhuce.do")
public String doUpdateYonghuzhuce(int id,ModelMap map,Yonghuzhuce yonghuzhuce){
yonghuzhuce=yonghuzhuceService.getById(id);
map.put("yonghuzhuce", yonghuzhuce);
return "yonghuzhuce_updt";
}
@RequestMapping("doUpdateYonghuzhuce2.do")
public String doUpdateYonghuzhuce2(ModelMap map,Yonghuzhuce yonghuzhuce,HttpServletRequest request){
yonghuzhuce=yonghuzhuceService.getById(Integer.parseInt((String)request.getSession().getAttribute("uid")));
map.put("yonghuzhuce", yonghuzhuce);
return "yonghuzhuce_updt2";
}
@RequestMapping("updateYonghuzhuce2.do")
public String updateYonghuzhuce2(int id,ModelMap map,Yonghuzhuce yonghuzhuce){
yonghuzhuceService.update(yonghuzhuce);
//return "redirect:doUpdateYonghuzhuce2.do";
return "redirect:doUpdateYonghuzhuce2.do?ok=1";
}
//后台详细
@RequestMapping("yonghuzhuceDetail.do")
public String yonghuzhuceDetail(int id,ModelMap map,Yonghuzhuce yonghuzhuce){
yonghuzhuce=yonghuzhuceService.getById(id);
map.put("yonghuzhuce", yonghuzhuce);
return "yonghuzhuce_detail";
}
//前台详细
@RequestMapping("yhzcDetail.do")
public String yhzcDetail(int id,ModelMap map,Yonghuzhuce yonghuzhuce){
yonghuzhuce=yonghuzhuceService.getById(id);
map.put("yonghuzhuce", yonghuzhuce);
return "yonghuzhucedetail";
}
//
@RequestMapping("updateYonghuzhuce.do")
public String updateYonghuzhuce(int id,ModelMap map,Yonghuzhuce yonghuzhuce,HttpServletRequest request,HttpSession session){
yonghuzhuceService.update(yonghuzhuce);
//session.setAttribute("backxx", "修改成功");
//session.setAttribute("backurl", request.getHeader("Referer"));
//return "redirect:postback.jsp";
return "redirect:"+request.getHeader("Referer")+"&ok=1";
//String url = request.getHeader("Referer");
//return "redirect:"+url;
//return "redirect:yonghuzhuceList.do";
}
//分页查询
@RequestMapping("yonghuzhuceList.do")
public String yonghuzhuceList(@RequestParam(value="page",required=false)String page,code>
ModelMap map,HttpSession session,Yonghuzhuce yonghuzhuce, String yonghuming, String mima, String xingming, String xingbie, String chushengnianyue1,String chushengnianyue2, String QQ, String youxiang, String shouji, String shenfenzheng, String touxiang, String dizhi, String beizhu, String issh){
if(page==null||page.equals("")){
page="1";code>
}
PageBean pageBean=new PageBean(Integer.parseInt(page), 5);
Map<String, Object> pmap=new HashMap<String,Object>();
pmap.put("pageno", pageBean.getStart());
pmap.put("pageSize", 5);
if(yonghuming==null||yonghuming.equals("")){pmap.put("yonghuming", null);}else{pmap.put("yonghuming", yonghuming);}
if(mima==null||mima.equals("")){pmap.put("mima", null);}else{pmap.put("mima", mima);}
if(xingming==null||xingming.equals("")){pmap.put("xingming", null);}else{pmap.put("xingming", xingming);}
if(xingbie==null||xingbie.equals("")){pmap.put("xingbie", null);}else{pmap.put("xingbie", xingbie);}
if(chushengnianyue1==null||chushengnianyue1.equals("")){pmap.put("chushengnianyue1", null);}else{pmap.put("chushengnianyue1", chushengnianyue1);}
if(chushengnianyue2==null||chushengnianyue2.equals("")){pmap.put("chushengnianyue2", null);}else{pmap.put("chushengnianyue2", chushengnianyue2);}
if(QQ==null||QQ.equals("")){pmap.put("QQ", null);}else{pmap.put("QQ", QQ);}
if(youxiang==null||youxiang.equals("")){pmap.put("youxiang", null);}else{pmap.put("youxiang", youxiang);}
if(shouji==null||shouji.equals("")){pmap.put("shouji", null);}else{pmap.put("shouji", shouji);}
if(shenfenzheng==null||shenfenzheng.equals("")){pmap.put("shenfenzheng", null);}else{pmap.put("shenfenzheng", shenfenzheng);}
if(touxiang==null||touxiang.equals("")){pmap.put("touxiang", null);}else{pmap.put("touxiang", touxiang);}
if(dizhi==null||dizhi.equals("")){pmap.put("dizhi", null);}else{pmap.put("dizhi", dizhi);}
if(beizhu==null||beizhu.equals("")){pmap.put("beizhu", null);}else{pmap.put("beizhu", beizhu);}
int total=yonghuzhuceService.getCount(pmap);
pageBean.setTotal(total);
List<Yonghuzhuce> list=yonghuzhuceService.getByPage(pmap);
map.put("page", pageBean);
map.put("list", list);
session.setAttribute("p", 1);
return "yonghuzhuce_list";
}
@RequestMapping("yhzcList.do")
public String yhzcList(@RequestParam(value="page",required=false)String page,code>
ModelMap map,HttpSession session,Yonghuzhuce yonghuzhuce, String yonghuming, String mima, String xingming, String xingbie, String chushengnianyue1,String chushengnianyue2, String QQ, String youxiang, String shouji, String shenfenzheng, String touxiang, String dizhi, String beizhu, String issh){
if(page==null||page.equals("")){
page="1";code>
}
PageBean pageBean=new PageBean(Integer.parseInt(page), 5);
Map<String, Object> pmap=new HashMap<String,Object>();
pmap.put("pageno", pageBean.getStart());
pmap.put("pageSize", 5);
if(yonghuming==null||yonghuming.equals("")){pmap.put("yonghuming", null);}else{pmap.put("yonghuming", yonghuming);}
if(mima==null||mima.equals("")){pmap.put("mima", null);}else{pmap.put("mima", mima);}
if(xingming==null||xingming.equals("")){pmap.put("xingming", null);}else{pmap.put("xingming", xingming);}
if(xingbie==null||xingbie.equals("")){pmap.put("xingbie", null);}else{pmap.put("xingbie", xingbie);}
if(chushengnianyue1==null||chushengnianyue1.equals("")){pmap.put("chushengnianyue1", null);}else{pmap.put("chushengnianyue1", chushengnianyue1);}
if(chushengnianyue2==null||chushengnianyue2.equals("")){pmap.put("chushengnianyue2", null);}else{pmap.put("chushengnianyue2", chushengnianyue2);}
if(QQ==null||QQ.equals("")){pmap.put("QQ", null);}else{pmap.put("QQ", QQ);}
if(youxiang==null||youxiang.equals("")){pmap.put("youxiang", null);}else{pmap.put("youxiang", youxiang);}
if(shouji==null||shouji.equals("")){pmap.put("shouji", null);}else{pmap.put("shouji", shouji);}
if(shenfenzheng==null||shenfenzheng.equals("")){pmap.put("shenfenzheng", null);}else{pmap.put("shenfenzheng", shenfenzheng);}
if(touxiang==null||touxiang.equals("")){pmap.put("touxiang", null);}else{pmap.put("touxiang", touxiang);}
if(dizhi==null||dizhi.equals("")){pmap.put("dizhi", null);}else{pmap.put("dizhi", dizhi);}
if(beizhu==null||beizhu.equals("")){pmap.put("beizhu", null);}else{pmap.put("beizhu", beizhu);}
int total=yonghuzhuceService.getCount(pmap);
pageBean.setTotal(total);
List<Yonghuzhuce> list=yonghuzhuceService.getByPage(pmap);
map.put("page", pageBean);
map.put("list", list);
session.setAttribute("p", 1);
return "yonghuzhucelist";
}
@RequestMapping("deleteYonghuzhuce.do")
public String deleteYonghuzhuce(int id,HttpServletRequest request){
yonghuzhuceService.delete(id);
//String url = request.getHeader("Referer");
//return "redirect:"+url;
//return "redirect:yonghuzhuceList.do";
return "redirect:"+request.getHeader("Referer")+"?ok=2";
}
@RequestMapping("quchongYonghuzhuce.do")
public void quchongYonghuzhuce(Yonghuzhuce yonghuzhuce,HttpServletResponse response){
Map<String,Object> map=new HashMap<String,Object>();
map.put("yonghuming", yonghuzhuce.getYonghuming());
System.out.println("yonghuming==="+yonghuzhuce.getYonghuming());
System.out.println("yonghuming222==="+yonghuzhuceService.quchongYonghuzhuce(map));
JSONObject obj=new JSONObject();
if(yonghuzhuceService.quchongYonghuzhuce(map)!=null){
obj.put("info", "ng");
}else{
obj.put("info", "用户名可以用!");
}
response.setContentType("text/html;charset=utf-8");
PrintWriter out=null;
try {
out=response.getWriter();
out.print(obj);
out.flush();
} catch (IOException e) {
e.printStackTrace();
}finally{
out.close();
}
}
}
可行性分析
一般情况下,如果要开发一个网站系统,需要非常大的投入,它包括前期的人员投入、租用服务器的资金投入、宣传投入等等。但是本系统是毕业设计,基本的要求是可以实现简单的资源学习共享论坛管理就可以,因此本系统只需要本人一个人就可以开发完成,出了一台电脑外,不用其他投入,因此在经济上是可性的。
操作可行性方面就是要考虑用户的习惯了,那么什么样的设计可能让用户感觉头疼,什么样的设计又能让用户感觉友好程度很高呢?这就需要我们在操作可行性上有所体现。所体现出来的。就目前而言,市面上所有BS的应用来说,布局方式、操作方法都是常见的那几种,所以我们只需参考他人成功的经验即可。在操作上,只要不做出任何奇形怪状的操作,那么对于操作可行性来说是完全没有问题的。
对于技术而言来说,项目本身就是一个技术的实现,而我们在大学中所学的语言也是主流的语言,比如说对于后台语言来说有PHP 、Java等,对于数据库来说有MySQL、SQL server等,这些都是在大学当中平常的课程,所以在技术方面。我们所接触的是主流开源技术。如果一旦遇到了。技术上有不懂的问题,那么也可以通过互联网或者是其他同学得到帮助,这样一来,技术上完全是可行的。
超市管理系统部署
超市管理系统开发出来是要部署的。只有部署了的系统才能使用,大家都应该也知道系统的应用部署是要从多个方面进行考虑的,首先要考虑的一点就是系统用户使用的并发速,如果难以估量并发出的话,可以通过日常的在线用户数和注册人数进行一个估量,一般并发数就是在线用户数的20%左右。例如我们真正用户使用数有100人,那么可能他的在线并发数就是20人,当我们的应用部署所考虑的注册人数一旦超过一定的人数时,我们需要做对应用服务器的集群,那么通过网关的负载均衡,就可均匀地将所发来的请求分摊给不同的服务器,然后再由服务器转发到数据库当中,作为增删改查的一个基础。当然,不同的数据库之间肯定是要做一个session的共享是以免每一个数据库的请求都要进行登录。这些问题都是需要在系统开发的前期进行一个考量,因为在后面的话,可能会系统的软件部署影响前期开发的技术选型,所以说每一个环节都是很重要的。
软件测试
软件测试的真实就是说我们的超市管理系统开发完成以后要进行一个测试。不能存在有问题的东西出现程序测试的目的就是为了能够让在程序系统上线之后没有存在bug,用户使用时没有明显的错误产生。当然,程序的bug存在着多种多样,他们一般按级别分为严重,一般、较轻,比如说严重的bug一般都是一些逻辑性的错误。对于一些采购信息系统或者经销存系统,比如说库存数量的算法等这些如果存在bug的话,那一定是严重的错误,因为这些错误可以直接影响到系统的逻辑计算。当然,还有一般普通的半错误别墅。比如说是界面的逻辑计算结果,加减乘除。没有带出来或者等因素影响,这都属于一般错误。
超市管理系统单元测试往往都是在程序开发的过程中进行的,所以这一点可以在测试过程中实际不必要那么强调的去做,但基层测试是整体项目进行一个总结、汇总之后进行的开发测试。当然,程序测试的方法也存在多种多样,我们普通常见的有黑盒、白盒、灰盒等一些测试方法。程序的测试总是通过黑盒和白盒进行的测试,一个是对内部结构的测试,另外一个也是对数据驱动的一种测试。通过这两种测试,可以有效的把系统的框架以及系统内部数据的逻辑性进行一个有效的罗列,一一整理,这才知道发现出bug存在的原因。灰盒测试其实就是一种综合性的总结性测试。它是由黑盒和白盒共同总结而成进行的。当然测试的方式不仅仅只有这几种,还有从项目执行的角度来讲,我们还有可以单元测试、集成测试,这些都是测试的一种方法,只不过从不同的角度而进行一个考量。
超市管理系统经过我们多项测试之后,发现系统上的bug基本不存在,对于系统的功能有一个有效性的实现。实际上可以证明出我们的程序功能开发都进行了一一的实现,而且实现的都比较不错,这一点还是非常不错的。
声明
本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。