基于SSM的在线商城系统(最新)

简介: 该系统适合选择框架为SSM,基础中等或以下,做类似商城系统,要求页面美观度高的同学。主要功能包括:完整的商城业务流程,比如用户管理,商品管理、订单管理、分类管理等,满足商城的基本要求。

系统使用技术:SSM


前端技术:bootstrap、css、js等


开发工具:eclipse或idea


数据库:mysql5.7


项目介绍:



该系统适合选择框架为SSM,基础中等或以下,做类似商城系统,要求页面美观度高的同学。主要功能包括:完整的商城业务流程,比如用户管理,商品管理、订单管理、分类管理等,满足商城的基本要求。


下面我们来看看功能。



系统登陆界面:


http://localhost:8080/technology/page/login.html


20210813173758294.png


首页


查看热销商品


image.png


分类查看


可以按照分类查看商品


image.png



商品详情


可以查看商品详情


20210813173914525.png


个人中心


用户登录后可以查看个人信息


20210813173933266.png


购物车


可以查看购物车内商品


20210813173953324.png


我的订单


可以查看个人订单信息


20210813174020676.png


后台首页


可以统计商品、订单信息


image.png


用户管理


对用户进行管理


2021081317410378.png


商品管理


对商品进行管理


20210813174123747.png


订单管理


对订单进行管理


20210813174137483.png


代码



用户登录:


/**
     * produces="application/json;charset=UTF-8":防止ajax获取中文时出现乱码
     * @return 将数据回传给ajax
     */
    @ResponseBody
    @RequestMapping(value = "/usertologin", method = RequestMethod.POST, produces = "application/json;charset=UTF-8")
    public Object usertologin(
            Integer uid,
            String upswd,
            HttpServletResponse response,
            HttpSession session) {
        //创建 JSONObject 对象,它会把放入的数据以 json 的数据格式存储,对于集合类型的数据还要用到 JSONArray 数组
        JSONObject object = new JSONObject();
        int i = loginSvc.checkUid(uid);
        if (i > 0) { // 证明账号存在,进行密码验证
            object.put("num_i", i);
            object.put("SUCCESS_MESSAGE", "账号验证成功!");
            int j = loginSvc.checkLogin(new User(uid, upswd));
            if (j > 0) { // 密码正确,进行相同账号的登录验证
                object.put("num_j", j);
                object.put("SUCCESS_MESSAGE2", "密码验证成功!");
                User user_session = (User) CoreUtil.getSession().getAttribute(Constants.LOGIN_USER);
                if (user_session!=null) { //证明用户已登录,不允许相同账号的登录
                    object.put("ERROR_MESSAGE", "该账号已登录!");
                    return object.toString();
                } else {  //尚未有该用户登录,需要获取个人信息,保存用户名等,用以显示
                    /*String ipAddr = ToolsUtil.getIpAddr(request);
            System.out.println("当前用户IP为:" + ipAddr);*/
                    User user = loginSvc.showUserInfo(uid);
                    /*保存信息,用于验证登录拦截器*/
                    session.setAttribute(Constants.LOGIN_USER, user);
                    session.setAttribute("myinfo", user);
                    String lasttime = ToolsUtil.getTime("yyyy-MM-dd HH:mm:ss", 0);
                    User user2 = loginSvc.showUserInfo(uid);
                    user2.setLasttime(lasttime);
                    int k = loginSvc.upUser(user2); // 此处可以对k进行判断,提示等
                    String logintime = ToolsUtil.getTime("yyyy年MM月dd日 HH:mm:ss", 0);
                    // 登录日志记录,此处为日志插入单独写了一个方法,调用即可
                    String descb = "您在【" + logintime + "】登录了本商城";
                    Log log = ToolsUtil.insertLog(uid, descb);
                    int m = loginSvc.insertUserLog(log);
                }
            } else {
                object.put("ERROR_MESSAGE", "密码错误,请重新输入!");
            }
        } else {
            object.put("ERROR_MESSAGE", "账号不存在!");
        }
        return object.toString();   //由于前端ajax在接收服务器数据时一般是字符串,因此要用“.toString()”方法转化
    }


生成订单:


@RequestMapping("/addOrder")
    public String addOrder(
            String orderaddress,
            @RequestParam(required = false) Integer[] pid,
            @RequestParam(required = false) int[] pronum,
            HttpSession session) {
        Order order = new Order();
        int id = getLoginUserId();
        order.setUid(id);
        order.setOrderaddress(orderaddress);
        /*Integer[] pid = {100001, 100002};
        int[] pronum = {23, 31};*/
        List<Map<String, Object>> prolist = productSvc.proSelByCIds(pid, pronum);
        List<OrderDetail> orderDetails = new ArrayList<OrderDetail>();
        for (Map<String, Object> aProlist : prolist) {
            OrderDetail od = new OrderDetail();
            od.setPid((Integer) aProlist.get("pid"));
            od.setPimg((String) aProlist.get("pimg"));
            od.setPname((String) aProlist.get("pname"));
            od.setPrice((Float) aProlist.get("price"));
            od.setOdetailnum((Integer) aProlist.get("pronum"));
            orderDetails.add(od);
        }
        /* 邮费 10-30 随机 */
        Random random = new Random();
        order.setPostalfee(random.nextInt(20) + 10);
        int i = orderSvc.addOrder(order, orderDetails); //会调用Dao,向order表插入数据
        if(i>0){
            String descb = "下单成功,订单号:【" + order.getOrdercode() + "】";
            Log log = ToolsUtil.insertLog(UserUtil.getLoginUserId(), descb);
            loginSvc.insertUserLog(log);
            Order orderss = iorderDao.getOrderDetailById(order.getOrderid());
        List<OrderDetail> details =  orderss.getOdetails();
        for(int i1= 0;i1<details.size();i1++){
          Product p = iProductDao.proSelByCId(details.get(i1).getPid());
          Product product = new Product();
          int stock = p.getStock() - details.get(i1).getOdetailnum();
          product.setStock(stock);
          product.setPid(details.get(i1).getPid());
          iProductDao.updataStock(product);
        }
        }
        System.out.println("----------" + i);
        return "redirect:getMyOrders";
    }


以上就是部分功能展示,从整体上来看,本系统功能是十分完整的,而且也与当前的热点话题关联,界面设计简洁大方,交互友好,数据库设计也很合理,规模适中,比较适合毕业设计和课程设计的相关应用。


好了,今天就到这儿吧,小伙伴们点赞、收藏、评论,一键三连走起呀,下期见~~

相关文章
|
7月前
|
存储 Java 关系型数据库
ssm026校园美食交流系统(文档+源码)_kaic
本文介绍了基于Java语言和MySQL数据库的校园美食交流系统的设计与实现。该系统采用B/S架构和SSM框架,旨在提高校园美食信息管理的效率与便捷性。主要内容包括:系统的开发背景、目的及内容;对Java技术、MySQL数据库、B/S结构和SSM框架的介绍;系统分析部分涵盖可行性分析、性能分析和功能需求分析;最后详细描述了系统各功能模块的具体实现,如登录、管理员功能(美食分类管理、用户管理等)和前台首页功能。通过此系统,管理员可以高效管理美食信息,用户也能方便地获取和分享美食资讯,从而提升校园美食交流的管理水平和用户体验。
|
6月前
|
Java 关系型数据库 MySQL
weixin050高校体育场管理系统+ssm(文档+源码)_kaic
本文针对高校体育场管理系统的开发与实现进行详细介绍。随着经济快速发展,人们对手机软件需求增加,高校体育场管理系统应运而生。系统采用JAVA技术、Mysql数据库和SSM框架等成熟技术,通过分析功能需求、可行性及性能,设计出包含管理员、用户和学生角色的功能模块。系统实现用户注册登录、信息管理等功能,简化传统手工统计模式,提高管理效率,满足用户对信息获取的及时性与准确性需求。
weixin050高校体育场管理系统+ssm(文档+源码)_kaic
|
6月前
|
前端开发 Java 关系型数据库
基于ssm的社区物业管理系统,附源码+数据库+论文+任务书
社区物业管理系统采用B/S架构,基于Java语言开发,使用MySQL数据库。系统涵盖个人中心、用户管理、楼盘管理、收费管理、停车登记、报修与投诉管理等功能模块,方便管理员及用户操作。前端采用Vue、HTML、JavaScript等技术,后端使用SSM框架。系统支持远程安装调试,确保顺利运行。提供演示视频和详细文档截图,帮助用户快速上手。
216 17
|
6月前
|
前端开发 Java 关系型数据库
基于ssm的超市会员(积分)管理系统,附源码+数据库+论文,包安装调试
本项目为简单内容浏览和信息处理系统,具备管理员和员工权限。管理员可管理会员、员工、商品及积分记录,员工则负责积分、商品信息和兑换管理。技术框架采用Java编程语言,B/S架构,前端使用Vue+JSP+JavaScript+Css+LayUI,后端为SSM框架,数据库为MySQL。运行环境为Windows,JDK8+Tomcat8.5,非前后端分离的Maven项目。提供演示视频和详细文档,购买后支持免费远程安装调试。
279 19
|
6月前
|
前端开发 JavaScript Java
[Java计算机毕设]基于ssm的OA办公管理系统的设计与实现,附源码+数据库+论文+开题,包安装调试
OA办公管理系统是一款基于Java和SSM框架开发的B/S架构应用,适用于Windows系统。项目包含管理员、项目管理人员和普通用户三种角色,分别负责系统管理、请假审批、图书借阅等日常办公事务。系统使用Vue、HTML、JavaScript、CSS和LayUI构建前端,后端采用SSM框架,数据库为MySQL,共24张表。提供完整演示视频和详细文档截图,支持远程安装调试,确保顺利运行。
244 17
|
6月前
|
前端开发 Java 关系型数据库
基于ssm的网络直播带货管理系统,附源码+数据库+论文
该项目为网络直播带货网站,包含管理员和用户两个角色。管理员可进行主页、个人中心、用户管理、商品分类与信息管理、系统及订单管理;用户可浏览主页、管理个人中心、收藏和订单。系统基于Java开发,采用B/S架构,前端使用Vue、JSP等技术,后端为SSM框架,数据库为MySQL。项目运行环境为Windows,支持JDK8、Tomcat8.5。提供演示视频和详细文档截图。
151 10
|
6月前
|
前端开发 Java 关系型数据库
基于ssm的台球厅管理系统,附源码+数据库+论文
本项目为新锐台球厅管理系统,支持管理员和会员两种角色。管理员可进行会员管理、台球桌管理、订单管理等;会员可查看台球桌、预约、购买商品等。技术框架基于Java,采用B/S架构,前端使用Vue+HTML+JavaScript+CSS+LayUI,后端使用SSM框架,数据库为MySQL。运行环境为Windows,JDK8+MySQL5.7+Tomcat8.5。提供演示视频及详细文档截图。
|
7月前
|
存储 Java 关系型数据库
ssm064农产品仓库管理系统系统(文档+源码)_kaic
农产品仓库管理系统基于现代经济快速发展和信息化技术的升级,采用SSM框架、Java语言及Mysql数据库开发。系统旨在帮助管理者高效处理大量数据信息,提升事务处理效率,实现数据管理的科学化与规范化。该系统涵盖物资基础数据管理、出入库订单管理等功能,界面简洁美观,符合用户操作习惯,并提供数据安全解决方案,确保信息的安全性和可靠性。通过自动化和集中处理,系统显著提高了仓库管理的效率和准确性。
|
12月前
|
Java 应用服务中间件 数据库连接
ssm项目整合,简单的用户管理系统
文章介绍了一个使用SSM框架(Spring、SpringMVC、MyBatis)构建的简单用户管理系统的整合过程,包括项目搭建、数据库配置、各层代码实现以及视图展示。
ssm项目整合,简单的用户管理系统
|
12月前
|
XML Java 数据库连接
如何搭建SSM框架、图书商城系统
这是一份详尽的《Spring + SpringMVC + Mybatis 整合指南》,作者耗时良久整理出约五万字的内容,现已经全部笔记公开。此文档详细地介绍了如何搭建与整合SSM框架,具体步骤包括创建Maven项目、添加web骨架、配置pom文件以及整合Spring、SpringMVC和Mybatis等。无论是对初学者还是有一定基础的开发者来说,都是很好的学习资源。此外,作者还提供了项目源码的GitHub链接,方便读者实践。虽然当前主流推荐学习SpringBoot,但了解SSM框架仍然是不可或缺的基础。
144 0

热门文章

最新文章