• (免费分享)java基于SSM的进销存管理系统设计与实现


    博主介绍:✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌

    项目名称
    (免费分享)java基于SSM的进销存管理系统设计与实

    系统说明

    摘 要
    进入21世纪以来,商业管理中需要处理的数据和信息越来越多。大量的数据和繁杂的数据使得古老的手工处理数据的方式渐渐显得力不从心。甚至有些信息处理的方式在手工处理的模式下是根本无法是实现的,只能利用计算机的高运行频率来进行迭代计算。而且最近国家正在提倡大众创业,中小型企业很多。中小企业在我国经济发展中具有重要地位,目前我国的中小企业数量多,地区分布广泛,行业分布跨度大。随着全球经济一体化的发展和电子商务的兴起,中小企业之间的竞争将越来越激烈。网络及电子商务的迅猛发展突破了时间、空间的局限性,给中小企业带来了更多的发展机会,同时也增大了企业之间的竞争强度。这就要求中小企业必须改变企业的经营管理模式,提高企业的运营效率。随着技术发展,电脑操作及管理日趋简化,电脑知识日趋普及,同时市场经济快速多变,竞争激烈,企业采用电脑管理进货、库存、销售等诸多环节也已成为必然趋势。
    关键词:进销存管理系统;B/S结构;mysql数据库;JSP;spring;springMVC;spring boot;JPA
    ABSTRACT
    Since twenty-first Century, more and more data and information are needed in business management. A large number of data and complex data makes the ancient way of manual processing of data gradually appear inadequate. Even some of the information processing in the manual processing mode can not be achieved at all, only the use of the computer's high operating frequency for iterative calculation. And recently, the country is promoting public entrepreneurship, many small and medium enterprises. Small and medium-sized enterprises play an important role in China's economic development. At present, there are a large number of small and medium-sized enterprises in china. With the development of global economic integration and the rise of e-commerce, the competition between small and medium enterprises will become more and more fierce. The rapid development of network and electronic commerce has broken through the limitation of time and space, and has brought more opportunities for the development of small and medium-sized enterprises. This requires the small and medium-sized enterprises must change the mode of operation and management of enterprises, improve the operational efficiency of enterprises. With the development of computer technology, operation and management is simplified, the growing popularity of computer knowledge, and fast changing market economy, intense competition, enterprise computer management purch asing inventory sales and many other sectors and has become an inevitable trend.
    Keywords: Purchase, sales and inventory management system; B / S structure; Mysql Database; JSP; Spring;SpringMVC;spring boot;JPA
    目 录
    第一章 绪论 1
    1.1 研究背景和意义 1
    1.2 研究目标 1
    1.3 论文结构 1
    1.4 本章小结 2
    第二章 相关技术与方法 3
    2.1 架构概述 3
    2.2 关键技术简介 3
    2.3 开发工具 4
    2.4 本章小结 5
    第三章 系统分析 6
    3.1 可行性分析 6
    3.2 需求分析 6
    3.3 本章小结 15
    第四章 系统设计 16
    4.1 系统类分析 16
    4.2 关键业务设计 21
    4.3 数据库设计 23
    4.4 本章小结 33
    第五章 系统实现 35
    5.1 用户登录 35
    5.2 采购管理 37
    5.3 库存管理 39
    5.4 销售管理 42
    5.5 备份与恢复 43
    5.6 本章小结 46
    第六章 系统测试 47
    6.1 系统测试综述 47
    6.2 测试用例 48
    6.3 测试分析 51
    6.4 本章小结 52
    第七章 总结 53
    参考文献 54
    致 谢 55

    环境需要
    1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
    2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
    3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
    4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 
    5.数据库:MySql 5.7版本;
    6.是否Maven项目:否;

    技术栈

    1. 后端:Spring+SpringMVC+Mybatis
    2. 前端:JSP+CSS+JavaScript+jQuery

    使用说明

    1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
    2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;
      若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
    3. 将项目中springmvc-servlet.xml配置文件中的数据库配置改为自己的配置;
    4. 运行项目,在浏览器中输入http://localhost:8080/ 登录

    运行截图

     用户管理控制层:


    package com.houserss.controller;

    import javax.servlet.http.HttpSession;

    import org.apache.commons.lang3.StringUtils;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RequestMethod;
    import org.springframework.web.bind.annotation.RequestParam;
    import org.springframework.web.bind.annotation.ResponseBody;

    import com.houserss.common.Const;
    import com.houserss.common.Const.Role;
    import com.houserss.common.ServerResponse;
    import com.houserss.pojo.User;
    import com.houserss.service.IUserService;
    import com.houserss.service.impl.UserServiceImpl;
    import com.houserss.util.MD5Util;
    import com.houserss.util.TimeUtils;
    import com.houserss.vo.DeleteHouseVo;
    import com.houserss.vo.PageInfoVo;

    /**

    • Created by admin
      */

    @Controller
    @RequestMapping("/user/")
    public class UserController {

    @Autowired
    private IUserService iUserService;
    
    /**
     * 用户登录
     * @param username
     * @param password
     * @param session
     * @return
     */
    @RequestMapping(value = "login.do",method = RequestMethod.POST)
    @ResponseBody
    public ServerResponse<User> login(User user,String uvcode, HttpSession session){
        String code = (String)session.getAttribute("validationCode");
        if(StringUtils.isNotBlank(code)) {
            if(!code.equalsIgnoreCase(uvcode)) {
                return ServerResponse.createByErrorMessage("验证码不正确");
            }
        }
        ServerResponse<User> response = iUserService.login(user.getUsername(),user.getPassword());
        if(response.isSuccess()){
            session.setAttribute(Const.CURRENT_USER,response.getData());
        }
        return response;
    }
    
    
    
    

    }
     

    管理员管理控制层:

    package com.sxl.controller.admin;

    import java.util.List;
    import java.util.Map;

    import javax.servlet.http.HttpServletRequest;

    import org.springframework.http.ResponseEntity;
    import org.springframework.stereotype.Controller;
    import org.springframework.ui.Model;
    import org.springframework.web.bind.annotation.RequestMapping;

    import com.sxl.controller.MyController;

    @Controller("adminController")
    @RequestMapping(value = "/admin")
    public class AdminController extends MyController {

    @RequestMapping(value = "/index")
    public String frame(Model model, HttpServletRequest request)throws Exception {
        return "/admin/index";
    }
    
    @RequestMapping(value = "/main")
    public String main(Model model, HttpServletRequest request)throws Exception {
        return "/admin/main";
    }
    
    @RequestMapping(value = "/tj1")
    public String tj1(Model model, HttpServletRequest request)throws Exception {
        String sql="select DATE_FORMAT(insertDate,'%Y-%m-%d') dates,sum(allPrice) price from t_order order by DATE_FORMAT(insertDate,'%Y-%m-%d')  desc";
        List<Map> list = db.queryForList(sql);
        model.addAttribute("list", list);
        System.out.println(list);
        return "/admin/tj/tj1";
    }
    
    
    @RequestMapping(value = "/password")
    public String password(Model model, HttpServletRequest request)throws Exception {
        return "/admin/password";
    }
    
    
    @RequestMapping(value = "/changePassword")
    public ResponseEntity<String> loginSave(Model model,HttpServletRequest request,String oldPassword,String newPassword) throws Exception {
        Map admin = getAdmin(request);
        if(oldPassword.equals(admin.get("password").toString())){
            String sql="update t_admin set password=? where id=?";
            db.update(sql, new Object[]{newPassword,admin.get("id")});
            return renderData(true,"1",null);
        }else{
            return renderData(false,"1",null);
        }
    }

    }
     

    修改密码业务逻辑:

    package com.sxl.controller.admin;

    import java.util.Map;

    import javax.servlet.http.HttpServletRequest;

    import org.springframework.http.ResponseEntity;
    import org.springframework.stereotype.Controller;
    import org.springframework.ui.Model;
    import org.springframework.web.bind.annotation.RequestMapping;

    import com.sxl.controller.MyController;

    @Controller("userController")
    @RequestMapping(value = "/user")
    public class UserController extends MyController {

    @RequestMapping(value = "/index")
    public String frame(Model model, HttpServletRequest request)throws Exception {
        return "/user/index";
    }
    
    @RequestMapping(value = "/main")
    public String main(Model model, HttpServletRequest request)throws Exception {
        return "/user/main";
    }
    
    
    @RequestMapping(value = "/password")
    public String password(Model model, HttpServletRequest request)throws Exception {
        return "/user/password";
    }
    
    
    @RequestMapping(value = "/changePassword")
    public ResponseEntity<String> loginSave(Model model,HttpServletRequest request,String oldPassword,String newPassword) throws Exception {
        Map user = getUser(request);
        if(oldPassword.equals(user.get("password").toString())){
            String sql="update t_user set password=? where id=?";
            db.update(sql, new Object[]{newPassword,user.get("id")});
            return renderData(true,"1",null);
        }else{
            return renderData(false,"1",null);
        }
    }
    @RequestMapping(value = "/mine")
    public String mine(Model model, HttpServletRequest request)throws Exception {

    Map user =getUser(request);Map map = db.queryForMap("select * from t_user where id=?",new Object[]{user.get("id")});model.addAttribute("map", map); return "/user/mine";

    }
    
    
    
    @RequestMapping(value = "/mineSave")
    public ResponseEntity<String> mineSave(Model model,HttpServletRequest request,Long id
        ,String username,String password,String name,String gh,String mobile) throws Exception{
        int result = 0;
            String sql="update t_user set name=?,gh=?,mobile=? where id=?";
            result = db.update(sql, new Object[]{name,gh,mobile,id});
        if(result==1){
            return renderData(true,"操作成功",null);
        }else{
            return renderData(false,"操作失败",null);
        }
    }
    }

    通用管理模块:
    package com.sxl.controller;

    import java.nio.charset.Charset;
    import java.util.Locale;
    import java.util.ResourceBundle;

    import javax.servlet.http.HttpServletRequest;

    import org.apache.commons.lang.StringUtils;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.http.HttpHeaders;
    import org.springframework.http.HttpStatus;
    import org.springframework.http.MediaType;
    import org.springframework.http.ResponseEntity;

    import com.sxl.util.JacksonJsonUtil;
    import com.sxl.util.StringUtil;
    import com.sxl.util.SystemProperties;

    public class BaseController {

    public static final Long EXPIRES_IN = 1000 * 3600 * 24 * 1L;// 1天
    
    @Autowired
    private SystemProperties systemProperties;
    
    /**
     * 获得配置文件内容
     */
    public String getConfig(String key) {
        return systemProperties.getProperties(key);
    }
    
    /**
     * 返回服务器地址 like http://192.168.1.1:8441/UUBean/
     */
    public String getHostUrl(HttpServletRequest request) {
        String hostName = request.getServerName();
        Integer hostPort = request.getServerPort();
        String path = request.getContextPath();
    
        if (hostPort == 80) {
            return "http://" + hostName + path + "/";
        } else {
            return "http://" + hostName + ":" + hostPort + path + "/";
        }
    }
    
    /***
     * 获取当前的website路径 String
     */
    public static String getWebSite(HttpServletRequest request) {
        String returnUrl = request.getScheme() + "://"
                + request.getServerName();
    
        if (request.getServerPort() != 80) {
            returnUrl += ":" + request.getServerPort();
        }
    
        returnUrl += request.getContextPath();
    
        return returnUrl;
    }
    
    
    
    /**
     * 初始化HTTP头.
     * 
     * @return HttpHeaders
     */
    public HttpHeaders initHttpHeaders() {
        HttpHeaders headers = new HttpHeaders();
        MediaType mediaType = new MediaType("text", "html",
                Charset.forName("utf-8"));
        headers.setContentType(mediaType);
        return headers;
    }
    
    /**
     * 返回 信息数据
     * 
     * @param status
     * @param msg
     * @return
     */
    public ResponseEntity<String> renderMsg(Boolean status, String msg) {
        if (StringUtils.isEmpty(msg)) {
            msg = "";
        }
        String str = "{\"status\":\"" + status + "\",\"msg\":\"" + msg + "\"}";
        ResponseEntity<String> responseEntity = new ResponseEntity<String>(str,
                initHttpHeaders(), HttpStatus.OK);
        return responseEntity;
    }
    
    /**
     * 返回obj数据
     * 
     * @param status
     * @param msg
     * @param obj
     * @return
     */
    public ResponseEntity<String> renderData(Boolean status, String msg,
            Object obj) {
        if (StringUtils.isEmpty(msg)) {
            msg = "";
        }
        StringBuffer sb = new StringBuffer();
        sb.append("{");
        sb.append("\"status\":\"" + status + "\",\"msg\":\"" + msg + "\",");
        sb.append("\"data\":" + JacksonJsonUtil.toJson(obj) + "");
        sb.append("}");
    
        ResponseEntity<String> responseEntity = new ResponseEntity<String>(
                sb.toString(), initHttpHeaders(), HttpStatus.OK);
        return responseEntity;
    }
    
    
    /***
     * 获取IP(如果是多级代理,则得到的是一串IP值)
     */
    public static String getIpAddr(HttpServletRequest request) {
        String ip = request.getHeader("x-forwarded-for");
        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
            ip = request.getHeader("Proxy-Client-IP");
        }
    
        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
            ip = request.getHeader("WL-Proxy-Client-IP");
        }
    
        if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) {
            ip = request.getRemoteAddr();
        }
    
        if (ip != null && ip.length() > 0) {
            String[] ips = ip.split(",");
            for (int i = 0; i < ips.length; i++) {
                if (!"unknown".equalsIgnoreCase(ips[i])) {
                    ip = ips[i];
                    break;
                }
            }
        }
    
        return ip;
    }
    
    /**
     * 国际化获得语言内容
     * 
     * @param key
     *            语言key
     * @param args
     * @param argsSplit
     * @param defaultMessage
     * @param locale
     * @return
     */
    public static String getLanguage(String key, String args, String argsSplit,
            String defaultMessage, String locale) {
        String language = "zh";
        String contry = "cn";
        String returnValue = defaultMessage;
    
        if (!StringUtil.isEmpty(locale)) {
            try {
                String[] localeArray = locale.split("_");
                language = localeArray[0];
                contry = localeArray[1];
            } catch (Exception e) {
            }
        }
    
        try {
            ResourceBundle resource = ResourceBundle.getBundle("lang.resource",
                    new Locale(language, contry));
            returnValue = resource.getString(key);
            if (!StringUtil.isEmpty(args)) {
                String[] argsArray = args.split(argsSplit);
                for (int i = 0; i < argsArray.length; i++) {
                    returnValue = returnValue.replace("{" + i + "}",
                            argsArray[i]);
                }
            }
        } catch (Exception e) {
        }
    
        return returnValue;
    }

    }
     


    如果本文对你有帮助,别忘记给我个3连 ,点赞,转发,评论,

    咱们下期见!答案获取方式:已赞 已评 已关~

    学习更多JAVA知识与技巧,关注与私信博主(03)

     

  • 相关阅读:
    Java 多线程共享模型之管程(下)
    486.预测赢家
    flink中维表Join几种常见方式总结
    卷积神经网络中的卷积核,卷积神经网络大小计算
    CentOS 7 安装Java环境
    手把手教你从零开始腾讯云服务器部署(连接建站教程)
    微信小程序学习day01
    工程管理系统简介 工程管理系统源码 java工程管理系统 工程管理系统功能设计
    计算属性,侦听属性,方法区别及例子
    来看下这篇文章,教你如何实现一个SpringBoot的Mybatis分库分表组件
  • 原文地址:https://blog.csdn.net/weixin_70730532/article/details/125427214