以下是我今年的论文加作品源码,感谢阅读,如需要源码学习,和本论文进行参考,可私聊我,如遇什么不懂的,我很乐意帮助你,让我们一起成长

目录

摘 要

ABSTRACT

1 绪论

1.1 研究背景

1.2 研究意义

1.3 国内外研究现状

2 开发环境以及技术方案

2.1 开发环境

2.2 技术方案

3 需求分析

3.1 前台功能性需求分析

3.2 后台功能性需求分析

3.3 设计约束

3.4 系统用例图

4 概要设计

4.1前台系统架构流程图设计

4.2后台系统架构流程图设计

4.3数据库系统设计

4.3.1 数据库结构E-R图

4.3.3 数据库物理设计

4.3.4 数据库模型展示

5 详细设计与实现

5.1 前台各项基本功能的实现

5.1.1 注册功能的实现

5.1.2 登录功能的实现

5.1.3 地址模块的实现

5.1.4 订单模块的实现

5.1.5 购物车模块的实现

5.1.6 购买模块的实现

5.1.7 关键字搜索的实现

5.1.8 商品销量展示功能的实现

5.2 后台各项基本功能的实现

5.2.1 管理员登录模块的实现

5.2.2 商品管理模块的实现

5.2.3订单管理模块的实现

5.2.4 用户管理模块的实现

6 测试运行

6.1 注册与登录模块测试

6.2 地址模块测试

6.3 购买模块测试

6.4 购物车模块测试

6.5 订单模块测试

6.6 关键字搜索测试

6.7 管理员登录与商品管理的测试

6.8 订单管理模块的测试

6.9 用户模块的测试

6.10 销量排序的测试

7 总结

参 考 文 献

致 谢

近年来,随着互联网行业的兴起,各种购物网站层出不穷,例如淘宝、天猫、京东、拼多多等。这种购物平台也是为了方便我们购物者,可以让我们实现足不出户就能买到心仪的商品。由于上述的购物商城都是大类化,什么都有,太过于繁多,所以本论文专门为了满足某一部分群体的需求而进行开发设计。

本论文主要设计的是母婴电商平台,该平台用到的技术比较多,不过万变不离其宗,后端的开发设计主要是基于Java、Java Web、Spring Framework、Spring Mvc、mybatis等技术进行实现,这几项技术是目前最流行的SSM部署技术,它帮助了开发者快速的搭建好开发架构,对开发者的开发效率提供了非常大的帮助。而前端则使用Layui、HTML5、JS、CSS等技术进行实现。服务器则用的是tomcat9部署的,tomcat是一个容器,是apache服务器的插件,专门用来装载servelet(java)程序。在本文中还用到了OSS对象存储技术,该技术主要用于存储用户的头像、商品的图片等等。本系统最终实现了用户的登录、注册、查看订单、销量排序、购买商品、加入购物车、管理商品、对用户做出封禁的处理等功能。本文会在后续的内容中一一为大家展现如何使用上述技术进行设计和实现本平台。

关键词: 互联网;购物平台;OSS

*ABSTRACT*

In recent years, with the rise of the Internet industry, various shopping websites emerge in endlessly, such as Taobao, Tmall, JINGdong, Pinduoduo and so on. This kind of shopping platform is also for the convenience of us shoppers, so that we can buy the desired goods without leaving home. Because the above shopping malls are big categories, having everything, so this paper is designed and developed specifically to meet the needs of a certain part of the community.

In this paper, the main design is maternal and child e-commerce platform, the platform uses more technology, but all changes are inseparable from the same, back-end development design is mainly based on Java, Java Web, Spring Framework, Spring Mvc, Mybatis and other technologies to achieve. These technologies are the most popular SSM deployment technologies at present, which help developers quickly set up the development architecture and provide great help to developers’ development efficiency. The front-end uses Layui, HTML5, JS, CSS and other technologies to achieve. The server is deployed with Tomcat 9. Tomcat is a container, a plug-in for the Apache server, specially used to load Servelet (Java) programs. OSS object storage technology is also used in this paper, which is mainly used to store user’s profile picture, pictures of goods and so on. This system finally realizes the user’s login/registration, viewing the order, sales sort, purchasing goods, adding to the shopping cart, managing goods, making banning for the users. This article will show you how to design and implement this platform using the above techniques in a subsequent article.

*Key words*: Internet; Shopping platform; OSS

1 绪论

1.1 研究背景

1.1.1实用性品牌专营店严重空白

​ 在我国的孕婴市场还没有形成的过渡时期,除了少数大型商场还有专卖店外,基本上都没有品牌效应的专营店店面,一些买卖该类商品的店面仍将孕婴用品伴同百货用品发卖,它这样做既不方便采办,又缺少安全感;而近似会合谋划婴幼用品的谋划店却又无严酷意义上的品牌。是以,消费者们呼喊需要既具备品牌价值,又具备品格包管,且能顺应消耗需求的品牌专营店。

1.1.2购物地理环境局限性大

​ 孕婴用品的消耗主体一般是怀有孩子6-10个月的时代孕妇或新生儿的妈妈,这两类消耗群体购买商品时,对安全性要求出格强,这是这两类特别阶级消耗的共性。故而那种交通便当,靠近社区服务,且情况优雅的购物场合成为消费者的急需。市场上的买卖孕婴用品的店面多在大型市场和购物中心,不是很方便消费者们对其消费。因而,消费者在出于安全及合格的两重的需求下,对出现在家门口、接管社区服务的专营性品牌店尤其期望,对其的需求非常强烈。

1.1.3缺乏综合性,结构相对单一

​ 孕婴用品触及行业普遍(衣饰、塑胶、轻工、电子、医疗器械、钢材、纸品数十个行业),且市场较分离,买卖的商品比较单一。同时,品牌店中买卖的商品一般只有必用品、衣饰两类商品。而像日用品、起居用品、妊妇的特别用品、工艺礼节、美术品几近为零。

1.1.4销售方式单一

​ 因为孕婴行业自己的特色,所以需要社区服务的切近与人性化的服务,而很多品牌店在买卖上仍采取传统的接待方式来接待客人,并且因为传统的营销模式的终端紧张滞后,市场意识不高造成谋划上的短期行为,都无形地拉远了与主顾的间隔。亲情式营销,人性化办事将成为市场发展的重中之重。

1.1.5现有产品价格体系不合理

​ 现如今,孕婴产物显现两个极度:一方面,进口产物太高的代价令通俗消费者望而生畏,一个童车的代价动辄八九百乃至几千,已经相当于一辆山地车的代价;另一方面品质低价格低的产物又不能适应泛博中层消费者的需求。中端产物在中国市场中是个空缺。消费者呼喊合适中国市场普通化的中端品牌。

1.1.5母婴商城平台知名度低

目前,国内的母婴商城屈指可数,平台过少并且知名度低,而我国人口基数大,从而导致了部分消费者因无合适的平台购买必需品而感到不满。

1.2 研究意义

随着互联网的飞速发展,母婴市场作为一个刚需的行业,其规模从未停止过增长,反而呈现出越长越快的趋势,而国内的母婴市场尚未形成过渡时期,只有一些根本不具备品牌效应的专营店店面,并且实体店的可选商品非常的有局限性。

母婴用品的消费者一般是怀孕期间的孕妇或新生儿的母亲,这两类消费群体因为各种的生活上的不便,所以不利于去到当地的实体店购买母婴用品,而有时候该两大消费群体又非常的需要该商品时,这时就会考虑到有没有更加方便,快捷,不用出门的购物方式。

随着近年来国内线上零售占比逐步提升,消费者对母婴产品的丰富度需求和消费习惯的改变,以及行业规模的持续增长,可以预见线上母婴市场仍存在巨大提升空间。同时线上母婴市场中综合电商平台占主要消费出口。而本网站就是趋于网络的发展而进行开发的,它有助于宝妈们,寻找需要的商品时不费吹灰之力就可以轻松找到,效率高,可以带动线上的经济发展可以最大限度的节省人力的输出,是线下无法比拟的,这也是本网站的意义所在。

1.3 国内外研究现状

国外存在着大量的母婴商城平台,虽然说他们存在着母婴商城,可国外的新生儿人口基数不算太多,并且不管是国外还是国内,母婴市场这个行业现在只能说是刚刚露头,虽只是刚刚露头,但是母婴商城的需求还是很大的。现在我们所处的是一个快消时代,母婴行业同时也分别被贴上了“多快好省”的标签,在不同的渠道能满足大家不同的需求,当然也正在及时全面满足消费者的本质需求。

作为当代年轻人,我个人认为,母婴市场还有很大的发展潜力,并且我认为,该市场潜力,在未来的10年内,不会呈现出饱和的状态。

2 开发环境以及技术方案

2.1 开发环境

硬件环境:移动便捷笔记本、16G内存、500SSD

开发环境:MySql(5.5.5)、apache-maven-3.6.1 、apache-tomcat-9.0.7、jdk1.8.0_321、jre1.8.0_321

开发软件:IntelliJ IDEA 2020.1 、Navicat Premium、postman、Visio

操作系统:Win10

2.2 技术方案

2.2.1前端技术方案

HTML标签:英文是HyperText Markup Language,也叫HTML,它是一种用于建立网页的超文本标签语言。

CSS:只要对响应的代码做一些简略的点窜,就能够转变统一页面的分歧部门,或页数分歧的网页的表面和格局。

JavaScript:JS最初受是Java的启发而起头计划的,其中的目标之一便是“看上去像Java”,是以语法上有类似之处,一些名称和定名范例也借自Java,但JavaScript的首要计划原则源自Self和Scheme。JavaScript与Java名称上的类似,是那时Netscape为了营销斟酌与Sun微体系达成协议的成果。微软当时也推出了JScript用来打败JavaScript的脚本语言。

JQuery:jQuery是一个快速、简练的JavaScript框架,是继Prototype以后又一个优异的JavaScript代码库(框架)于2006年1月由John Resig公布。jQuery计划的主旨是“write Less,Do More”,即提倡写更少的代码,做更多的工作。它封装JavaScript经常使用的功效代码,供给一种简洁的JavaScript计划模式,优化HTML文档操纵、事务处置、动画计划和Ajax交互。

Ajax:Ajax即Asynchronous Javascript And XML(异步JavaScript和XML)在 2005年被Jesse James Garrett提出的新术语,用来描写一种利用现有手艺调集的‘新’方式,包罗: HTML 或 XHTML, CSS, JavaScript, DOM, XML, XSLT, 和最主要的XMLHttpRequest[1]。利用Ajax手艺网页利用可以或许快速地将增量更新显现在用户界面上,而不需要重载(革新)全部页面,该技术可以更快速的帮助用户进行操作页面。

Layui:layui它是一套开源的[ web 的ui ](https://baike.baidu.com/item/ Web UI /5701329)解决方案,利用了自身经典的模块化规范,并遵循原生[ HTML](https://baike.baidu.com/item/ HTML/97049)/CSS/JS的开发方式,常适合网页界面的快速开发。layui 区分于那些基于MVVM 底层的前端框架,它更可能是面向后端开发者,无需涉足前端各类东西,只需面临浏览器自己。

2.2.1后端技术方案

Maven:Maven项目工具模子(POM),只需一小段代码就可以用来管理项目和构建,陈述和文档的项目办理工具软件。

Tomcat:Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个焦点项目,由Apache、Sun 和其他一些公司共同开发而成的项目。因为有了Sun 的介入和撑持,最新的Servlet 和JSP 范例老是能在Tomcat 中获得表现,Tomcat 5撑持最新的Servlet 2.4 和JSP 2.0 规范。由于Tomcat 技术先进、机能不变,并且免费,因此深受Java 爱好者的爱好并获得了部门软件开发商的承认,成为比力风行的Web 应用服务器。

Mysql:MySQL是一个干系型数据库办理体系,由瑞典MySQL AB 公司开辟,属于 Oracle 旗下产物。MySQL 是最风行的干系型数据库办理体系之一,在 WEB 利用方面,MySQL是最佳的 RDBMS (Relational Database Management System,干系数据库办理体系) 利用软件之一。

MyBatis:MyBatis本是apache的一个开源项目iBatis,2010年这个项目由apache software foundation迁徙到了谷歌 code,而且更名为MyBatis[2]。2013-11月该项目迁移到Github

Driud:连接池主要负责分配,管理和释放数据库连接,它能够允许应用程序重复利用现有数据库连接,而不是再去重新建立一个数据库连接;释放空闲时间比最大空闲时间大时,连接池会避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术能明显提高对数据库操作的性能。

Spring:Spring框架是一个开放源代码的J2EE应用程序框架,由Rod Johnson倡议,是针对bean的生命周期举行办理的轻量级容器(lightweight container)[3]。 Spring办理了开辟者在J2EE开辟中碰到的很多常见的题目,供给了功能强大的IOC、AOP及Web MVC等功能。Spring可以零丁应用于修建应用程序,也可以和Struts、Webwork、Tapestry等浩繁Web框架组合利用,而且可以与 Swing等桌面应用程序AP组合。

SpringMvc:Spring MVC属于SpringFrameWork的后续产物,已融会在Spring Web Flow内里。Spring 框架供给了构建 Web 应用程序的全功能 MVC 模块。

Jsp:JSP它的全名字为JavaServer Pages,它是由[Sun Microsystems](https://baike.baidu.com/item/Sun Microsystems)公司主导创建的一种动态网页技术标准。JSP可以部署于网络服务器上,它可以响应客户端那边发送过来的请求,并可以根据请求内容动态地生成HTMLXML或其他格式文档的Web网页情况,然后它再返回给请求者[4]。JSP技术是一个以Java语言作为脚本语言,为用户的HTTP请求提供服务,它还可以与服务器上的其它Java程序共同处理复杂的业务需求。

OSS工具存储:OSS具备与平台无关的Restful API接口。

Hutool-captcha:实现了验证码文本生成、非大小写敏感的验证、写出到流和文件等方法。

fastJSON:Fastjson 是一个 Java 库,可以将 Java 工具转换为 JSON 格局,固然它也可以将 JSON字符串转换为 Java 的对象。Fastjson 可以操作任何 Java 对象,即使是一些预先存在的没有源码的对象。

Lombok:Lombok项目是一个Java库,它会自动插入编辑器和构建工具中,Lombok提供了一组有用的注释,用来消除Java类中的大量样板代码。

3 需求分析

3.1 前台功能性需求分析

前台的功能性需求分析,主要分析用户能在本网站里干什么,想要用户看到什么和让用户拥有愉快的购物体验,和视觉享受。而现在所做的分析是为了往后在后续的开发中可以少走弯路,在一个确定好了的架构上开发比什么都没有始终要强。

以下关于本网站前台的一个需求分析。

1、用户注册:该功能是必不可少的,只有用户注册了账号,用户才能继续进行后续的相关操作,例如登录该平台、查看个人信息、查看个人地址和查看订单信息等。

2、用户登录:用户注册好的账号可通过该功能进行登录,进入到商城中,从而实现购买商品等。

3、验证码:该功能用于检测登录该账号或者注册账号的人是否是人类,而不是一段程序,从而有效的防止黑客的恶意注册和恶意登录。

4、购物车:为了方便用户选择合适的商品,而当时又不想购买时,就可以把该商品放入购物车中,等待以后想购买时,就可打开购物车进行结账购买。

5、购买商品:当用户想要该商品时,就可以点击它进行购买,并且能够选择购买的数量等等。

6、订单:方便用户进行查看购买了什么商品,查看下单的时间,购买的数量等等。

7、收货地址:该功能也是一个必不可少的功能,用户下单后商家总要向买家发货,而买家就应该在这个功能中新增他的地址,可以有多个地址。

8、个人信息:该功能中,用户可查看自己的详情,例如手机号,地址,是否新增地址和删除地址等。

9、分页:该功能是对数据过多的时候,进行商品的分页,地址的分页等等。

10、确认收货:该模块用于确认用户是否收到了商品,后台好知道该商品的动态消息。

11、关键字搜索:用户想要购买某个商品时,搜索关键字的,该商品就会出现在用户界面上。

12、商品销量展示:用户想要购买销量最高的商品时,可选择销量排序然后进行购买。

3.2 后台功能性需求分析

后台的功能性需求分析,主要分析用于上传商品、修改商品、查看商品和删除商品。并可对订单进行实际性的观察和发货功能。还可对用户的账号进行封禁和解禁的管理等。

以下是关于本网站后台的一个需求分析。

1、管理员登录:管理员账号是不能注册的,所以想要管理员账号就得开发者提供,得到管理员账号后,就可进行登录,继续后续相关的操作。

2、商品管理:该功能是对商品的一些必要性的管理,有如下几种小功能。

(1)商品的增加。

(2)商品的修改。

(3)商品的删除。

(4)商品的批量删除。

3、订单管理:该功能主要实现了管理员对订单的发货操作,并可查看用户的收货地址和电话,从而可以实现线下提供售后等服务。

4、用户管理:该功能主要用于实现对用户账号的封禁和解禁处理,所谓的封禁就是拉入黑名单,不能登录。

5、系统管理:可以查看管理员账号,可以查看本次管理员的基本信息,还可以修改该管理员密码。

3.3 设计约束

本平台涉及到的约束点分别是,持久化存储只能是mysql,项目部署只能部署在windows系统上,计算机系统中的环境变量必须要有jdk1.8或以上。

3.4 系统用例图

用户进入到首页能干什么?管理员进入到管理界面又能管理什么?接下来我主要通过系统用例图来展示系统大致功能。如图3.1所示。

img

图3.1 系统用例图

4 概要设计

4.1前台系统架构流程图设计

前台总体流程图如图4.1所示:

img

图4.1前台系统架构流程图

4.2后台系统架构流程图设计

前台总体流程图如图4.2所示:

img

图4.2 后台系统架构流程图

4.3数据库系统设计

4.3.1 数据库结构E-R图

在设计数据库表结构,还有数据库字段表的时候,首先都要预先画一个数据库结构E-R图出来进行分析其可行性,E-R图还可以让你看清每个表之间的关系[5]。E-R图也叫实体接洽图,它为咱们供给了实体范例、属性和接洽的方式。用来描写实际现实中的生活概念模型。对我们建立数据库模型起到了启发性的作用。

以下是本数据库结构的E-R图。如4.3所示。

img

图4.3 数据库E-R图

4.3.2实体类属性定义

\1. 用户表:uid、username、password、phone、nickname、birthday、salt、img

\2. 订单表:oid、oname、state、oprice、uid、alterdate

\3. 订单项表:orid、orprice、ornumber、orupdate、oid、gid、uid、address_id

\4. 购物车表:cid、uid、gid、oid、orid、cnumber

\5. 收获地址表:id、uid、uaddress、name、phone

\6. 商品表:gid、gname、gnumber、sellprice、getprice、gunit、city、skid、img

\7. 管理员表:aid、ausername、apassword

\8. 一级标签表:fkid、kname、ksignatrue

\9. 二级标签表:skid、kname、ksinatrue、fkid

4.3.3 数据库物理设计

根据数据库结构E-R图进行建表。由E-R图可得知有以下表:用户表,商品表,订单表,订单项表,购物车表,收货地址表,管理员表,一级标签表,二级标签表。然后现在开始具体介绍数据库中各表的结构:

\1. 用户信息表,表昵称:user,用于存储用户信息的表,其表布局如表4.1所示。

表4.1 用户表

字段名数据类型长度是否为null备注
uidInt11Not null主键
usernamevarchar255Not null账号
passwordvarchar255Not null密码
phonevarchar255手机号
nicknamevarchar255昵称
birthdayvarchar255生日
saltvarchar1账号状态
imgvarchar255用户头像

\2. 订单表,表昵称:orderform,用于存储订单信息的表,其表结构如表4.2所示。

表4.2 订单表

字段名数据类型长度是否为null备注
oidint11Not null主键
Onamevarchar255Not null商品名
stateint10Not null订单状态
opricedouble10Not null订单总价
uidint11Not null用户id
alterdatevarchar255Not null生成时间

\3. 订单项表,表昵称:orderitems,用于存储订单项信息的表,其表结构如表4.3所示。

表4.3 订单项表

字段名数据类型长度是否为null备注
oridint11Not null主键
orpricedouble10Not null商品单价
ornumberint10Not null购买数量
orupdatevarchar255Not null生成日期
oidint11Not null订单id
gidint11Not null商品id
uidint11Not null用户id
address_idint11Not null地址id

\4. 商品表,表昵称:goods,用于存储商品信息的表,其表结构如表4.4所示。

表4.4 商品表

字段名数据类型长度是否为null备注
gidint11Not null主键
gnamevarchar255Not null商品昵称
gnumberint11Not null库存数量
sellpricevarchar255售价
getpricevarchar255进货价
gunitvarchar255单位
cityvarchar255简介
skidInt11二级标签id
imgvarchar255商品图片

\5. 购物车表,表昵称:shopcar,用于存储购物车信息的表,其表结构如表4.5所示。

表4.5 购物车表

字段名数据类型长度是否为null备注
cidint11Not null主键
uidint10Not null用户id
gidint10Not null商品id
oidint11Not null订单id
oridint11Not null订单项id
cnumberint11Not null商品数量

\6. 收货地址表,表昵称:address_1,用于存储收货地址信息的表,其表结构如表4.6所示。

表4.6 收货地址表

字段名数据类型长度是否为null备注
Idint11Not null主键
uidint11Not null用户id
uaddressvarchar255Not null地址
namevarchar255Not null收货人
phonevarchar255Not null收货电话

\7. 管理员表,表昵称:admin,用于存储管理员信息的表,其表布局如表4.7所示。

表4.7 管理员表

字段名数据类型长度是否为null备注
aidint11Not null主键
ausernamevarchar255Not null管理员账号
apasswordvarchar255Not null管理员密码

\8. 一级标签表,表昵称:fkinds,用于存储一级标签信息的表,其表结构如表4.8所示。

表4.8 一级标签表

字段名数据类型长度是否为null备注
fkidint11Not null主键
knamevarchar255Not null标签名
ksignatruevarchar255简介

\9. 二级标签表,表昵称:skinds,用于存储二级标签信息的表,其表结构如表4.9所示。

表4.9 二级标签表

字段名数据类型长度是否为null备注
skidint11Not null主键
knamevarchar255Not null标签名
ksignatruevarchar255Not null简介
fkidInt11一级标签id

4.3.4 数据库模型展示

确定E-R图没有什么问题之后,就可以参照着E-R图的关系建立出数据库模型[6],然后数据库模型就可以逆向生成相应的实体表。

以下是数据库模型图。如图4.4所示。

img

图4.4数据库模型

*5 详细设计与实现*

5.1 前台各项基本功能的实现

5.1.1 注册功能的实现

用户的注册功能,实现起来并不复杂,首先数据库中要有用户表,并在HTML页面上画好了页面之后,通过form标签提交至后台,进行数据处理,但是我并没有直接通过HTML自带的提交功能直接提交,而是通过Layui的form.on方式举行提交,如此提交的益处是什么?这样提交的好处,主要是可以得到数据回显,可以把后台返回的数据进行异步判断,以此来判断该用户是否注册成功?不成功又是为何原因?例如账号已存在,无法注册等原因。如图5.1所示。

img

图5.1 注册失败,账号已存在

而这前端的代码是怎么实现的呢?首先要把按钮设置为不可提交,然后通过layui绑定按键,触发form.on函数,接着在此中挪用ajax就好了。

接下来我将展示form.on中写的方法。其主要函数如下:

form.on('submit(submitBtn)', function (data) {

​    console.log(data.field)

​    let username = data.field.username;

​    let password = data.field.password;

​    $.ajax({

​     type:'post',

​     url:'/user/reg',

​     data:data.field,

​     success: function (data) {

​      console.log(data)

​      console.log(data.data.salt)if (data.data.salt==="1"){

​       layer.msg('注册成功',{icon: 1 },function () {

​        location.href="/html/login.html";})}else if (data.data === 0){

​       layer.msg('账号已存在', { icon: 2 }, { time: 2000 });}else if (data.data === 3) {

​       layer.msg('验证码错误', {icon: 2}, {time: 2000});} else {

​       layer.msg('未知注册异常', { icon: 2 }, { time: 2000 });}},

​     error: function (data) {

​      layer.msg('连接网络失败,请检查网络设置或联系管理员', { icon: 2 }, { time: 2000 });}})

   });

提交成功后,数据就会进入到后端,后端可以通过HttpServletRequest[7]中的getParameter[8]获取到想要的input中的value。获得了想要的数据以后,就能够去营业层举行逻辑处置。

以下代码是注册的逻辑代码:

public Result reg(String username, String password, String phone,String nickname) {

​    User user = selByName(username);

​    if (Objects.nonNull(user)) {

​      return Result.ok(Constants.ACCOUNT_EXISIS).data(0);

​    }

​    User u = new User();

​    u.setUsername(username);

​    u.setPassword(password);

​    u.setPhone(phone);

​    u.setNickname(nickname);

​    //默认1 有效

​    u.setSalt("1");

​    int i = userMapper.insertSelective(u);

​    if (i > 0) {

​      return Result.ok(Constants.OK).data(u);

​    }

​    return Result.ok(Constants.UNKNOWN_REASON).data(2);

  }

代码中的Result静态方法是我封装好的一个统一结果处理类。该代码的作用是统一返回的数据,提高代码的复用性[9]。

在注册中,我还增加了一个小功能,验证码功能。该功能我通过编写代码,自己写了一个工具类进行实现,方便后面登录的时候进行调用,它可以绘制干扰线,随机生成字体。详情代码请看附录中的VerificationCodeImage。

通过此工具类,就可以在控制层中输出相应的验证码了,以下是控制层中的详细代码:

@RequestMapping("/user/imgCode")

  public void imgcode(HttpServletRequest request,HttpServletResponse response) throws IOException {

//生成验证码String code = CodeUtils.getCode4Hard();//将验证码存储session中

​    request.getSession().setAttribute("code", code);System.out.println("当前验证码"+code);//设置响应的内容类型(图片)

​    response.setContentType("img/jpeg");//防止缓存

​    response.setHeader("Pragma","No-cache");

​    response.setHeader("Cache-Control","no-cache");

​    response.setDateHeader("Expires",0);//将图片通过respose输出流输出图片ImageIO.write(new VerificationCodeImage(code).createImg(), "JPEG", response.getOutputStream());

  }

验证码的主要原理就是,通过生成获得的验证码,然后把验证码存入session[10]会话中,然后在前端中显示出图片。以下是前端调用其接口代码:

<img src=“/user/imgCode” alt=“” width=“300px” height=“50px” title=“看不起换一张”

οnclick=“this.src=‘/user/imgCode?r=’+Math.random()”>

其显示效果,如图5.2 所示。

img

图5.2 验证码图

5.1.2 登录功能的实现

注册功能实现之后,用户就可以知道了自己的账号和密码,然后就可以等待其跳转到登录页面进行下一步操作,登录上网站。

登录是每一个网站中必不可少的一个功能,为什么说它不可缺少呢,因为其特殊性,如果你不登录网站,就获取不到你的信息,获取不到你的信息,后续的大部分功能都是围绕着用户登录的信息展开的,而没有登录,也就无法实现后续的功能,所以说登录是必不可少的。

首先还是一样在HTML中创建一个form标签,并把其设置为post提交方式,之所以设置为这个提交方式,一是因为其不会把用户的信息在地址栏后拼接暴露出来,二是因为它的安全性和可传输的长度远远大于get提交方式。

把按钮设置为不可提交,然后通过layui绑定按键,触发form.on函数,接着在其中调用ajax就行了,接下来我将展示form.on中写的方法。其主要函数如下:

 form.on('submit(submitBtn)', function (data) {

​    console.log(data.field)

​    let username = data.field.username;

​    let password = data.field.password;

​    $.ajax({

​     type:'post',

​     url:'/user/login',

​     data:data.field,

​     success: function (data) {

​      console.log(data)

​      console.log(data.data.salt)if (data.data.salt==="1"){

​       layer.msg('登录成功',{icon: 1 },function () {

​        location.href="/html/index.html";})}else if (data.data === 0){

​       layer.msg('账号已被禁用', { icon: 2 }, { time: 2000 });}else if (data.data === 3) {

​       layer.msg('验证码错误', {icon: 2}, {time: 2000});} else {

​       layer.msg('密码错误', { icon: 2 }, { time: 2000 });}},

​     error: function (data) {

​      layer.msg('连接网络失败,请检查网络设置或联系管理员', { icon: 2 }, { time: 2000 });}})

   });

提交成功后,数据就会进入到后端,后端可以通过HttpServletRequest中的getParameter获取到想要的input中的value。得到了想要的数据之后,就可以去业务层进行逻辑处理。

以下代码是登录的逻辑代码:

public Result login(String name,String password) {User user = selByName(name);if (Objects.nonNull(user)) {if (user.getUsername().equals(name) && user.getPassword().equals(password)) {if (Objects.equals(user.getSalt(),"0")){return Result.ok(Constants.LOGIN_ACCOUNT_DISABLED).data(0);}return Result.ok(Constants.LOGIN_OK).data(user);}}return Result.ok(Constants.LOGIN_UNKNOW_USERNAME).data(2);

  }

同注册中的验证码功能一样,我也给了登录写上了验证码功能,可以有效防止用户的恶意登录。

5.1.3 地址模块的实现

在数据库中建好数据库表之后,还得在首页上写个超链接可以跳转到个人信息模块中,在个人信息模块中,可查看注册时填写的手机号、昵称、收货人、收货地址等。并且如果在购买商品时忘记填写地址时,会提示填写地址。在个人信息模块中还可对地址进行管理,例如删除和新增。

新增地址功能我是通过前端的form标签直接按钮提交至后端,后端拿到input的value值之后,直接进行相应的添加操作。

以下是后端的具体的代码实现:

地址新增代码的控制层:

 @RequestMapping("/add/address")

  public String addRess(HttpServletRequest request){String province = request.getParameter("province");String city = request.getParameter("city");String district = request.getParameter("district");String address = request.getParameter("address");String name = request.getParameter("name");String phone = request.getParameter("phone");//得user对象Object user1 = request.getSession().getAttribute("user");User user = (User) user1;

​    address = province +"-"+city+"-"+district+"-"+address;Address1 address1 = new Address1();

​    address1.setUid(user.getUid());

​    address1.setUaddress(address);

​    address1.setName(name);

​    address1.setPhone(phone);

​    address1Service.insertSelective(address1);return "redirect:/html/user.html";

  }

控制层通过HttpServletRequest中的getParameter方法得到input的value值之后,就可以进行业务层的业务逻辑插入数据库操作了。而因为我的个人信息是存储在session中的,所以需要它时,只需要通过request.getSession().getAttribute()[11];方法取得相应的session值即可。

地址的显示是基于layui上的table模块进行实现显示的,它里面有一个table.render进行数据表格渲染。

以下是数据表格的渲染代码:

table.render({

​      elem: '#test',url: '/info/address'

​      ,toolbar: '#toolbarDemo'

​      ,cols: [[{type:'radio'},{field:'id', width:80, title: 'ID', sort: true},{field: 'name', title: '收货人姓名'},{field: 'phone', title: '电话',  sort: true},{field: 'uaddress', title: '收获地址'}]],page: true});

数据渲染完成后,页面就可以成功回显出你想要的数据了。如图5.3所示。

img

图5.3 地址显示

地址的删除功能,是基于layui数据表格实现的,该table中有一个属性叫toolbar该属性可开启头部按钮并可绑定table.on头部工具栏事件。

以下是头部工具栏事件的Javascript的代码:

table.on('toolbar(test)', function(obj){var checkStatus = table.checkStatus(obj.config.id); //获取选中行状态switch(obj.event){case 'getCheckData':var data = checkStatus.data;  //获取选中行数据

​          layer.confirm("确认删除?",function (index,resp) {

​            $.each(data,function (index,e) {

​            let address_id = e.id;

​            let uid = e.uid;

​            $.ajax({

​              type:'get',

url:'/address/del?address_id='+address_id+'&uid='+uid,

​              success: function (data) {

​                console.log(data)if (data.data===1){

​                  layer.msg('删除成功', { icon: 1 }, { time: 2000 });

​                  location.reload();}else {

​                  layer.msg('删除失败,请检查该地址是否已删除', { icon: 1 }, { time: 2000 });}},

​              error: function (data) {

​                layer.msg('连接网络失败,请检查网络设置或联系管理员', { icon: 2 }, { time: 2000 });}})})})break;};});

5.1.4 订单模块的实现

订单模块是整个系统中实现起来最复杂的一个模块了,因为它要处理的逻辑有很多,关联的表也有很多,所以它才显得比较麻烦和复杂,而我是怎么实现的呢?首先数据库中我先给了它一个存储订单的订单表,而有了订单表还不行,还要有一个与之对应的订单项表,订单项表中装有订单表的商品数量生成时间,收货地址等。订单表还要跟用户关联,这样才能确定订单是谁的,是哪个用户的。

订单在前端中的显示并不复杂,复杂的是购买商品成功后,生成订单时的复杂关系。

而现在,我所说的订单模块,订单模块,在前端中只用显示用户何时购买的、货物运输的状态、收到货后可让用户点击确认收货。

货物运输的状态,用户购买成功时,其状态是默认未发货,只能通过后台管理员确认已发货时,方可点击发货。

以下是确认收货的前端Javascript[12]代码的具体实现:

function btn(id) {

​    layui.config({

​      base: '../res/static/js/util/' 

​    }).use(['mm', 'laypage', 'jquery'], function () {var laypage = layui.laypage, $ = layui.$,

​        mm = layui.mm;

​      let jquery = layui.jquery;

​      let s = id.charAt(id.length - 1);

​      console.log(id + "---" + s)

​      let value = document.getElementById('i' + s).value;

​      let oid = document.getElementById('oid' + s).value;

​      $.get('/goods/alterGoodsState?oid=' + oid);if (value === "2") {

​        console.log(value)

​        document.getElementById('bdiv' + s).innerHTML = '<input type="hidden" id="oid{{index}}" value="{{item.orderform.oid}}">\n' +

​          '           <span id="b{{index}}" class="layui-btn layui-bg-orange" " >\n' +

​          '             已到收货\n' +

​          '           </span>';}})

  }

后台则是获取到其订单id后即可进行订单状态的修改。

以下代码为确认收货成功后的订单后台状态代码:

@ResponseBody

  @RequestMapping("/goods/alterGoodsState")

  public Result alterState(HttpServletRequest request){String oid = request.getParameter("oid");int id = Integer.parseInt(oid);System.out.println(id);Object user1 = request.getSession().getAttribute("user");User user = (User) user1;Orderform orderform = orderformService.selectByPrimaryKey(id, user.getUid());

​    orderform.setState(2);System.out.println(orderform);return orderformService.updateByPrimaryKeySelective(orderform);

  }

确认收货后,页面会提升收货成功,如图5.4所示。

img

图5.4确认收货效果

订单列表展示,该功能主要用于展示订单,让用户可以查询订单,看到订单的详情等。具体实现,我前端用的是模板渲染出效果。后端就一个查询所有提供数据,再通过前端传回分页数据,完成分页。

以下是前端的渲染模板代码:

有了模板之后还要通过后端接口返回接口数据才能完成真正的渲染,以下是Javascript详情代码:

let html1 = demo1.innerHTML;

 

​        let listCont1 = document.getElementById('huolong');

​        jquery.get('/goods/selOrderform?limit=5&page=0&uid=' + uid, function (resp) {

 

​          let data1 = resp.data;

​          laypage.render({

​            elem: 'demo0',

​            count: resp.count, //数据总数

​            limit:3,

​            jump:function (obj,first) {

​              jquery.get('/goods/selOrderform?uid=' + uid+'&page='+obj.curr+'&limit='+obj.limit, function (resp) {

​                listCont1.innerHTML = mm.renderHtml(html1, resp);})}});})

前端已经准备完毕了,接下来就是后端的接口数据,由于代码过于繁多就不放上来了。

5.1.5 购物车模块的实现

该模块中包含了商品加入购物车、购物车结算和删除购物车商品等功能。

首先是加入购物车的实现在每一个商品详情页中加入一个购物车按钮,该购物车按钮可以把它设置为一个超链接,然后通过地址拼接方式得到商品信息,再从后端中查询商品加入到购物车中就可以实现该功能。

以下是后端控制层代码:

@ResponseBody

  @RequestMapping("/goods/addnumber")

public Result addNumber(HttpServletRequest request){String cid1 = request.getParameter("cid");int cid = Integer.parseInt(cid1);Object user = request.getSession().getAttribute("user");User u = (User)user;int uid = u.getUid();Shopcar shopcar = shopcarService.selByCidAndUid(cid, uid);Integer cnumber = shopcar.getCnumber();

​    cnumber+=1;

​    shopcar.setCnumber(cnumber);int i = shopcarService.updateByPrimaryKeySelective(shopcar);System.out.println(i);return  Result.ok(Constants.OK).data(i);

}

然后是复杂的购物车结算功能,因为结算时,你必须需要得到用户的地址,你才可以进入到下一步,如果你不得到地址,或者不给用户选择地址的机会,这一切都是不合理的,所以我设计了一套逻辑。如图5.5所示。

img

图5.5 购物车结算流程图

5.1.6 购买模块的实现

购买模块,实现的过程总的来说挺曲折的,当时开发的时候,走了不少弯路,跌跌撞撞终于不负众望成功实现了该功能。

该模块的总体流程图如图5.6所示。

img

图如5.6 购买商品流程图

首先是点击商品进行购买,然后进入到了商品详情页后可选择加入购物车或者购买,点击购买的话,还会进入到一个页面中,等待用户选择商品的数量。待用户操作完后,点击确认购买,就会进入到下一个页面,该页面中会显示用户需要购买商品的数量、商品的价格和选择地址。如果用户没有地址的话,可以选择新增地址,不选择新增地址的话,用户是不能点击付款进行下一步支付操作的。选择完地址后,用户就会进入到下一个页面再次确认地址和商品没有问题时,方可付款。

用户确认地址,和商品无误后方可进行下一步,付款操作。如图5.7所示。

img

图5.7用户确认界面

前端的处理流程大致情况如上所述,然后接下来是关于后端的数据操作。

首先获取到前端的传到后台的数据数据,需要获得的数据有商品表的唯一id、地址表的唯一id、商品的数量ornumber和用户唯一id。得到了这些数据后就可以继续进行下一步了。

首先是减少商品库存,下一步是生成订单,下一步是商品计算总价,下一步是为订单加上地址,最后是为用户生成订单。

以下是具体控制层代码:

@RequestMapping("/goods/pay")

  public String pay(HttpServletRequest request,String gid,String ornumber){int gid1 = Integer.parseInt(gid);int ornumber1 = Integer.parseInt(ornumber);String id = request.getParameter("id");int address_id = Integer.parseInt(id);//时间DateFormat fmt = DateFormat.getDateTimeInstance();

​    fmt = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String format = fmt.format(new Date());//修改库存Result result = goodsService.selectByPrimaryKey(gid1);Object data = result.getData();List<Goods> g= (List<Goods>) data;Goods goods = g.get(0);Integer gnumber = goods.getGnumber();String gname = goods.getGname();int number = gnumber - ornumber1;

​    goods.setGnumber(number);

​    goodsService.updateByPrimaryKeySelective(goods);//获取用户对象Object user = request.getSession().getAttribute("user");User u = (User) user;Integer uid = u.getUid();//生成订单Orderform or1 = new Orderform();

​    orderformService.selCountUid(uid);

​    or1.setOname(gname);

​    or1.setOprice((ornumber1 * goods.getSellprice()));

​    or1.setUid(uid);//默认 0未发货

​    or1.setState(0);

​    or1.setAlterdate(format);//生成订单IDint i = orderformService.insertSelective(or1);System.out.println("自增id:"+or1.getOid());System.out.println("===="+i);Orderitems orderitems = new Orderitems();

​    orderitems.setUid(uid);

​    orderitems.setGid(goods.getGid());

​    orderitems.setOid(or1.getOid());

​    orderitems.setOrnumber(ornumber1);

​    orderitems.setOrprice(goods.getSellprice());

​    orderitems.setAddressId(address_id);

​    orderitems.setOrupdate(format);//生成订单项int i1 = orderitemsService.insertSelective(orderitems);System.out.println("===="+i1);return "redirect:/html/payfinish.html";

  }

5.1.7 关键字搜索的实现

关于本功能,我在商城的首页右上角,每个页面的右上角都加了一个搜索框,该搜索框可帮助用户找不到商品时,可直接用这个搜索框进行模糊查询,搜索到自己想要的商品。

以下是关于搜索框的展示图。如图5.8所示。

img

图5.8搜索框展示图

该功能用了layui的form.on函数进行绑定提交,通过location.href 进行地址栏拼接方式把用户要搜索的商品名发送到后端,后端接受到后,再用模糊查询进行查询。

以下是前端form.on的JS代码:

//绑定表单提交的回调

 form.on('submit(submitBtn)', function (data) {

  //发送ajax请求,提交表单数据到后台

  console.log(data.field.gname);

  console.log(data.field);

  sessionStorage.setItem("goodsItem", JSON.stringify(data.field));

  location.href = '/html/sousuo.html?gname='+data.field.gname+'&limit=10&page=0';

 });

提交后可跳转到查询页面,通过后端查询,以下是后端控制层代码:

@ResponseBody

  @RequestMapping("/goods/sousuo")

  public Result sousuo(HttpServletRequest request,String gname,String page,String limit){int limit_1 = Integer.parseInt(limit);int page_1 = Integer.parseInt(page);String name = "%"+ gname +"%";Result result = goodsService.selectByGnameMoHu(name,page_1,limit_1);return result;

  }

以下是模糊查询的查询语句:

select  gid, gname, gnumber, sellprice, getprice, gunit, city, skid, img  from momandbabyshop.goods where gname like #{gname,jdbcType=VARCHAR}

Sql中我为什么不用号查询呢?既方便又省心,我之所以不用是因为号的效率极其的低下,非必要的时候一定不能用它。

5.1.8 商品销量展示功能的实现

本功能的实现我是把销量的显示放在了商品的右下角,这样用户就可以清晰的看到该商品卖出了多少件,然后商品页面还有销量和价格的排序,这样就可以帮助用户拥有更多的选择性。如图5.9所示。销量的排序主要实现思路是点击它跳转到一个新页面进行查询销量数排序即可完成该功能,简单并且实用。

img

图5.9 商品销量的展示

5.2 后台各项基本功能的实现

5.2.1 管理员登录模块的实现

管理员登录,该功能,我做的很简单,就一个简单的登录功能,不能注册,它没有多余的功能,就只能用来登录上后台管理界面。

同前台的登录功能一样,需要得到前端传过来账号密码,后端获取到再做相应的逻辑处理,然后把管理员信息,保存到session会话中,就可以随意取到它完成往后的操作了。

5.2.2 商品管理模块的实现

商品管理模块,其中包含了许多小功能,例如商品列表的展示、商品的上传、商品的编辑、商品的详情和商品的删除。

1.商品的上传

首先是商品上传,前台的商品是怎么来的呢?当然是从后台进行上架,前台才可以看的到,所以这个商品上传功能就因此诞生。首先我商品图片的存储位置,我利用的是OSS对象存储技术,并根据其的开发手册封装成了一个新的工具类。我为什么要把它封装成工具栏?因为封装成工具类,可以方便我的复用。因为我不止一处地方使用到它,我很多地方都使用到了它。该工具类代码详情请看附录内的QiniuOssUtils代码。

商品上传唯一一点比较麻烦的地方就是上传商品的图片至七牛云存储空间中,不过用我已经封装好的工具类,困难也就迎刃而解了。只需要在前端把提交方式改为post提交,之后再用layui的form.on函数就可以解决掉这个难题。

以下是前端提交的JS代码:

//绑定表单提交的回调

​    form.on('submit(submitBtn)', function (data) {//将表单对象包装为一个formdata(提交到后台数据)

​      let formData = new FormData($('#form1')[0]);//发送ajax请求,提交表单数据到后台

​      $.ajax({

​        url: '/admin/goods/add',

​        type: 'post',

​        data: formData,   //设置需要提交的表单数据

​        contentType: false,//禁用jquery提供的默认contenttype设置(防止表单数据以查询字符串的形式提交)

​        processData: false,//设置数据出来方式:禁止将数据转换为查询字符串

​        success: function (resp) {if (resp.code === 10016) {

​            layer.msg('添加完成', function () {

​              location.href = 'goodslist.jsp'

​            })}},

​        error:function (response) {

​          console.log(response)

​          layer.msg('添加失败')}});});

在其中我还增加了一个小小的功能,上传前可以预览你上传的图片是什么图片。该功能使用了layui中的upload.render上传渲染函数。

以下是具体实现代码:

upload.render({

​      elem: '#selectBtn',

​      auto: false,

​      field: 'headImg',

​      acceptMime: 'image/*',

​      choose: function (obj) {

​        obj.preview(function (i, f, result) {

​          $('#headImg').prop('src', result);

​        })

​      }

​    })

后端的控制层接受到数据之后在调用我所封装的七牛云工具类,即可直接上传至七牛云存储空间,它会返回一个访问地址,把该访问地址存储到mysql数据库表中即可完成此功能。

以下是具体的控制层代码:

@ResponseBody

  @RequestMapping("/admin/goods/add")

  public Result addGoods(HttpServletRequest request,@RequestPart("headImg") MultipartFile file) throws IOException, ServletException {String gname = request.getParameter("gname");String n = request.getParameter("gnumber");int gnumber = Integer.parseInt(n);String sell = request.getParameter("sellprice");double sellprice = Double.parseDouble(sell);String get = request.getParameter("getprice");double getprice = Double.parseDouble(get);String gunit = request.getParameter("gunit");String city = request.getParameter("city");String sid = request.getParameter("skid");int skid = Integer.parseInt(sid);String fname = file.getOriginalFilename();// 使用七牛Oss存储文件并获取最终的文件存储地址

​    fname = new QiniuOssUtils().upload(file.getInputStream(), fname);Goods goods = new Goods(gname, gnumber, sellprice, getprice, gunit, city, skid, fname);return goodsService.insertSelective(goods);

}

2.商品的编辑

接着就是商品的编辑,起初我为了实现商品的编辑,一直在研究怎么再前端把数据表格中的数据带入到下一个页面中,这个问题,困扰了我将近一个星期,最后通过我的不断查询资料文件,终于在一个不起眼的小网站中看到了该函数“sessionStorage.setItem(“goodsItem”, JSON.stringify(data))”,该函数的作用是什么呢,原来,该函数可以把一个json出入到session会话中,之后再通过KEY-值的方式再下一个页面取出来,于是我就通过这个函数实现了该方法。

虽然说该功能跟商品上传功能类似,但当时我完成该功能时,进行测试的时候,其有一个小小的bug,就是你修改完之后,但是你没有改动图片,最后你提交数据,再查看时,就发现图片看不到了,地址的指向不对了。

后面经过我的不断调试,我发现了原因。原来直接不修改图片上传的话,上传的是一串地址,七牛云那边可不知道这一串地址是什么意思,于是我就在控制层做了如下的代码逻辑:

String img = request.getParameter("img");

int i = img.lastIndexOf("/");

int index =i+1;//获取图片的名字String imgName = img.substring(index);String fname = file.getOriginalFilename();

​    fname = new QiniuOssUtils().upload(file.getInputStream(), fname);String sub = fname.substring(index);//判断是否是图片.的名字

boolean matches = sub.matches(".+(.JPEG|.jpeg|.JPG|.jpg|.GIF|.gif|.BMP|.bmp|.PNG|.png)$");//纯地址就拼接原来的图片名if (!matches){

​      fname = fname +imgName;}

​ 该代码的意思就是,如果是存地址的话就拼接前端传过来的图片名字,并存入到持久层中,如不是则上传至七牛云,并得到其返回的地址存入到持久层中。

3.商品的详情

这个功能很简单,只需要一串代码就搞定了,其实就是在后台显示其的json数据。

代码如下:

layer.alert(JSON.stringify(obj.data));

4.商品的删除

删除功能,该功能是通过layui的table.on中确定删除的数据id,再通过地址拼接方式传入后端,后端获取到id可直接调用业务层代码进行删除。

5.商品列表的显示

该功能利用了layui中的table.render函数来渲染出整个表格,以上的4个功能也是基于这个显示表格进行实现的。如何渲染?为前端提供个接口,接口提供layui的table.render中的json规范,即可成功渲染。

5.2.3订单管理模块的实现

订单模块,为什么要做这个模块呢?因为该模块可以让我选择什么时候发货,还可以帮助我们发货后可再后台观察到订单的走向,用户有没有确认收货等。

订单列表显示,该功能利用了layui中的table.render函数来渲染出整个表格如何渲染?为前端提供个接口,接口提供layui的table.render中的json规范,即可成功渲染。

渲染成功后,再其身后我为其加了一个发货功能,当货物准备好时,交给快递员并发送出去,这时就可以点击发货,用户那边也可以看到商品已经发货。该功能是实时的。如果已经发货过,再点击发货,是无法发货的,页面会提醒无法发货。如图5.9所示。

img

图5.9发货失败

以下是前端具体实现代码:

case 'edit':

​          layer.confirm("确认要发货么?",function (index,resp) {

​            let oid = data.orderform.oid;

​            let uid = data.orderform.uid;

​            $.ajax({

​              type:'get',

​              url:'/admin/goods/upstate?oid='+oid+'&uid='+uid,

​              success: function (data) {

​                console.log(data)if (data.data===1){

​                  layer.msg('发货成功', { icon: 1 }, { time: 2000 });

​                  location.reload();}else {

​                  layer.msg('发货失败,请检查该订单是否已发货', { icon: 1 }, { time: 2000 });}},

​              error: function (data) {

​                layer.msg('连接网络失败,请检查网络设置或联系管理员', { icon: 2 }, { time: 2000 });}})})break;

5.2.4 用户管理模块的实现

该功能的作用,主要是用于防止那些恶意用户胡乱购买,胡乱搞破坏而开发的功能,该功能可以对用户进行封禁和解禁处理。如图5.10所示。

img

图5.10 用户列表展示图

该功能实现方式也很简单,首先通过layui的table.on函数获取到该用户id后,再传入到后台,做出相应的逻辑判断。即可完成对该用户账号的相应操作。封禁后,该用户将不可再次登录到本网站中。

*6* *测试运行*

6.1 注册与登录模块测试

注册登录模块首先是判断该用户是否已经被注册过,如果已被注册过,将不可再次注册。这时就得更换其他注册账号,并且验证码需要填对才可进行注册。

以下是注册成功的页面。如图6.1所示。

img

图6.1注册成功页面

注册成功后,页面将跳转至登录页面。再登录页面输入刚刚注册的账号即可登录成功。以下是登录成功的页面,如图6.2所示。

img

图6.2登录成功页面

登录成功后进入到商城首页。如图6.3所示。

img

图6.3 商城首页

点击所有商品进入到所有商品页面。如图6.4所示。

img

图6.4 所有商品页面

6.2 地址模块测试

地址模块中包含了地址显示、地址删除和地址新增功能。以下是地址显示的页面,因地址是于用户关联的,所以我把它放在了用户个人信息模块下。如图6.5所示。

img

图6.5 个人地址显示列表

接下来是新增地址,点击新增地址之后,就会进入到新增地址页面中,城市的选择我用的是导入js然后下拉框读取js中的json实现的。以下是添加地址的页面,添加成功后,页面就会自动跳回个人信息模块。如图6.6所示。

img

图6.6 地址添加页面

添加成功后,即可在用户信息中查看地址信息。如图6.7所示。

img

图6.7地址列表显示

接着就是地址的删除,选中地址删除后,会弹出一个对话框,询问是否删除,如点确定则删除成功。如图6.8所示。

img

图6.8 删除地址

6.3 购买模块测试

首先随便选择一个商品,点击其图片,然后进入到其商品详情页。如图6.9所示。img

图6.9 商品详情页

然后点击购买,即可进入选择商品数量页面图,如图6.10所示。

img

图6.10 选择购买数量页面

选择好数量后,在进行下一步选择地址,没有地址的话就可以点击下方的新增地址进行增加地址。如图6.11所示。

img

图6.11 选择地址页面

选择好地址就可以点击左上方的确认地址,如图6.12所示。

img

图6.12 确认地址页面

就可以进入到下一步确认商品和地址无误的页面。如图6.13所示。

img

图6.13 确认购买页面

在点击购买即可进入付款页面,付完款,点击已付款即可购买成功。如图6.14所示。

img

图6.14支付成功

6.4 购物车模块测试

购物车包含加入购物,删除购物车中的商品和结算商品功能。

首先是加入购物车,先随便选择某一个商品,进入到其商品详情页之后,选择加入购物车,如图6.15所示。

img

图6.15 加入购物车

加入购物车后,可在购物车页面查看到该商品。如图6.16所示。

img

图6.16 购物车页面

接着是结算,结算一样需要地址,没有地址的话可以新增一个地址,已有地址则继续下一步确认地址信息是否正确,接着就是支付。如图6.17所示。

img

图6.17 确认地址页面

检查地址和确认地址页面,如图6.18所示。

img

图6.18检查地址页面

确认地址无误后,点击确定购买,跳转到支付页面,支付成功后点已付款即可。如图6.19所示。

img

图6.19 购物车结算页面

6.5 订单模块测试

订单模块中主要包含订单列表显示和订单确认收货等。点击商城右上角的订单按钮,可进入订单页面。如图6.20所示。

img

图6.20订单列表页面

当商品发货时,用户已收到货,用户可点击确认收货,按钮则会变成已到货模样。如图6.21所示。

img

图6.21 点击确认到货效果图

6.6 关键字搜索测试

这个功能是为了方便用户能够更快的更加精准的找到想要的商品。

以下是搜索框的效果图。如图6.22所示。

img

图6.22关键字效果图

当我搜索“儿”的时候,只要有关于儿的字眼的标题都会显示出来。如图6.23所示。

img

图6.23 搜索关键字儿的效果

6.7 管理员登录与商品管理的测试

首先是管理员登录,输入正确的账号和密码时,点击登录则成功,自动跳转到管理员后台管理界面。如图6.24和图6.25所示。

img

图6.24登录界面

img

图6.25 后台管理首页

接着就可以继续进行后续操作了,首先是上传商品,填写好商品信息后即可进行上传,上传完成后还可去商品列表进行查看。如图6.26所示和图6.27所示。

img

图6.26 商品添加成功

img

图6.27 商品显示列表

商品的编辑,点击商品列表的编辑可进行操作,如图6.28所示。

img

图6.28 商品的编辑

点击编辑之后,就会跳转到如下图6.29页面,修改完毕后,点击提交修改即可。

img

图6.29 修改页面

修改完商品后,会弹出修改完成的提示,待提示消失就会返回商品列表。如图6.30所示。

img

图6.30 修改完成

最后则是删除商品,同样的,删除商品会弹出一个对话框来提示操作者,防止操作者误删等操作如图6.31所示。

img

图6.31 删除商品操作

删除完成后就会返回商品列表。

6.8 订单管理模块的测试

订单模块是用于给用户发货的模块,其页面展示效果如下图6.32所示。

img

图6.32 订单列表展示

当用户购买商品时,并且我已经准备好发送出快递时我就可点击发货。其发货效果如下图6.33所示。

img

图6.33 商品发货效果图

6.9 用户模块的测试

该模块主要是用来封禁那些顽固分子的功能,比如用户的恶意购买,恶意破坏网站等。这时就可以用这个功能来封禁那些可恨的账号。

用户列表展示效果。如下图6.34所示。

img

图6.34 用户列表

点击封禁用户效果图。如图6.35所示。

img

图6.35 禁用后的效果图

被禁用的用户登录网站时是登录不上的,并且会收到提醒,如图6.36所示。

img

图6.36 账号封禁后登录效果

6.10 销量排序的测试

点击所有商品,进入到所有商品页面时,即可看到商品的销量库存等。点击商品列表上方的销量排序,即可看到销量由多到少进行排序。如图6.37所示。

img

图6.37 商品销量排序

*7* *总结*

作为一个即将毕业的大四学生的我来说,这一次的毕业设计对我的影响非常的巨大。我从刚开始拿到毕业设计时的无从下手,到现在的想修改哪就修改哪都离不开我的指导老师的帮助。

而我在实现项目中遇到的困难不止那一星半点,有些困难难住了我一个星期,有些难住了我半个月,甚至有时候睡觉的时候,我都在梦里梦到了我在奋力的敲代码。其中我遇到的最大的困难就是调用其他平台的接口来实现自己的文件储存。因为我当时想的是如果文件存储在本地的话,往后如果继续在这个项目上进行开发。会造成很多不必要bug,所以我就把储存地址,更换到了七牛云上。刚开始使用时,我是完全不知道如何使用的,然后只能自己一个字一个字的啃七牛云提供给开发者的开发文档,自己独立研究。慢慢的研究了一个多星期,终于实现了OSS对象储存。也就是只需要提供一个key就能取到其中的值。当然这个其中不止这一个难点,还有它的文件上传方式,当时我还特意为其写了一个正则表达式,专门为它所用。

项目中的配置也是最让人难受的,一不小心就看漏一点。项目就会报错个不停,刚开始搭建起项目框架就花费了我大量的精力,主要还是它报的错有点不搭边,非常让人感觉到其不规范性。不过后来慢慢查阅资料,慢慢就学会了。

论文原版地址:https://download.csdn.net/download/blacksix/86732794
源码地址:https://download.csdn.net/download/blacksix/86732793

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐