Java项目:ssm校内超市管理系统

news2024/9/26 1:24:58

作者主页:源码空间站2022

 简介:Java领域优质创作者、Java项目、学习资料、技术互助

文末获取源码

项目介绍

本系统分为管理员与普通用户两种角色。采用后端SSM框架,前端BootStrap(前后端不分离)的系统架构模式,实现了基本的超市管理功能;

本系统实现了超市管理的基本功能,包括商品库存模块,商品分类模块,供应商管理模块,销售统计模块以及用户管理模块。

环境需要

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项目:是;

技术栈

- 后端:Spring + SpringMVC + MyBatis
- 前端:BootStrap
- 插件:PageHelper分页插件

- 环境:Jdk 1.8 + Tomcat 9.0.45 + Maven管理工具 + MySQL v5.7.33

使用说明

1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;

2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;

若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;

3. 将项目中jdbc.properties配置文件中的数据库配置改为自己的配置;

4. 运行项目,访问路径(本地部署):localhost:8080/sms

运行截图

相关代码

UserController

package com.wxl.sms.controller;

import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.wxl.sms.bean.User;
import com.wxl.sms.service.UserService;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.util.List;

/**
 * @author wxl on 2021/5/8 22:25
 */
@Controller
public class UserController {
    @Resource
    private UserService userService;

    /**
     * 系统登录处理
     *
     * @param request 获取登录表单数据
     * @param model 存储显示登录状态信息
     * @param session 用于过滤器判断, 存储登录状态信息
     * @return login.jsp、main.jsp
     */
    @RequestMapping("/login")
    public String login(HttpServletRequest request, Model model, HttpSession session) {
        String loginName;
        String loginPassword;
        String rememberMe;
        if (request.getParameter("loginName") != null
                && !request.getParameter("loginName").equals("")) {
            loginName = request.getParameter("loginName");
            loginPassword = request.getParameter("loginPassword");
        } else {
            model.addAttribute("ERROR_INFO", "请输入用户名!");
            return "../login";
        }

        System.out.println("username = " + loginName + ", password = " + loginPassword);

        User userInDB = userService.getUserByUsername(loginName);
        System.out.println("======> " + userInDB);
        if (userInDB == null) {
//            System.out.println("用户名输入错误!");
            model.addAttribute("ERROR_INFO", "用户名输入错误!");
            return "../login";
        } else if (!userInDB.getPassword().equals(loginPassword)) {
//            System.out.println("密码输入错误!");
            model.addAttribute("ERROR_INFO", "密码输入错误!");
            return "../login";
        } else {
//            System.out.println("登录成功!");
            model.addAttribute("ERROR_INFO", null);
            // 判断session中是否有User, 有的话就是已经登录 -> 即放行
            session.setAttribute("user", userInDB);

            rememberMe = request.getParameter("rm");
            if ("1".equals(rememberMe)) {
                // 设置勾选“记住我”之后保存登录状态为24h
                session.setMaxInactiveInterval(24 * 60 * 60);
            }

            return "other/main";
        }
    }

    /**
     * 处理退出系统
     *
     * @param session 用于清除系统登录状态
     * @return 登录页面
     */
    @RequestMapping("/exit")
    public String exitSystem(HttpSession session) {
        // 用户点击退出登录, 这里进行session中清除当前用户信息
        session.removeAttribute("user");

        return "../login";
    }


    /**
     * 获取当前系统中的所有用户用于信息显示
     *
     * @param pn 显示页码
     * @param model 为了将数据传入到cookie域中方便取出数据
     * @return user.jsp
     */
    @RequestMapping("/userList")
    public String getAllUser(@RequestParam(value = "pn", defaultValue = "1") Integer pn, Model model
            /*, @RequestAttribute("ADD_USER_MSG") String msg*/) {
        PageHelper.startPage(pn, 5);
        List<User> allUser = userService.getAllUser();
        PageInfo<User> pageInfo = new PageInfo<>(allUser, 5);
        model.addAttribute("pageInfo", pageInfo);

        // 显示添加用户信息操作
//        model.addAttribute("ADD_USER_STATE_MSG", msg);

        return "user/user";
    }

    /**
     * 仅仅是跳转到新增用户界面
     *
     * @return userAdd.jsp
     */
    @RequestMapping("toAddUser")
    public String toAddUserPage() {
        return "user/userAdd";
    }


    /**
     * 添加系统登录用户
     *
     * @param user 表单封装的用户对象
     * @return 用户列表
     */
    @RequestMapping("/addUser")
    public String addUser(User user, HttpServletRequest request) {
        // ****************添加用户时的用户名不可以与之前的重复*******************
        List<User> allUser = userService.getAllUser();
        for (User savedUser : allUser) {
            if (savedUser.getUsername().equals(user.getUsername())) {
                System.out.println("用户名已存在, 添加失败");
                request.setAttribute("ADD_USER_MSG", "用户名已存在, 添加失败");
//                model.addAttribute("ADD_USER_MSG", "用户名已存在, 添加失败");
//                session.setAttribute("ADD_USER_MSG", "用户名已存在, 添加失败");
                return "forward:userList";
            }
        }
        // *******************************************************************

        int addUser = userService.addUser(user);
        System.out.println("addUser ==> " + addUser);
        request.setAttribute("ADD_USER_MSG", "添加用户 " + user.getUsername() + " 成功");
//        model.addAttribute("ADD_USER_MSG", "添加用户 " + user.getUsername() + " 成功");
//        session.setAttribute("ADD_USER_MSG", "添加用户 " + user.getUsername() + " 成功");

        return "forward:userList";
    }

    /**
     * 重置所有用户的密码为123456
     *
     * @return 重定向到userList.jsp
     */
    @RequestMapping("/resetAllPassword")
    public String resetAllPassword() {
        int resetAllPassword = userService.resetAllPassword();
        System.out.println("resetAllPassword ==> " + resetAllPassword);

        return "forward:userList";
    }

    /**
     * 重置选中用户密码
     *
     * @param id 选中用户id
     * @return 重定向到userList.jsp
     */
    @RequestMapping("/resetSelectedUserPassword")
    public String resetSelectedUserPassword(@RequestParam("id") Integer id) {
        int resetPasswordByUserId = userService.resetPasswordByUserId(id);
        System.out.println("resetPasswordByUserId ==> " + resetPasswordByUserId);

        return "forward:userList";
    }

    /**
     * 删除选中用户
     *
     * @param id 选中用户id
     * @return 重定向到userList.jsp
     */
    @RequestMapping("/deleteSelectedUser")
    public String deleteSelectedUser(@RequestParam("id") Integer id, HttpSession session) {
        // ********************如果删除选中的用户是当前系统登录本人, 则删除失败
        User user = (User) session.getAttribute("user");
//        System.out.println("---> 当前系统登录用户:" + user);
        User userByUserId = userService.getUserByUserId(id);
//        System.out.println("---> 根据id查的用户:" + userByUserId);
        if (user.getId().equals(userByUserId.getId())) {
            System.out.println("您不可以删除您自己");
            return "forward:userList";
        }

        int deleteUserByUserId = userService.deleteUserByUserId(id);
        System.out.println("deleteUserByUserId ==> " + deleteUserByUserId);

        return "forward:userList";
    }

    /**
     * 注销当前用户并退出
     *
     * @param id 选中用户id
     * @return 注销后退出系统
     */
    @RequestMapping("/deleteCurrentUser")
    public String deleteCurrentUser(@RequestParam("id") Integer id) {
        // ******************如果当前用户是最后一个管理员账户, 设置不可删除
        List<User> allAdmin = userService.getAllAdmin();
        if (allAdmin.size() == 1) {
            System.out.println("您是当前系统的最后一位管理员, 禁止删除");
            return "forward:userList";
        }

        int deleteUserByUserId = userService.deleteUserByUserId(id);
        System.out.println("deleteUserByUserId ==> " + deleteUserByUserId);

        return "forward:/exit";
    }

    /**
     * 跳转到修改当前用户密码界面
     *
     * @return updatePassword.jsp
     */
    @RequestMapping("/toUpdateCurrentPasswordPage")
    public String toUpdateCurrentPasswordPage() {
        return "user/updatePassword";
    }

    /**
     * 修改当前用户密码
     *
     * @param request 获取输入的新密码
     * @param session 获取当前登录用户id
     * @param model 存储修改结果
     * @return main.jsp
     */
    @RequestMapping("/updateCurrentUserPassword")
    public String updateCurrentUserPassword(HttpServletRequest request, HttpSession session, Model model) {
        String password = request.getParameter("password");
        User user = (User) session.getAttribute("user");
        int updatePassword = userService.updatePassword(user.getId(), password);
        System.out.println("updatePassword ==> " + updatePassword);
        model.addAttribute("updatePassword", updatePassword);

        return "other/main";
    }

    // ********以下两个Controller是为了防止JSP页面跳转失败而加的, 无逻辑操作

    /**
     * 跳转到首页
     *
     * @return main.jsp
     */
    @RequestMapping("/home")
    public String toHomePage() {
        return "other/main";
    }

    /**
     * 跳转到结算业面
     *
     * @return checkout.jsp
     */
    @RequestMapping("/toCheckout")
    public String toCheckoutPage() {
        return "other/checkout";
    }
}

 如果也想学习本系统,下面领取。关注并回复:179ssm

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/97579.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

python中调用命令行执行外部程序

&#x1f31e;欢迎来到python的世界 &#x1f308;博客主页&#xff1a;卿云阁 &#x1f48c;欢迎关注&#x1f389;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f31f;本文由卿云阁原创&#xff01; &#x1f320;本阶段属于练气阶段&#xff0c;希望各位仙友顺利完成…

STM32的三种更新固件的方式

说明&#xff1a; stm32有三种更新固件的方式&#xff0c;分别为&#xff08;1&#xff09;DFU模式&#xff08; Development Firmware Upgrade 即“开发固件升级”&#xff09;&#xff1b;&#xff08;2&#xff09;SWD/JLINK 下载 &#xff08;3&#xff09;第三方bootload…

NoSQL数据库原理与应用综合项目——HBase篇

NoSQL数据库原理与应用综合项目——HBase篇 文章目录NoSQL数据库原理与应用综合项目——HBase篇0、 写在前面1、本地数据或HDFS数据导入到HBase2、Hbase数据库表操作2.1 Java API 连接HBase2.2 查询数据2.3 插入数据2.4 修改数据2.5 删除数据3、Windows远程连接HBase4、数据及源…

springboot常用组件集成

今天与大家分享spring-mybatis、reids集成&#xff0c;druid数据库连接池。如果有问题&#xff0c;望指教。 1. 创建项目 File -> New -> project ...Spring Initializr选择项目需要的第三方组件注&#xff1a;可以参考第二次课演示的操作步骤&#xff0c;有详细的拷图…

java药店网站药店系统药店源码刷脸支付源码

简介 首页&#xff0c;搜索商品&#xff0c;详情页&#xff0c;根据不同规格显示不同的商品价格&#xff0c;加入购物车&#xff0c;立即购买&#xff0c;评价列表展示&#xff0c;商品详情展示&#xff0c;商品评分&#xff0c;分类商品&#xff0c;标签查询&#xff0c;更多…

MapReduce 概述原理说明

文章目录MapReduce概述一、MapReduce定义二、MapReduce 优缺点1、MapReduce 优点(1)、MapReduce 易于编程(2)、良好的扩展性(3)、高容错性(4)、适合PB级以上的海量数据的离线处理2、MapReduce 缺点(1)、不擅长实时计算(2)、不擅长流式计算(3)、不擅长DAG(有向图)计算三、MapRed…

二叉树进阶

博主的博客主页&#xff1a;CSND博客 Gitee主页&#xff1a;博主的Gitee 博主的稀土掘金&#xff1a;稀土掘金主页 博主的b站账号&#xff1a;程序员乐 公众号——《小白技术圈》&#xff0c;回复关键字&#xff1a;学习资料。小白学习的电子书籍都在这。 目录根据二叉树创建字…

基于java+springmvc+mybatis+vue+mysql的协同过滤算法的电影推荐系统

项目介绍 基于协同过滤算法的电影推荐系统利用网络沟通、计算机信息存储管理&#xff0c;有着与传统的方式所无法替代的优点。比如计算检索速度特别快、可靠性特别高、存储容量特别大、保密性特别好、可保存时间特别长、成本特别低等。在工作效率上&#xff0c;能够得到极大地…

Hive自定义UDF函数

以下基于hive 3.1.2版本 Hive中自定义UDF函数&#xff0c;有两种实现方式&#xff0c;一是通过继承org.apache.hadoop.hive.ql.exec.UDF类实现&#xff0c;二是通过继承org.apache.hadoop.hive.ql.udf.generic.GenericUDF类实现。 无论是哪种方式&#xff0c;实现步骤都是&…

网上超市系统

开发工具(eclipse/idea/vscode等)&#xff1a; 数据库(sqlite/mysql/sqlserver等)&#xff1a; 功能模块(请用文字描述&#xff0c;至少200字)&#xff1a; 研究内容&#xff1a;设计开发简单购网上超市系统&#xff0c;采用Java语言&#xff0c;使用ySQL数据库&#xff0c; 实…

毕业设计 单片机家用燃气可视化实时监控报警仪 - 物联网 嵌入式 stm32

文章目录0 前言1 简介2 主要器件3 实现效果4 设计原理4.1 硬件部分4.2 软件部分5 部分核心代码6 最后0 前言 &#x1f525; 这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的毕设题目缺少创新和亮点&#xff0c;往往达不到毕业答辩的要求&#xff0c;这两…

SAP ABAP 开发管理 代码内存标记 位置使用清单(Mark of memory id)

SAP ABAP 开发管理 代码内存标记 位置使用清单&#xff08;Mark of memory id&#xff09; 引言&#xff1a; 代码内存标记&#xff08;Mark of memory id&#xff09;是我开发中对 ABAP MEMORY ID 使用管理的一种方法&#xff0c;他能有效保障使用了 ABAP MEMORY ID 程序的可…

25岁从运维转向软件开发是选择Python还是Java

25岁的年龄不大&#xff0c;若是有扎实的基础&#xff0c;后期转转向软件开发是个不错的选择&#xff0c;Python是目前最火的编程语言&#xff0c;python作为人工智能的主要编程语言也有着不错的发展前景。 关于编程语言的选择&#xff0c;如果从就业的角度出发应该重点考虑一…

[附源码]Nodejs计算机毕业设计基于框架的校园爱心公益平台的设计与实现Express(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置&#xff1a; Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术&#xff1a; Express框架 Node.js Vue 等等组成&#xff0c;B/S模式 Vscode管理前后端分…

Mechatrolink III转EtherCAT网关模块解决方案

概述 工业以太网在工业控制领域越来越流行&#xff0c;协议种类较多&#xff0c;例如Mechatrolink III、EtherCAT、Powerlink、Profinet、EtherNet/IP等等&#xff0c;在数控加工领域主流的协议有Mechatrolink III、EtherCAT。但是各种协议之间很难通信协作。 安川电机的Mech…

CPOFDM-16QAM性能仿真,输出接收端的星座图

目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 CP-OFDM&#xff08;Cyclic Prefix Orthogonal Frequency Division Multiplexing&#xff0c;循环前缀正交频分复用&#xff09;通信系统采用多个正交子载波&#xff08;Orthogonalsub-Carrier&a…

非科班出身零基础能学好编程吗

近几年IT行业越来越火热&#xff0c;有很多人想转行跨界进入这个行业&#xff0c;那么作为初学者的你&#xff0c;是不是也很困惑&#xff0c;0基础非科班出身能学好编程吗&#xff1f; 编程是一个技术活&#xff0c;没有专业知识想进入这个行业是行不通的&#xff0c;这也决定…

Go工程化项目布局

如果你尝试学习Go&#xff0c;或者你正在为自己建立一个Poc或者一个玩具项目&#xff0c;这个项目布局是没有啥必要的&#xff0c;从一些简单的事情开始&#xff08;一个main文件绰绰有余&#xff09;。当有更多的人参与这个项目的时候&#xff0c;你讲需要更多的结构&#xff…

基于springboot超市进销存管理系统(Java毕业设计,包含部署文档)

大家好✌&#xff01;我是CZ淡陌。一名专注以理论为基础实战为主的技术博主&#xff0c;将再这里为大家分享优质的实战项目&#xff0c;本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目&#xff0c;希望你能有所收获&#xff0c;少走一些弯路…

神经网络种类及应用领域,常用的神经网络有哪些

1、神经网络算法的三大类分别是&#xff1f; 神经网络算法的三大类分别是&#xff1a; 1、前馈神经网络&#xff1a; 这是实际应用中最常见的神经网络类型。第一层是输入&#xff0c;最后一层是输出。如果有多个隐藏层&#xff0c;我们称之为“深度”神经网络。他们计算出一…