基于SSM和MySQL实现的一站式购物商城

基于SSM和MySQL实现的一站式购物商城 1 前言 本次课程设计旨在考察学生对工程的规划与设计能力,本次课程设计中,我选择的题目是web应用,目的在于在对JAVAEE的兴趣的前提下

本文包含相关资料包-----> 点击直达获取<-------

基于SSM和MySQL实现的一站式购物商城

1 前言

本次课程设计旨在考察学生对工程的规划与设计能力。本次课程设计中,我选择的题目是web应用,目的在于在对JAVAEE的兴趣的前提下,增加自己对WEB应用开发的项目经验,从项目中找到自己编码的闪光点,增加自信;又可以从中找到自己的不足,锻炼自己设计功能需求的思维能力,为以后正式步入开发岗位做好准备。

2 需求分析

随着网络的迅速发展和普及,以及网络支付手段的逐步完善,使得越来越多的人逐渐相信以及依赖于网上购物。只需在家,打开网上商城,就可以享受与实体店一般的选择购物以及送货上门的购物体验。传统的线下商城和超市已经越来越难满足现阶段越来越快的生活节奏,越来越多的人会因为时间关系而逐渐转移到网上商城,线下购物已经逐渐成为一种生活消遣放松的方式。而且网上商城能借助网络的便利性和跨地域的特点,能改良线下商城只能满足周边居民的这一缺点,实现跨地域的交易,从而大大增加了客户的数量。

我们这次所设计的网上商城“FPShop”,在满足用户各项需求的同时,也对各项功能进行了强化完善,目的是为了让用户能在享受网上购物的便利的同时,也能有个很流畅很舒服的购物体验。“FPShop”的个性和功能主要体现在下面几点:

  • 简洁美观的操作界面 :这次网上商城的总体页面颜色采用了粉色,可爱温馨的颜色是为了能让用户在打开商城时能有个舒畅的心情。而简单的操作界面又能让用户在使用的时候不会因为过于繁琐而频繁出现错误操作,因此留下不愉快的购物体验。所以一个简单美观的操作界面能给用户留下好印象,从而留住用户

  • 种类丰富的商品选择 :为了能满足更多用户的要求,我们的网上商城设置了多个分类,让我们的商城不仅仅只能满足一部分商品需求。用户能通过分类搜索,简单快捷的找到自己想要的商品,也能通过分类列表,简单明了的知道这个网上商城所卖的商品

  • 操作简便的前台功能布局 :前台作为与用户直接交互的界面,在考虑功能的同时,也考虑了操作的简洁和方便性,目的是让大多数不在懂电脑操作的客户,也能轻松的享受电子商务给他们带来的便利。 前台主要功能包括:注册/登录、个人中心、商品分类、购物车、最新商品、最热商品等功能

  • 简单实用的后台管理 :本商城的后台管理在操作上依旧以简单快捷而又不失实用为主。大体上分为用户管理、商品分类管理,商品信息管理、订单管理以及商品的上下架等功能。同时增加了可查看用户的消费情况

3 系统设计

本系统采用B/S模式,前端和后台均使用框架进行开发,前端使用jsp、js和jq技术,后台使用springmvc、spring、mybatis框架整合开发。实现一个完整的网上商城从用户、商品、订单等的管理与操作。以下为详细的设计介绍:

3.1 类结构设计

3.2 购物基本流程时序图

3.3 数据库设计

User表 :uid为主键

Product表 :pid为主键,cid为外键。cid属于category表的主键

Order表 :oid为主键,aid为外键,aid是address表的主键

Orderitem表 :itemid为主键,oid、pid为外键,oid是order表主键,pid是product表主键

Address表 :aid为主键,uid为外键,uid为user表的主键

Category表 ,cid为主键

Power表 ,powerid为主键

User表结构设计

User表主要记录了各个user的个人信息,通过uid主键来作为索引区别。通过state字段判断用户是否注销。Username和password 分别作为用户登录的账号和密码。这里的电话与地址无关。

product表结构设计

product表主要记录了所有商品的详细信息,通过pid主键作为索引区别。通过cid决定该商品属于哪个分类。

address表结构设计

address表主要记录了所有用户的地址,通过aid主键作为索引,uid作为外键标识属于哪个用户,每个用户可以用有多个地址,但是只能拥有一个默认地址。

order表结构设计

Order表主要记录了所有订单的状态、时间以及总花费,通过oid订单编号作为索引区别,以aid为外键索引订单发货地址。State分为四个状态:0为未付款,1为已付款未发货,2为已发货,3为已收货;默认0。Total字段是所有属于同一个oid的orderitem的subtotal的总和。

Orderitem表结构设计

Orderitem表主要记录了所有订单明细的信息,通过字段itemid订单明细编号作为索引区别。pid作为外键索引所买商品的详细信息。

Category表结构设计

Category表主要记录了所有分类的信息,通过字段cid类别编号作为索引区别。

Power表结构设计

Power主要是记录了后台管理员的信息,通过powerid管理员编号作为索引区别。

4 系统实现

4.1 功能模块实现说明

4.1.1 商品管理

后台可以通过该功能模块实现商品上架、商品下架、修改商品信息、查看商品。通过该模块将指定的商品信息增加到数据库中,实现商品上架功能。通过该模块将商城已有商品的商品数目改为0,实现下架商品功能。通过该模块在数据库内修改指定的商品信息,实现修改商品信息功能。

用户通过该模块实现在前台页面查看和搜索商品,并浏览商品。

商品管理页面

修改商品信息

依据类别、价格及库存筛选

相关代码

java //商品分类 @RequestMapping("/admin/orderBy") public String orderBy(String cid,String price,String amount,HttpServletRequest request) { List<Product> productList = null; System.out.println("cid:"+cid+" price:"+price+ " amount:"+amount); if(cid != null) { productList = service.getProductByDetails(cid,price,amount); } request.setAttribute("productList", productList); return "admin/newProductManage"; } //弹窗展示获得的商品数据 @RequestMapping("/admin/showProductInfo") public void showProduct(String pid,HttpServletRequest request,HttpServletResponse response) throws IOException { Product product = productservice.getProductInfo(pid); Gson gson = new Gson(); String json = gson.toJson(product); response.getWriter().write(json); } @RequestMapping("/admin/modifyProduct") public void modifyProduct(Product product,HttpServletResponse response) throws IOException { System.out.println(product.getPid()); productservice.modifyProduct(product); response.getWriter().write("{\"isSuc\":"+true+"}"); }

4.1.2 分类管理

后台可以通过该功能模块实现增加商品分类,修改商品分类以及删除商品分类等功能要求。对应在数据库中对分类信息进行增删改。

用户通过该功能模块实现商品的分类浏览。

类别管理页面

根据分类选择商品

javaAdminController

java @RequestMapping("/admin/orderManage") public String orderManage(HttpServletRequest request) { List<Order> orderList = orderservice.getAllOrder(); Gson gson = new Gson(); String json = gson.toJson(orderList); request.setAttribute("orderList", orderList); request.setAttribute("json", json); return "admin/orderManage"; }

productController

java @RequestMapping("/productByCategory") public String getOrderByUser(String cid, @RequestParam(value = "currentPage", defaultValue = "1") int currentPage, HttpServletRequest request) { PageBean pagebean = service.getProductListByCid(cid, currentPage); request.setAttribute("pageBean", pagebean); request.setAttribute("cid", cid); return "productList"; }

4.1.3 订单管理

用户通过该模块查看自己的订单信息、提交订单、删除订单以及更改订单收货状态。

后台通过该模块查看所有用户的订单信息以及更改订单的发货状态。

个人中心订单

订单管理页面

4.1.4 用户权限

用户权限分为一般浏览者和买家。一般浏览者可以查看所有商品信息,但是不能购买商品以及没有个人中心,在选择购买时会跳到用户注册登录界面。买家则是已登录的用户,可以购买商品也拥有自己的个人中心,可查看自己的个人信息。

登录页面

个人中心资料页

UserInterceptor.java 登录拦截器

java public class UserInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception { HttpSession session = request.getSession(); Object user = session.getAttribute("user"); if(user != null) { return true; }else { response.sendRedirect(request.getContextPath()+"/login.html"); } return false; }

4.1.5 注册与登录

用户只有在登录后才可以购买商品以及查看个人信息,没有账户的游客则需要进行注册再登录。

UserConroller

java @RequestMapping("/login") public void login(String account, String password, HttpServletRequest request, HttpServletResponse response) throws Exception { String email = ""; String username = ""; boolean flag = false; try { String check = "^([a-z0-9A-Z]+[-|_|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-zA-Z]{2,}$"; Pattern regex = Pattern.compile(check); Matcher matcher = regex.matcher(account); flag = matcher.matches(); } catch (Exception e) { flag = false; } if (flag) { email = account; } else { username = account; } System.out.println("email:" + email); System.out.println("username:" + username); User user = new User(); user.setUsername(username); user.setEmail(email); user.setPassword(password); User logined = service.login(user); boolean isSuccess = true; System.out.println(logined); HttpSession session = request.getSession(); if (logined != null) { session.setAttribute("user", logined); response.getWriter().write("{\"isSuccess\":" + isSuccess + "}"); }else { isSuccess = false; response.getWriter().write("{\"isSuccess\":" + isSuccess + "}"); } }

4.1.6 浏览商品

浏览商品

详细商品信息

ProductController

java //根据pid展示商品 @RequestMapping("/product") public String productInfo(String pid, HttpServletRequest request) { Product product = service.getProductInfo(pid); request.setAttribute("product", product); return "productInfo"; }

indexController

java //展示最新和热门商品 @RequestMapping(value = {"/","/index"}) public String index(Model model) { List<Product> hotProductList = indexservice.getHotProducts(); List<Product> newProductList = indexservice.getNewProducts(); model.addAttribute("hotProductList", hotProductList); model.addAttribute("newProductList", newProductList); return "index"; }

4.1.7 用户信息管理

用户可以在这里查看自己的所有信息,以及地址管理和充值服务。

修改个人资料

余额充值页面-方式一

余额充值页面-方式二

新增地址

修改地址

userController

```java @RequestMapping("/user/userInfo") public String toUserInfo() { return "privilege/userInfo"; }

// 修改用户信息
@RequestMapping("/user/modify")
public void modifyUserInfo(User user, HttpServletRequest request, HttpServletResponse response) throws Exception {
    System.out.println(user);
    service.modifyUserInfo(user);
    User newUser = service.getUser(user.getUid());
    HttpSession session = request.getSession();
    Boolean isSuccess = false;
    if (newUser != null) {
        isSuccess = true;
        session.setAttribute("user", newUser);
    }
    response.getWriter().write("{\"isSuccess\":" + isSuccess + "}");
}

// 前往充值余额页面
@RequestMapping("/user/balance")
public String toBalancePage() {
    return "privilege/balance";
}

// 充值余额
@RequestMapping("/user/recharge")
public void recharge(Double pay, HttpServletRequest request, HttpServletResponse response) throws Exception {
    HttpSession session = request.getSession();
    User user = (User) session.getAttribute("user");
    Double money = user.getMoney();
    Double newMonney = 0.0;
    if (pay != 0.0 && pay != null) {
        newMonney = money + pay;
    }
    System.out.println("money:" + newMonney);
    user.setMoney(newMonney);
    service.modifyUserInfo(user);
    user = service.getUser(user.getUid());
    System.out.println(user);
    session.setAttribute("user", user);
    Boolean isSuccess = false;
    if (user.getUid() != "") {
        isSuccess = true;
    }
    response.getWriter().write("{\"isSuccess\":" + isSuccess + "}");
}

// 跳转到支付成功页面
@RequestMapping("/user/paySuccess")
public String topaySuccessPage() {
    return "privilege/recharge";
}

// getAddsByUser
@RequestMapping("/user/address")
public String addressManage(HttpServletRequest request) {
    HttpSession session = request.getSession();
    User user = (User) session.getAttribute("user");
    List<Address> addList = service.getAddress(user.getUid());
    request.setAttribute("addList", addList);
    return "privilege/addManage";
}

// 添加或修改用户地址
@RequestMapping("/user/addManage")
public String addManage(String aid,String tel,String address,String name,HttpServletRequest request) {
    System.out.println(aid);
    System.out.println(tel);
    System.out.println(address);
    System.out.println(name);
    Address address1 = new Address();
    address1.setAid(aid);
    address1.setTel(tel);
    address1.setAddress(address);
    address1.setName(name);
    System.out.println(address1);
    HttpSession session = request.getSession();
    User user = (User)session.getAttribute("user");
    address1.setUid(user.getUid());
    System.out.println(address1);
    if(address1.getAid() != null && address1.getAid() != "") {
        service.updateAdd(address1);
    }else {
        service.addAddress(address1);
    }
    return "redirect:/user/address";
}

//删除地址
@RequestMapping("/user/delAdd")
public String delAdd(@RequestParam(value = "aid") String aid) {
    Address address = new Address();
    address.setAid(aid);
    service.delAdd(address);
    return "redirect:/user/address";
}

//设置默认地址
@RequestMapping("/user/setDefaultAdd")
public String setDefaultAdd(String aid,HttpServletRequest request) {
    HttpSession session = request.getSession();
    User user = (User)session.getAttribute("user");
    Address address = new Address();
    address.setAid(aid);
    address.setUid(user.getUid());
    service.setDefaultAdd(address);
    return  "redirect:/user/address";
}

@RequestMapping("/user/setDefaultAddFromCart")
public String setDefaultAddFromCart(String aid,HttpServletRequest request) {
    HttpSession session = request.getSession();
    User user = (User) session.getAttribute("user");
    Address address = new Address();
    address.setAid(aid);
    address.setUid(user.getUid());
    service.setDefaultAdd(address);
    List<Address> addList = service.getAddress(user.getUid());
    session.setAttribute("addListCart", addList);
    return "redirect:/cart.html";
}

```

4.18 购物车模块

用户可以将自己心仪的商品先添加至购物车,然后继续浏览其他商品,最后再进行付款提交订单。

购物车页面

确认订单

购物车为空

Productcontroller

```java // 加入购物车 @RequestMapping("/addCart") public String addCart(String pid, int buyNum, HttpServletRequest request) { HttpSession session = request.getSession(); Cart cart = (Cart) session.getAttribute("cart"); if (cart == null) { cart = new Cart(); } CartItem cartitem = new CartItem(); Product product = service.getProductInfo(pid); cartitem.setProduct(product); cartitem.setBuyNum(buyNum); double subtotal = product.getPrice() * buyNum; cartitem.setSubtotal(subtotal); double total = 0.0d; Map cartItems = cart.getCartItems(); if(cartItems.containsKey(pid)) { CartItem item = cartItems.get(pid); int oldNum = item.getBuyNum(); int newNum = oldNum+buyNum; item.setBuyNum(newNum); item.setSubtotal(product.getPrice()*newNum); cart.setCartItems(cartItems); }else { cartItems.put(pid, cartitem); } total = cart.getTotal()+cartitem.getSubtotal(); cart.setTotal(total); User user = (User) session.getAttribute("user"); if (user != null) { List

address = userservice.getAddress(user.getUid()); System.out.println(address); session.setAttribute("addListCart", address); } session.setAttribute("cart", cart); return "redirect:/cart.html"; }

@RequestMapping("/delCartItem")
public String delCartItem(String pid,HttpServletRequest request) {
    HttpSession session = request.getSession();
    Cart cart = (Cart) session.getAttribute("cart");
    if(cart!=null) {
        Map<String, CartItem> cartItems = cart.getCartItems();
        //修改总价
        double  newTotal = cart.getTotal() - cartItems.get(pid).getSubtotal();
        cart.setTotal(newTotal);
        // 删除
        cartItems.remove(pid);
        cart.setCartItems(cartItems);
    }
    session.setAttribute("cart", cart);
    return "redirect:/cart.html";
}

@RequestMapping("/removeCart")
public String removeCart(HttpServletRequest request) {
    HttpSession session = request.getSession();
    session.removeAttribute("cart");
    return "redirect:/cart.html";
}

```

4.2 配置文件

ApplicationContext.xml是web应用中spring框架的配置文件,负责对web系统中beanfactory和各个bean的属性注入以及数据库连接池的配置设置。

部分配置代码如下:

xml <context:property-placeholder location="classpath:db.properties" /> <bean id="dataSource" > <property name="driverClassName" value="${jdbc.driver}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> <property name="maxActive" value="10" /> <property name="maxIdle" value="5" /> </bean> <!-- sqlSessionFactory --> <bean id="sqlSessionFactory" > <!-- mybatis核心配置 --> <property name="configLocation" value="classpath:SqlMapConfig.xml"></property> <!-- 数据源 --> <property name="dataSource" ref="dataSource" /> </bean> <!-- mapper扫描器 --> <bean > <property name="basePackage" value="cn.fpshop.dao" /> </bean>

Sqlmapconfig.xml是基于SSM的web系统中Mybatis的配置文件,负责关联mapper.xml文件

部分代码如下:

```xml

```

Springmvc.xml是基于SSM的web系统中SpringMVC的配置文件。负责对springmvc的核心组件前端控制器、处理器等进行配置

总结

在本次课程设计中,我的题目是基于SSM的一站式购物商城。在本次开发中,是在基于原生api的商城的基础上,进行后端代码的升级——SSM框架。因为这是我第一次使用SSM进行web开发,所以遇到了些问题。例如在进行数据持久化的过程中,即对数据库表的映射的配置中,因为对配置文件的配置方式不熟悉,导致在进行增、删、改、查的过程中屡次出现报错,经过多方面的查找资料与尝试,最终理解了配置的思路,而后也比较顺利的完成了此次课程设计的全部要求。

参考文献

  • 基于Spring Boot的电子商城设计与实现(哈尔滨工业大学·李晨)
  • 基于Spring Boot的电子商城设计与实现(哈尔滨工业大学·李晨)
  • 网上商城系统的设计与实现(北京邮电大学·时光)
  • 基于SSM的分布式商城的设计与实现(中国地质大学(北京)·刘彤月)
  • 基于JSP网上购物系统的实现与应用(南昌大学·曾磊)
  • 基于JAVA的B2C电子商城设计与实现(西安电子科技大学·胡峰)
  • 基于SSM框架的电子商城项目的设计与实现(山东大学·李天庆)
  • 电子商务系统的设计与实现(吉林大学·刘莹)
  • 基于JSP技术的网上购物系统设计与实现(电子科技大学·包敏)
  • 基于SSM框架的电子商城项目的设计与实现(山东大学·李天庆)
  • 基于SSM的分布式商城的设计与实现(中国地质大学(北京)·刘彤月)
  • 基于.NET的在线购物平台研究与实现(东北师范大学·刘雪娇)
  • 基于B/S结构的电子商务的研究与应用(哈尔滨工程大学·车彦朋)
  • 基于JAVA的B2C电子商城设计与实现(西安电子科技大学·胡峰)
  • 基于Spring Boot的电子商城设计与实现(哈尔滨工业大学·李晨)

本文内容包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主题。发布者:源码客栈 ,原文地址:https://m.bishedaima.com/yuanma/35397.html

相关推荐

  • 基于SSM框架的电影院售票系统

    这是一个🔥🔥基于SSM框架的电影院售票系统🔥🔥的项目源码,开发语言Java,开发环境Idea/Eclipse,这个 SSM框架电影院售票系统开发技术栈为SSM项目,可以作为毕业设计课程设计作业使用SSM框架实现一个电影院售票平台
    2024年05月23日
    15 1 2
  • 基于Python的中文自动分词实验

    中文自动分词实验 实验内容 使用任意分词方法进行分词 实验要求和目的 使用任意分词方法实现汉语自动分词; 给出至少 1000 个句子的分词结果(以附件形式); 计算出分词结果的正确率
    2024年05月14日
    2 1 1
  • 基于springboot的在线慕课学习网站,基于javaweb的mooc网站

    设计并实现基于Spring Boot的在线慕课学习网站和基于JavaWeb的MOOC网站是当前计算机科学领域的研究热点之一,随着互联网的普及和技术的不断发展,人们对于便捷高效的在线学习方式的需求日益增加
    2024年05月07日
    9 1 1
  • 基于Python制作的记忆翻牌小游戏

    基于 Python 制作的记忆翻牌小游戏 导语 昨天看到有留言竟然说我是月更博主,我明明更新地这么勤快(心虚,jpg),看吧,昨天刚更新过,今天又来更新了
    2024年05月14日
    18 1 3
  • 基于SpringBoot框架的旅游管理系统

    这是一套采用🔥🔥SpringBoot为核心的旅游管理系统的源代码实现,主要编程语言为Java,并结合了Vue技术进行开发,开发工具选择的是Idea或Eclipse,此项目是一个精简版的旅游管理应用
    2024年05月23日
    4 1 2
  • 基于Python制作小恐龙游戏

    基于 Python 设计的小恐龙小游戏 本来想带大家用遗传算法再训一波龙的,于是把自己之前写的仿谷歌浏览器小恐龙代码找了出来,就是这个: Python 制作小游戏(七) 想在它基础上加 AI 控制的代码的
    2024年05月14日
    5 1 1
  • 基于PHP和Web的subversion用户管理系统

    基于PHP和Web的subversion用户管理系统 摘 要 本系统主要是基于Web的subversion系统的用户管理系统,在开源软件世界,并行版本系统(cvs)一直是版本控制长久以来的唯一选择
    2024年05月14日
    2 1 1
  • 基于JSP和MySQL的电脑彩票销售管理系统的设计与实现

    基于Jsp和Mysql的电子产品销售管理系统 1 绪论 随着科技水平的飞速发展,计算机走进了千家万户,人们开始越来越多地利用计算机解决和日常生活相关的各种问题
    2024年05月14日
    4 1 1
  • 构造正规式r1|r2

    近年来,随着计算机科学领域的迅速发展,正规式与自动机理论作为编译原理等诸多领域的基础,备受关注,在编写程序中,正规式的构造是一项常见而且关键的任务,特别是在涉及到复杂文本匹配与处理的场景下
    2024年05月07日
    7 1 3
  • 基于JAVA实现的超级马里奥(Super Mario)游戏

    基于JAVA实现的超级马里奥(Super Mario)游戏 一,项目简介 刚进入的时候会有一个界面,为地图编辑器,可以使用此编辑器进行地图编辑,地图编辑器的内容包括:关卡
    2024年05月14日
    6 1 2

发表回复

登录后才能评论