基于Spring Boot的美妆销售系统设计与实现--14016(免费领源码)原创的定制程序,java、PHP、python、C#小程序、文案全套、毕设成品等等.

 

随着互联网技术的飞速发展和电子商务行业的不断壮大,美妆行业也迎来了线上销售的新浪潮。然而,传统的美妆销售系统往往缺乏个性化服务与高效的管理系统支持,难以满足现代消费者日益增长的需求及商家精细化管理的要求。本研究旨在通过设计并实现一个基于Spring Boot框架的美妆销售系统,以提升用户体验和优化后台管理效率为目标,为美妆电商的发展提供新的思路与方法。

美妆销售系统采用Java编程语言,结合Spring Boot框架构建后端服务,并使用MySQL数据库进行数据存储。系统实现了用户注册登录、商品浏览购买、购物车管理、订单处理等基本功能;同时,管理员可通过后台实现对商品信息、用户信息、订单状态、网站公告以及美妆资讯等内容的高效管理。此外,系统还特别集成了权限管理模块,确保不同角色的用户只能访问相应权限范围内的资源。

美妆销售系统的开发不仅为用户提供了一个便捷、个性化的在线购物平台,同时也为商家提供了强大的后台管理支持,有助于提高运营效率和服务质量,进而增强市场竞争力。系统的设计理念和技术方案对于推动美妆电商行业的创新与发展具有重要的理论价值和实践意义。

关键词Spring Boot框架;美妆销售系统;Java语言;MySQL

Abstract

With the rapid development of Internet technology and the continuous growth of the e-commerce industry, the beauty industry has also ushered in a new wave of online sales. However, the traditional beauty sales system often lacks personalized services and efficient management system support, which is difficult to meet the growing needs of modern consumers and the requirements of refined management of merchants. The purpose of this research is to design and implement a beauty sales system based on the Spring Boot framework, with the goal of improving user experience and optimizing the efficiency of back-end management, and provide new ideas and methods for the development of beauty e-commerce.

The beauty sales system uses the Java programming language, combined with the Spring Boot framework to build back-end services, and uses the MySQL database for data storage. The system realizes basic functions such as user registration and login, product browsing and purchase, shopping cart management, and order processing; At the same time, administrators can efficiently manage product information, user information, order status, website announcements, beauty information and other content through the background. In addition, the system also integrates a permission management module to ensure that users with different roles can only access resources within the corresponding permission range.

The development of the beauty sales system not only provides users with a convenient and personalized online shopping platform, but also provides merchants with strong back-end management support, which helps to improve operational efficiency and service quality, thereby enhancing market competitiveness. The systematic design concept and technical scheme have important theoretical value and practical significance for promoting the innovation and development of the beauty e-commerce industry.

Key words: Spring Boot framework; beauty sales system; Java language; MySQL

目  录

第1章 绪  论

1.1 研究背景和意义

1.2 国内外研究现状

1.3 本文主要工作

1.4 论文结构与章节安排

第2章 关键技术介绍

2.1 Java语言

2.2 Spring Boot框架

2.3 MySQL数据库

2.4 B/S体系结构

第3章 系统分析

3.1 可行性分析

3.1.1 技术可行性

3.1.2 经济可行性

3.1.3 操作可行性

3.2 系统功能需求分析

3.3 系统用例分析

3.3.1 注册用户用例分析

3.3.2 管理员用例分析

3.4 非功能需求分析

3.5 系统流程分析

3.5.1 用户注册登录流程

3.5.2 用户购买美妆商品流程

3.5.3 管理员美妆商城管理流程

第4章 系统设计

4.1 系统架构设计

4.2 功能模块设计

4.3 数据库设计

4.3.1 概念设计

4.3.2 逻辑设计

第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.2 后台管理模块的实现

5.2.1 后台登录界面

5.2.2 后台首页界面

5.2.3 系统用户界面

5.2.4 系统管理界面

5.2.5 资源管理界面

5.2.6 商城管理界面

5.2.7 权限管理界面

第6章 系统测试

6.1 测试目的

6.2 测试用例

6.3 测试结果

结  论

参考文献

附 录

第1章绪  

1.1研究背景和意义

随着互联网技术的迅猛发展和移动智能设备的广泛普及,电子商务已成为现代商业活动不可或缺的一部分。特别是在美妆行业,消费者对于个性化服务、便捷购物体验的需求日益增长,传统的美妆销售模式已难以满足市场需求。此外,随着市场竞争的加剧,商家迫切需要一种能够提高运营效率、优化顾客服务体验并能实现精细化管理的解决方案。然而,当前市场上许多美妆电商平台在用户体验和后台管理方面仍存在诸多不足,如系统响应速度慢、用户界面不友好、缺乏有效的数据管理和分析工具等。这些问题的存在不仅限制了商家的发展,也影响了消费者的购物体验。

本研究旨在通过设计与实现一个基于Spring Boot框架的美妆销售系统来解决上述问题。该系统不仅为消费者提供了一个高效、便捷、个性化的在线购物环境,包括商品浏览、购买、购物车管理、订单追踪等功能,还为商家提供了强大的后台管理系统,支持商品信息管理、用户信息维护、订单处理、网站公告发布以及美妆资讯更新等操作,并通过权限管理确保系统的安全性。此美妆销售系统的开发对于推动美妆电商行业的创新与发展具有重要的理论价值和实践意义,有助于提升企业的市场竞争力,同时也能显著改善用户的购物体验,促进消费增长。

1.2国内外研究现状

在国内,随着互联网普及和电子商务的蓬勃发展,美妆行业的线上销售经历了从传统电商平台简单铺货到构建专业美妆垂直电商的转变。近年来,越来越多的品牌和零售商开始重视通过技术手段提升用户体验和运营效率,这促使了一系列专注于个性化推荐、智能客服、数据分析等领域的美妆销售系统的出现。然而,尽管市场呈现出快速增长的趋势,但许多系统在用户界面设计、后台管理功能以及数据安全方面仍存在改进空间。同时,随着消费者对美妆产品需求的多样化和个性化,如何更好地满足这些需求成为了当前国内美妆电商发展的重要课题。

在国外,美妆行业对于数字化转型和技术应用的研究起步较早,尤其在利用大数据分析进行精准营销、增强现实技术用于虚拟试妆等方面处于领先地位。国际上知名的美妆品牌和零售商纷纷加大了对线上销售渠道的投资,并积极探索AI和机器学习技术的应用,以实现更高效的库存管理和个性化的顾客体验。此外,国外的美妆电商平台更加注重用户的隐私保护和数据安全,不断引入先进的加密技术和隐私保护策略。尽管如此,面对日益激烈的市场竞争和消费者期望值的提高,持续的技术创新和服务优化依然是国外美妆电商领域关注的重点。

1.3本文主要工作

在本文中,我们首先分析了当前美妆电商领域存在的挑战和需求,明确了系统的选题依据和目的。随后,详细阐述了系统的设计与实现过程,包括技术选型Spring Boot、Java、MySQL、功能模块划分以及数据库结构设计等关键环节。此外,我们还讨论了如何通过引入权限管理和数据加密等措施来增强系统的安全性。最后,通过对系统进行严格的测试和验证,证明了所提出的美妆销售系统不仅能够满足用户的购物需求,也为商家提供了一套有效的后台管理工具,具有较高的实用价值和市场应用前景。

系统集成了用户注册登录、商品浏览与购买、购物车管理、订单处理等核心功能,并提供了针对管理员的商品信息维护、用户信息管理、订单状态跟踪及网站公告发布等全面的后台管理功能。特别地,系统还强调了权限管理的重要性,以确保不同角色用户只能访问相应权限范围内的资源。通过结合现代Web开发技术和数据库管理策略,本研究探索了如何为美妆电商提供一个既高效又安全的在线平台。

1.4论文结构与章节安排

本文的结构按逻辑顺序分为以下几个章节:

第1章绪论,本章节介绍研究背景和意义,回顾当前研究现状,并阐明本文主要工作和论文组织结构。

第2章系统关键技术,本章节将对美妆销售系统的实现关键技术进行简要介绍。

第3章系统分析,本章节基于市场调研,分析美妆销售系统的可行性、功能、角色、性能等需求,明确各模块的业务需求。

第4章系统设计,本章节详细阐述系统的整体架构设计,包括前后端结构、数据库设计及功能模块的设计思路。

第5章系统实现,本章节介绍系统各主要模块的具体实现,包括代码示例、业务逻辑及界面设计等。

第6章系统测试,本章节描述系统的测试方法及结果,分析系统的性能、稳定性及用户反馈。

第7章结论,本章节对主要对研究成果进行总结。

第2章
关键技术介绍

2.1Java语言 

Java作为一种广泛使用的面向对象编程语言[1],为本系统提供了强大的开发基础。它具备跨平台特性、丰富的类库和稳定的安全性能,能够确保系统的高效运行和良好的扩展性。在美妆销售系统中,Java[2]用于编写后端业务逻辑,处理包括用户管理、信息管理在内的各种复杂操作,同时支持高并发访问,保证了系统的响应速度和稳定性。

2.2Spring Boot框架

Spring Boot是基于Spring框架的快速开发平台[3],极大地简化了基于Java的应用程序构建过程。它通过自动配置和约定优于配置的原则,减少了繁琐的设置工作,使开发者可以更专注于业务逻辑的实现。在本系统中,Spring Boot[4]不仅用于搭建RESTful API服务,提供前后端数据交互的接口,还集成了安全认证、事务管理和缓存等功能,以提升系统的整体性能和安全性,确保美妆销售系统的稳定性和可维护性。

2.3MySQL数据库

作为一款流行的开源关系型数据库管理系统,MySQL[5]以其高性能、可靠性和易于使用的特点成为本系统的数据存储解决方案。它支持复杂的查询和事务处理,适用于存储和管理大量的功能模块信息、用户数据以及交互记录。通过优化表结构设计和索引策略,MySQL能够快速响应系统的读写请求,保障数据的一致性和完整性,同时为数据分析和报表生成提供了坚实的基础[6]。

2.4B/S体系结构

B/S体系,即Browser/Server体系[7],是一种常见的网络应用程序架构。其工作原理基于客户端与服务器之间的请求-响应模型。用户通过浏览器向服务器发送请求,服务器接收到请求后进行处理,并生成相应的响应结果,最终将响应返回给客户端。浏览器接收到服务器返回的响应后,解析其中的标记语言(如HTML[8]),并根据CSS样式表和JavaScript脚本来渲染页面,呈现给用户。用户可以与页面进行交互,例如点击链接、填写表单等操作,这些操作会触发新的请求,循环执行上述过程。

第3章
系统分析

3.1可行性分析

3.1.1技术可行性

从技术角度来看,本系统基于Spring Boot框架构建,结合数据库管理,能够有效支持美妆销售系统的各项功能需求。Spring Boot提供了强大的架构支持,确保系统的可扩展性和稳定性。通过充分的技术调研和原型测试,我们确认现有的技术栈完全能够满足系统的开发和运行要求,具备较高的技术可行性。

3.1.2经济可行性

从经济角度考量,本系统的开发和维护成本在可控范围内,且预期的投资回报率较高。初期投入主要包括软件开发、硬件采购和人员培训等方面,但通过合理的预算规划和资源分配,可以有效控制成本。更重要的是,系统上线后将显著提升美妆销售系统的运营效率,减少人工干预,降低管理成本。

3.1.3操作可行性

在操作可行性方面,本系统设计注重用户体验,采用了直观易用的界面设计,并提供详细的帮助文档支持,确保用户可以轻松上手使用各项功能。无论是用户还是后台管理员,都能通过简洁明了的操作流程完成信息查询和管理等任务。因此,从用户操作的角度来看,本系统具备良好的操作可行性。

3.2系统功能需求分析

本美妆销售系统旨在为用户提供便捷的在线购物体验,并为管理员提供高效的后台管理工具。系统需要支持用户注册登录、商品浏览购买、订单处理等基础功能,同时还要具备个性化的用户中心和全面的后台管理系统,包括商品信息维护、订单管理、用户管理以及权限控制等功能模块。

  1. 注册用户模块:

首页:展示热门商品、推荐美妆和最新公告信息,吸引用户关注;支持分类筛选和搜索功能,帮助用户快速定位目标商品。

网站公告:查看系统发布的最新公告内容,了解书店动态。

美妆资讯:浏览行业动态或美妆商城相关的文章,丰富用户知识;支持按分类筛选和评论互动。

美妆商城:展示美妆商品信息、库存状态和价格详情,支持商品详情查看;用户可将商品加入购物车或直接购买。

商城管理:

我的购物车:管理已添加的商品,调整数量或删除商品;支持一键结算功能,生成订单。

我的订单:查看所有订单的状态和详情,包括待支付、已支付和已完成订单;支持订单取消和售后申请。

我的地址:管理收货地址信息,支持新增、编辑和删除操作;默认地址优先显示,方便快速下单。

我的账户:管理个人信息,包括昵称、头像和密码修改;支持绑定手机号或邮箱以增强账户安全。

个人中心:查看个人主页、订单配送和收藏夹内容。

  1. 管理员模块:

后台首页:提供商品销售金额与数量统计图表,帮助管理员快速了解销售情况。

系统用户:增删改查注册用户和管理员信息,包括账号状态和权限设置。

系统管理:上传和管理首页轮播图,支持图片排序和状态控制。

网站公告管理:发布和编辑公告内容,支持文本编辑。

资源管理:发布和管理美妆资讯内容,支持按分类筛选和评论管理。维护资讯分类信息,支持新增、编辑和删除操作;分类结构清晰,便于内容管理。

商城管理:

美妆商城:维护商品信息,包括名称、价格、库存和分类;支持商品上下架操作。

分类列表:管理商品分类信息,支持多级分类结构;分类支持拖拽排序和状态控制。

订单列表:查看所有订单状态和详情,支持按条件查询和批量处理;支持订单状态变更。

订单配送:管理订单配送信息,支持物流单号录入和状态更新;支持实时跟踪物流状态。

权限管理:设定不同角色的权限,限制其可访问的系统资源,确保数据安全性和系统的稳定运行。

3.3系统用例分析

3.3.1注册用户用例分析

注册用户主要围绕消费体验和个人信息管理展开。从浏览商品、加入购物车到下单支付,再到查看订单状态和物流信息,整个购物流程需要简洁高效。同时,美妆租借功能要求系统支持申请审核、归还提醒及超期处理等环节,确保用户体验流畅。此外,个人中心模块需提供账户管理、租借记录查询、收藏夹维护等功能,帮助用户更好地管理自己的信息和消费行为。注册用户角色用例图如下所示。

图3-1 注册用户用例图

3.3.2管理员用例分析

管理员聚焦于后台数据管理和业务流程监控。系统需支持用户信息维护、美妆与商品分类管理、库存更新及订单审核等核心操作,确保书店运营的规范化和高效化。在数据分析方面,管理员可通过统计图表了解销售情况、库存状态及用户行为,为决策提供依据。此外,公告发布、资讯管理和轮播图配置等功能则用于维护网站内容,提升品牌形象和用户吸引力。管理员角色用例图如下所示。

图3-2 管理员用例图

3.4非功能需求分析

系统非功能需求指的是性能需求,对一个系统的性能需求进行分析和定义的过程。在进行性能需求分析时,因此美妆销售系统的设计与实现主要需要考虑以下几个方面的性能需求:

响应时间:响应时间是指系统在接收到请求后,作出响应的时间。根据具体的业务需求和用户体验要求,可以确定系统在不同场景下的响应时间要求。

吞吐量:吞吐量是指系统在一定时间内处理的事务或请求的数量。根据业务需求和用户量的估计,可以确定系统需要支持的最大吞吐量。

并发用户数:并发用户数是指系统在同时使用的用户数量。根据预期的用户量和并发访问需求,可以确定系统需要支持的最大并发用户数。

可扩展性:可扩展性是指系统在面对用户量增加或并发访问需求增加时,能否通过增加硬件资源或调整系统架构来满足需求。根据预期的用户增长和扩展计划,可以确定系统需要具备的可扩展性要求。

故障处理能力:系统对故障的处理能力是指在出现错误或故障时,系统能够快速、准确地识别、定位并处理故障的能力。根据业务的重要性和对故障处理的要求,可以确定系统需要具备的故障处理能力。

安全性:系统在性能需求分析中,也需考虑安全方面的需求,如数据的保密性、完整性和可用性等。根据具体的安全需求和合规要求,可以确定系统需要满足的安全性需求。

通过对这些性能需求进行详细分析和定义,可以为美妆销售系统的设计和开发提供指导,确保系统在满足预期的性能需求的同时,具备良好的性能和可靠性。

3.5系统流程分析

3.5.1用户注册登录流程

用户注册登录模块主要是为了方便用户和管理员能够安全地访问系统并管理自己的信息。用户通过浏览器访问美妆销售系统,首先进入的是系统的登录页面。在登录页面,用户可以选择自己的账户角色,并输入相应的账号和密码。系统接收到用户的登录请求后,会将提供的账号和密码与数据库中存储的信息进行比对。如果账号或密码为空或者不匹配,则提示用户重新输入,并停留在登录界面。当账号和密码正确无误时,系统根据用户类型跳转到对应的首页界面。用户注册登录流程如下图所示。

图3-3 用户注册登录流程图

3.5.2用户购买美妆商品流程

用户购买美妆商品的流程始于访问系统主页,通过浏览商品列表或使用搜索功能找到目标商品。在商品详情页,用户可查看商品图片、价格、库存等信息,并选择规格后将商品加入购物车或直接下单。进入购物车后,用户可以调整商品数量、删除不需要的商品,并在确认无误后进入结算页面。在此阶段,用户需填写收货地址、选择支付方式并提交订单。支付完成后,用户可在“我的订单”中查看订单状态。用户购买美妆商品流程图如下图所示。

图3-4 购买美妆商品流程图

3.5.3管理员美妆商城管理流程

管理员对美妆商城的管理流程包括商品的新增、编辑、上下架以及分类维护等多个环节。首先,管理员通过后台管理系统录入商品基本信息,如名称、价格、库存、规格、简介等,并上传商品图片。接着,管理员根据商品类别将其归类,确保商品展示逻辑清晰。在商品上架前,管理员还需审核商品信息的完整性和准确性。当商品需要下架或更新时,管理员可通过编辑功能修改商品详情或直接将其下架。此外,管理员还可以批量导入商品数据以提高效率,并定期检查商品库存状态,及时补充或调整相关信息,确保平台商品信息的实时性和有效性。管理员美妆商城管理流程图如下图所示。

图3-5 管理员美妆商城管理流程图

第4章系统设计

4.1系统架构设计

美妆销售系统的架构设计包括客户端、服务器端、第三方集成、安全性和权限控制、扩展性和性能优化、高可用性和容错性等方面。客户端通过Web浏览器访问系统,而服务器端负责接收和处理请求,并提供功能和数据。系统采用分层架构,包括表现层、业务逻辑层、数据访问层和数据库。同时,系统需考虑与其他系统的集成、安全性和权限控制、扩展性和性能优化、高可用性和容错性等方面的问题。这样的架构设计将确保系统的稳定性、可扩展性和安全性,为用户提供稳定、高效的使用体验。系统架构图如下图所示。

图4-1 系统架构图

4.2功能模块设计

通过整体功能模块设计,我们将根据需求分析的结果,将系统的功能划分为不同的模块。每个模块负责实现特定的功能,并与其他模块进行协作。我们将详细定义每个模块的输入、输出、处理逻辑和相互依赖关系。系统总体功能模块图如下图所示。

图4-2 系统功能模块图

4.3数据库设计

4.3.1概念设计

借助先进的系统,E-R图使其他用户可以快速轻松地了解系统的功能以及他们之间的关系。根据美妆销售系统分析结果,本美妆销售系统总体E-R图如下图所示。

图4-3 系统总体E-R图

4.3.2逻辑设计

所有系统的应用数据相互区分。一旦在相应的系统中实现,它们将与自己相应的网络和服务器通信。所以这个系统可以连接这些数据。当我们选择桥梁截面时,以下将简要介绍如何建立系统。在单击上一个按键的时候,就会自动在对话框中弹出数据源的名字,之后再单击下一个按键时,就在填写相对应的身份验证和登录信息。按照系统功能设计的特点与职能模块的分类,美妆销售系统的总体设计和实施过程一共涉及到了几个资料表格。

根据E-R图,建立各个实体的数据表。由于本系统数据库数据表数量较多,所以只选取部分表单作为案列,如下所示:

表 4-1-access_token(登陆访问时长)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

token_id

int

临时访问牌ID

2

token

varchar

64

临时访问牌

3

info

text

65535

信息

4

maxage

int

最大寿命:默认2小时

5

create_time

timestamp

创建时间

6

update_time

timestamp

更新时间

7

user_id

int

用户编号

表 4-2-address(收货地址)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

address_id

int

收货地址

2

name

varchar

32

姓名

3

phone

varchar

13

手机

4

postcode

varchar

8

邮编

5

address

varchar

255

地址

6

user_id

mediumint

用户ID

7

create_time

timestamp

创建时间

8

update_time

timestamp

更新时间

9

default

tinyint

默认判断

表 4-3-article(文章)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

article_id

mediumint

文章id

2

title

varchar

125

标题

3

type

varchar

64

文章分类

4

hits

int

点击数

5

praise_len

int

点赞数

6

create_time

timestamp

创建时间

7

update_time

timestamp

更新时间

8

source

varchar

255

来源

9

url

varchar

255

来源地址

10

tag

varchar

255

标签

11

content

longtext

4294967295

正文

12

img

varchar

255

封面图

13

description

text

65535

文章描述

表 4-4-article_type(文章分类)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

type_id

smallint

分类ID

2

display

smallint

显示顺序

3

name

varchar

16

分类名称

4

father_id

smallint

上级分类ID

5

description

varchar

255

描述

6

icon

text

65535

分类图标

7

url

varchar

255

外链地址

8

create_time

timestamp

创建时间

9

update_time

timestamp

更新时间

表 4-5-auth(用户权限管理)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

auth_id

int

授权ID

2

user_group

varchar

64

用户组

3

mod_name

varchar

64

模块名

4

table_name

varchar

64

表名

5

page_title

varchar

255

页面标题

6

path

varchar

255

路由路径

7

parent

varchar

64

父级菜单

8

parent_sort

int

父级菜单排序

9

position

varchar

32

位置

10

mode

varchar

32

跳转方式

11

add

tinyint

是否可增加

12

del

tinyint

是否可删除

13

set

tinyint

是否可修改

14

get

tinyint

是否可查看

15

field_add

text

65535

添加字段

16

field_set

text

65535

修改字段

17

field_get

text

65535

查询字段

18

table_nav_name

varchar

500

跨表导航名称

19

table_nav

varchar

500

跨表导航

20

option

text

65535

配置

21

create_time

timestamp

创建时间

22

update_time

timestamp

更新时间

表 4-6-beauty_mall(美妆商城)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

beauty_mall_id

int

美妆商城ID

2

product_brand

varchar

64

商品品牌

3

product_name

varchar

64

商品名称

4

product_specifications

varchar

64

商品规格

5

hits

int

点击数

6

collect_len

int

收藏数

7

comment_len

int

评论数

8

recommend

int

智能推荐

9

cart_title

varchar

125

标题

10

cart_img

text

65535

封面图

11

cart_description

varchar

255

描述

12

cart_price_ago

double

原价

13

cart_price

double

卖价

14

cart_inventory

int

商品库存

15

cart_type

varchar

64

商品分类

16

cart_content

longtext

4294967295

正文

17

cart_img_1

text

65535

主图1

18

cart_img_2

text

65535

主图2

19

cart_img_3

text

65535

主图3

20

cart_img_4

text

65535

主图4

21

cart_img_5

text

65535

主图5

22

create_time

datetime

创建时间

23

update_time

timestamp

更新时间

表 4-7-cart(购物车)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

cart_id

int

购物车ID

2

title

varchar

64

标题

3

img

varchar

255

图片

4

user_id

int

用户ID

5

create_time

timestamp

创建时间

6

update_time

timestamp

更新时间

7

state

int

状态:使用中,已失效

8

price

double

单价

9

price_ago

double

原价

10

price_count

double

总价

11

num

int

数量

12

goods_id

mediumint

商品id

13

type

varchar

64

商品分类

14

description

varchar

255

描述

表 4-8-code_token(验证码)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

code_token_id

int

验证码ID

2

token

varchar

255

令牌

3

code

varchar

255

验证码

4

expire_time

timestamp

失效时间

5

create_time

timestamp

创建时间

6

update_time

timestamp

更新时间

表 4-9-collect(收藏)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

collect_id

int

收藏ID

2

user_id

int

收藏人ID

3

source_table

varchar

255

来源表

4

source_field

varchar

255

来源字段

5

source_id

int

来源ID

6

title

varchar

255

标题

7

img

varchar

255

封面

8

create_time

timestamp

创建时间

9

update_time

timestamp

更新时间

表 4-10-comment(评论)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

comment_id

int

评论ID

2

user_id

int

评论人ID

3

reply_to_id

int

回复评论ID

4

content

longtext

4294967295

内容

5

nickname

varchar

255

昵称

6

avatar

varchar

255

头像地址

7

create_time

timestamp

创建时间

8

update_time

timestamp

更新时间

9

source_table

varchar

255

来源表

10

source_field

varchar

255

来源字段

11

source_id

int

来源ID

表 4-11-goods(商品信息)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

goods_id

mediumint

产品ID

2

title

varchar

125

标题

3

img

text

65535

封面图:用于显示于产品列表页

4

description

varchar

255

描述

5

price_ago

double

原价

6

price

double

卖价

7

sales

int

销量

8

inventory

int

商品库存

9

type

varchar

64

商品分类

10

hits

int

点击量

11

content

longtext

4294967295

正文

12

img_1

text

65535

主图1

13

img_2

text

65535

主图2

14

img_3

text

65535

主图3

15

img_4

text

65535

主图4

16

img_5

text

65535

主图5

17

create_time

timestamp

创建时间

18

update_time

timestamp

更新时间

19

customize_field

text

65535

自定义字段

20

source_table

varchar

255

来源表

21

source_field

varchar

255

来源字段

22

source_id

int

来源ID

23

user_id

int

添加人

表 4-12-goods_type(商品类型)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

type_id

int

商品分类ID

2

father_id

smallint

上级分类ID

3

name

varchar

255

商品名称

4

desc

varchar

255

描述

5

icon

varchar

255

图标

6

source_table

varchar

255

来源表

7

source_field

varchar

255

来源字段

8

create_time

timestamp

创建时间

9

update_time

timestamp

更新时间

表 4-13-hits(用户点击)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

hits_id

int

点赞ID

2

user_id

int

点赞人

3

create_time

timestamp

创建时间

4

update_time

timestamp

更新时间

5

source_table

varchar

255

来源表

6

source_field

varchar

255

来源字段

7

source_id

int

来源ID

表 4-14-logistics_delivery(物流配送)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

logistics_delivery_id

int

物流配送ID

2

order_number

varchar

64

订单号

3

product_name

varchar

64

商品名称

4

purchase_quantity

varchar

64

购买数量

5

total_transaction_amount

double

交易总额

6

the_date_of_issuance

date

发货日期

7

delivery_number

varchar

30

配送订单

8

ordinary_users

int

普通用户

9

shipping_address

varchar

64

收货地址

10

delivery_status

varchar

64

配送状态

11

signing_status

varchar

64

签收状态

12

recommend

int

智能推荐

13

contact_name

varchar

255

联系人名字

14

merchant_id

int

商家id

15

create_time

datetime

创建时间

16

update_time

timestamp

更新时间

表 4-15-notice(公告)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

notice_id

mediumint

公告ID

2

title

varchar

125

标题

3

content

longtext

4294967295

正文

4

create_time

timestamp

创建时间

5

update_time

timestamp

更新时间

表 4-16-order(订单)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

order_id

int

订单ID

2

order_number

varchar

64

订单号

3

goods_id

mediumint

商品ID

4

title

varchar

255

商品标题

5

img

varchar

255

商品图片

6

price

double

价格

7

price_ago

double

原价

8

num

int

数量

9

price_count

double

总价

10

norms

varchar

255

规格

11

type

varchar

64

商品分类

12

contact_name

varchar

32

联系人姓名

13

contact_email

varchar

125

联系人邮箱

14

contact_phone

varchar

11

联系人手机

15

contact_address

varchar

255

收件地址

16

postal_code

varchar

9

邮政编码

17

user_id

int

买家ID

18

merchant_id

mediumint

商家ID

19

create_time

timestamp

创建时间

20

update_time

timestamp

更新时间

21

description

varchar

255

描述

22

state

varchar

16

订单状态:待付款,待发货,待签收,已签收,待退款,已退款,已拒绝,已完成

23

remark

text

65535

订单备注

24

delivery_state

varchar

16

发货状态:未配送,已配送

25

vip_discount

double

折扣

表 4-17-praise(点赞)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

praise_id

int

点赞ID

2

user_id

int

点赞人

3

create_time

timestamp

创建时间

4

update_time

timestamp

更新时间

5

source_table

varchar

255

来源表

6

source_field

varchar

255

来源字段

7

source_id

int

来源ID

8

status

tinyint

点赞状态:1为点赞,0已取消

表 4-18-registered_user(注册用户)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

registered_user_id

int

注册用户ID

2

user_name

varchar

64

用户姓名

3

contact_information

varchar

16

联系方式

4

examine_state

varchar

16

审核状态

5

user_id

int

用户ID

6

create_time

datetime

创建时间

7

update_time

timestamp

更新时间

表 4-19-schedule(日程管理)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

schedule_id

smallint

日程ID

2

content

varchar

255

日程内容

3

scheduled_time

datetime

计划时间

4

user_id

int

用户ID

5

create_time

datetime

创建时间

6

update_time

datetime

更新时间

表 4-20-score(评分)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

score_id

int

评分ID

2

user_id

int

评分人

3

nickname

varchar

64

昵称

4

score_num

double

评分

5

create_time

timestamp

创建时间

6

update_time

timestamp

更新时间

7

source_table

varchar

255

来源表

8

source_field

varchar

255

来源字段

9

source_id

int

来源ID

表 4-21-slides(轮播图)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

slides_id

int

轮播图ID

2

title

varchar

64

标题

3

content

varchar

255

内容

4

url

varchar

255

链接

5

img

varchar

255

轮播图

6

hits

int

点击量

7

create_time

timestamp

创建时间

8

update_time

timestamp

更新时间

表 4-22-upload(文件上传)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

upload_id

int

上传ID

2

name

varchar

64

文件名

3

path

varchar

255

访问路径

4

file

varchar

255

文件路径

5

display

varchar

255

显示顺序

6

father_id

int

父级ID

7

dir

varchar

255

文件夹

8

type

varchar

32

文件类型

表 4-23-user(用户账户)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

user_id

int

用户ID

2

state

smallint

账户状态:(1可用|2异常|3已冻结|4已注销)

3

user_group

varchar

32

所在用户组

4

login_time

timestamp

上次登录时间

5

phone

varchar

11

手机号码

6

phone_state

smallint

手机认证:(0未认证|1审核中|2已认证)

7

username

varchar

16

用户名

8

nickname

varchar

16

昵称

9

password

varchar

64

密码

10

email

varchar

64

邮箱

11

email_state

smallint

邮箱认证:(0未认证|1审核中|2已认证)

12

avatar

varchar

255

头像地址

13

open_id

varchar

255

针对获取用户信息字段

14

create_time

timestamp

创建时间

表 4-24-user_group(用户组)

编号

字段名

类型

长度

是否非空

是否主键

注释

1

group_id

mediumint

用户组ID

2

display

smallint

显示顺序

3

name

varchar

16

名称

4

description

varchar

255

描述

5

source_table

varchar

255

来源表

6

source_field

varchar

255

来源字段

7

source_id

int

来源ID

8

register

smallint

注册位置

9

create_time

timestamp

创建时间

10

update_time

timestamp

更新时间

第5章
系统实现

5.1前台用户模块的实现

5.1.1用户注册界面

用户可以通过注册功能创建个人账号,填写包括用户名、密码、邮箱或手机号等基本信息完成注册流程。系统会对输入信息进行校验,确保唯一性和格式正确性,并将用户数据存储至数据库中,同时发送验证邮件或短信以确认账户有效性。用户注册界面如下图所示。

图5-1 用户注册界面

5.1.2用户登录界面

系统前台上注册后的用户是可以通过自己的账户名和密码进行登录的,当用户输入完整的自己的账户名和密码信息并点击“登录”按钮后,将会首先验证输入的有没有空数据,再次验证输入的账户名、密码和数据库中当前保存的用户信息是否一致,只有在一致后将会登录成功并自动跳转到系统的首页中;否则将会提示相应错误信息。用户登录界面如下图所示。

图5-2 用户登录界面    

5.1.3前台首页界面

首页模块旨在为用户提供一个直观且信息丰富的入口,集成了网站公告、热门美妆资讯推荐以及精选商品展示等功能。用户登录后,可以看到个性化的欢迎信息及根据其偏好推荐的商品列表,同时可以快速访问最新发布的网站公告和热门的美妆文章或视频,帮助用户了解最新的美妆趋势和促销活动。前台首页界面如下图所示。

图5-3 前台首页界面

5.1.4美妆资讯界面

美妆资讯模块专注于提供专业的美妆知识和最新的行业动态,用户可以通过该模块浏览由系统管理员发布的各类美妆文章或观看相关视频。此模块支持按照不同的分类筛选内容,并允许用户收藏感兴趣的文章以便日后查阅,从而增强用户的参与度和满意度。美妆资讯界面如下图所示。

图5-4 美妆资讯界面

5.1.5美妆商城界面

美妆商城是用户进行商品浏览和购买的主要区域,提供了强大的搜索和过滤功能,使用户能够轻松找到所需商品。每个商品页面都包含详细的产品描述、价格、用户评价等信息,方便用户做出购买决策。此外,用户可以直接将心仪的商品添加到购物车中,或者立即购买,享受便捷的一站式购物体验。美妆商城展示界面如下图所示。

图5-5 美妆商品展示界面

订单支付界面如下图所示。

图5-6 订单支付界面

5.1.6商城管理界面

商城管理模块包括我的购物车、我的订单、我的地址三个子模块,为用户提供了一套完整的购物流程管理工具。在“我的购物车”中,用户可以查看已选商品、调整数量或删除不需要的商品。我的购物车界面如下图所示。

图5-7 我的购物车界面

“我的订单”则让用户能够追踪订单状态、查看历史订单详情并进行退换货申请。我的订单界面如下图所示。

图5-8 我的订单界面

“我的地址”允许用户维护多个收货地址,设置默认地址,确保每次购物时都能准确无误地收到商品。我的地址界面如下图所示。

图5-9 我的地址界面

5.1.7个人中心界面

个人中心作为用户个性化服务的核心,提供了账户管理、订单跟踪等多项功能。用户可以在个人中心编辑个人信息、修改密码、查看收藏的商品列表,并通过直观的界面管理所有与账户相关的事务。此外,个人中心还集成了订单配送状态查询功能,使得用户可以随时掌握订单的最新动态,提升购物体验的整体满意度。用户个人中心界面如下图所示。

图5-10 用户个人中心界面

5.2后台管理模块的实现

5.2.1后台登录界面

后台登录模块为管理员提供了安全的身份验证入口,确保只有授权用户能够访问系统后台。通过输入正确的用户名和密码,并经过系统的身份验证流程,管理员可以成功登录到后台管理系统,保障了数据的安全性和系统的稳定性。后台登录界面如下图所示。

图5-11 后台登录界面

5.2.2后台首页界面

后台首页模块为管理员提供了一个全面的概览界面,集成了关键业务指标如商品销售金额统计、商品销售数量统计等图表展示功能,帮助管理员快速了解当前业务状况并据此做出决策。后台首页界面如下图所示。

图5-12 后台首页界面

5.2.3系统用户界面

系统用户模块用于管理员对注册用户和管理员账号进行统一管理,包括新增、编辑、删除用户信息以及调整用户权限状态。管理员可以通过搜索功能快速定位目标用户,模块还支持用户状态管理,确保系统的安全性与规范性。系统用户界面如下图所示。

图5-13 系统用户界面

5.2.4系统管理界面

轮播图模块为管理员提供管理首页展示内容的功能,支持上传图片、设置链接地址以及调整显示顺序。管理员可以通过该模块灵活更新平台的宣传内容,吸引更多用户关注。系统通过后端接口将数据存储至数据库,确保前端展示效果与后台配置一致。轮播图管理界面如下图所示。

图5-14 轮播图管理界面

5.2.5资源管理界面

资源管理模块主要用于管理和发布美妆资讯及分类信息,帮助管理员丰富平台内容。管理员可以创建、编辑或删除美妆资讯,并对资讯进行分类管理,确保内容组织清晰有序。资源管理界面如下图所示。

图5-15 资源管理界面

5.2.6商城管理界面

商城管理模块是管理员进行商品和订单管理的核心区域,其中“美妆商城”部分允许管理员添加新商品、更新库存信息、设定促销活动等;“分类列表”则用于管理商品分类结构,方便商品查找和展示;在“订单列表”中,管理员可以查看所有订单详情、处理发货请求;而“订单配送”功能使得管理员能够追踪物流状态,确保订单按时送达顾客手中。美妆商城管理界面如下图所示。

图5-16 美妆商城管理界面

分类列表界面如下图所示。

图5-17 分类列表界面

订单列表界面如下图所示。

图5-18 订单列表界面

订单配送界面如下图所示。

图5-19 订单配送界面

5.2.7权限管理界面

权限管理模块旨在确保不同角色只能访问与其职责相关的系统资源,管理员可以通过此模块定义各种角色及其对应的权限设置,如是否允许访问特定页面或执行某些操作。这不仅增强了系统的安全性,也提高了管理效率,避免了不必要的风险和错误。权限管理界面如下图所示。

图5-20 权限管理界面

第6章
系统测试

6.1测试目的

在对该系统进行完详细设计和编码之后,就要对美妆销售系统的程序进行测试,检测程序是否运行无误,反复进行测试和修改,使之最后成为完整的软件,满足用户的需求,实现预期的功能。系统测试的目的在于确保软件正常运作,并实现其应有的功能,促进行中出现的错误和逻辑问题。系统测试不但可以找见程序运行中的系统错误,还可以找见程序运行的需要改进的地方,并去协助改良程序运行使其获得最高幅度的完备。世界一流的安装测试员可以增加软件品质,将软件系统错误概率降至最少。

6.2测试用例

对以下功能进行测试,包括包括用户注册、用户登录、美妆商品搜索、美妆商品查看、美妆商品添加、美妆商品购买,具体测试用例如下表所示。

6-1 用户注册测试用例表

用例编号

用例名称

测试步骤

测试结果

6-1

用户注册

1. 输入有效注册信息,包括用户名、密码和联系方式。

注册成功,系统保存用户信息。

2. 点击注册按钮进行提交。

跳转至登录页面。

3. 检查是否成功注册并跳转至登录页面。

用户成功注册,可以登录使用。

6-2 用户登录测试用例表

用例编号

用例名称

测试步骤

测试结果

6-2

用户登录

1. 输入正确用户名和密码。

登录成功,系统验证通过。

2. 点击登录按钮进行验证。

跳转至用户首页。

3. 检查是否成功登录并跳转至用户首页。

用户成功登录,进入用户首页。

6-3 美妆商品搜索测试用例表

用例编号

用例名称

测试步骤

测试结果

6-3

美妆商品搜索

1. 在搜索框输入关键词,如商品名称。

显示相关商品列表。

2. 点击搜索按钮进行搜索。

匹配关键词的美妆商品显示在搜索结果中。

3. 检查是否显示相关美妆商品列表。

用户看到与搜索关键词匹配的美妆商品

6-4 美妆商品查看测试用例表

用例编号

用例名称

测试步骤

测试结果

6-3

美妆商品搜索

1. 点击美妆商品

显示所有美妆商品列表。

2. 进入详情页浏览

展示美妆商品详情页

3. 检查是否显示美妆商品是否正常展示

美妆商品展示正常

6-5 美妆商品添加测试用例表

用例编号

用例名称

测试步骤

测试结果

6-4

美妆商品添加

1. 进入后台美妆商城管理界面,点击添加按钮

显示美妆商品信息添加页面

2. 正确填写并提交相关信息

信息填写完整准确。

3. 检查是否提交成功,并检查美妆商品信息是否成功添加至平台。

美妆商品信息成功添加至平台。

6-6 美妆商品购买测试用例表

用例编号

用例名称

测试步骤

测试结果

6-4

美妆商品购买

1. 进入前台美妆商城详情页,点击购买按钮

显示美妆商品信息页面

2. 用户正确填写并提交订单相关信息

订单信息填写完整准确。

3. 检查是否提交并支付成功,并检查订单信息是否成功添加至平台。

订单信息成功添加至平台,可在个人中心-我的订单列表中查看。

6.3测试结果

经过对用户注册、用户登录、美妆商品搜索、美妆商品查看、美妆商品添加、美妆商品购买等功能的测试,系统表现稳定,用户注册流程顺畅,登录验证准确,美妆商品搜索、查看、添加功能有效,美妆商品购买信息流程顺利。各项功能符合预期,用户可以顺利注册登录,选择所需美妆商品进行浏览,可以成功发布购买美妆商品生成订单信息。系统运行良好,用户体验良好,功能完善。

  

本次美妆销售系统将Spring Boot同现实美妆销售工作进行相结合,在系统功能开始编码之前,作者花费了大量时间在图书馆内进行资料文献的收集和总结,通过大量文献的分析,能够发现,美妆商城销售的方式在当前美妆市场及销售管理中扮演的位置是越来越重要,而使用的方式也是越来越多元化,也正是因为这个原因,作者深深的希望能够开发出一种专门针对性的在线美妆销售系统,以满足不同用户的多样化需求。

基于Spring Boot的美妆销售系统设计与实现得到设计与实现,利用了目前市场上普遍使用的Java编程语言,以及MySQL数据库管理功能,和目前比较流行的Spring Boot框架进行系统界面的布置,以现实生活的美妆商城销售管理过程为标准,设计实现了包括首页、网站公告、美妆资讯、美妆商城、商城管理等模块,为用户提供多元前面的功能操作,基本实现整个美妆商品销售管理流程。

但是由于本人受到了技术水平的限制,在有限的时间,只能够将系统功能模拟时的功能实现,在许多功能方面仍然存在很大的弊端,而这些弊端需要不断的测试,不断的总结,不断的改进。例如本次系统设计中,在数据储存的方面并不够全面,很容易出现信息泄露的风险;例如针对用户权限的设置同样不够全面完整,没有考虑权限在实际情况的运用是否能够完美执行。而在这之后的日子里,我将会继续学习Spring Boot技术和相关的信息技术,对系统功能进行更加完整的,详细的分析,将系统功能一一进行完善,帮助使用者完成相应的操作。

参考文献

  1. 陈敬宗.计算机软件Java编程特点与技术应用分析[J].中国信息界,2025,(01):162-164.
  2. 柯灵.Java编程语言在计算机软件开发中的应用与问题处理探析[J].电脑知识与技术,2024,20(27):45-47.
  3. 王志亮,纪松波.基于SpringBoot的Web前端与数据库的接口设计[J].工业控制计算机,2023,36(03):51-53.
  4. 李兴华,马云涛.Spring开发实战[M].人民邮电出版社:202303.381.
  5. 李艳杰.MySQL数据库下存储过程的综合运用研究[J].现代信息科技,2023,7(11):80-82+88.
  6. 肖睿,李鲲程,范效亮,等.MySQL数据库应用技术及实践[M].人民邮电出版社:202206.228.
  7. 黄维.基于B/S模式的虚拟网络实验室安全管理体系分析[J].信息系统工程,2024,(05):4-7.
  8. 张宇薇.HTML5在Web前端开发中的应用[J].集成电路应用,2024,41(04):274-276.
  9. Miaoling J .Impact of Douyin Beauty Brand Live Streaming on Consumers’ Purchase Intentions[J].Scientific and Social Research,2024,6(11):37-42.
  10. Pei P .Empathy Expression in Beauty Teaching Short Videos from Bilibili during Group Communication Era from the Perspective of Role Theory[J].Arts Studies and Criticism,2024,5(5):
  11. 王培培.基于SpringBoot的网上商城管理系统设计与实现[J].现代计算机,2024,30(07):117-120.
  12. 张柱,宋存进,蒋乐,等.基于微信小程序校园美妆商城设计与实现设计与开发[J].电脑编程技巧与维护,2022,(12):59-61+142.
  13. 陈小燕,朱映辉,余晓春.基于SpringBoot+Vue的好农物商城的设计与实现[J].电脑知识与技术,2022,18(22):37-39.
  14. 苏珊珊.小红书平台美妆KOL的传播策略研究[D].华侨大学,2023.000589.
  15. 曹利军,段语嫣.互联网平台企业的动态隔离要素研究——基于“京东商城”的经验分析与实证[J].时代经贸,2024,21(07):111-119.
  16. 滕兴才.中国美妆闪耀巴黎——中国化妆品企业在国际化妆品创新匹亚大赛上斩获多项创新大奖[J].中国化妆品,2024,(06):12-14.
  17. 林海.美妆品销售管理中存在的问题分析及解决对策[J].现代商业,2024,(22):116-119.
  18. 苏悦怡.《中国化妆品》杂志社与法国化妆品谷深化合作共绘中法美妆产业新蓝图[J].中国化妆品,2024,(06):16-17.
  19. 贾志勇.基于SpringBoot的下沉市场交易平台的设计与实现[D].安徽大学,2020.000917.
  20. 曹艳琴.基于微信公众平台的美妆商城小程序的设计与实现[J].信息与电脑(理论版),2021,33(05):121-123.


致  谢

时光荏苒,大学的学业生涯即将画上美好的句号。在这段时光里,我深感老师的热情与友谊,校长对学生的关爱深深印在我的心中。老师们时常关心我们的生活状况,关切我们的旅游、寝室和学习环境,使我们感受到了温馨与关怀。在此,我想表达对那些曾经给予我帮助的人们的深深感激之情。

首先,我要衷心感谢我的导师。无论是在学业上还是生活中,您都给予我巨大的支持与启发。这些年来,在您的教导下,我不仅学到了丰富的知识,还领悟了做人的真谛。您的认真和待人之道让我受益匪浅,我感激能够成为您的学生。

同时,感谢我的专业课老师们。没有你们的精心教导,我的论文也不可能如此顺利。我所学到的知识将成为我未来发展的重要动力。

感谢同学们,写作过程中遇到的问题,得到了同学们的耐心指导和丰富参考材料。你们给予了我很多帮助,感谢你们对我的支持。

最后,感谢我的父母,是你们的支持和鼓励让我能够顺利完成学业。你们为我付出了辛勤的努力和无私的关爱,是我坚强前行的后盾。在即将离开校园,我深感家庭的温馨和爱意,这些将是我未来奋斗的力量源泉。

感谢你们一直以来的支持和陪伴,让我在大学的日子里无论遇到什么困难都感到温馨而坚定。未来,我将以更加饱满的热情投入社会工作,为家人和自己创造更美好的未来。再次感谢大家的陪伴与关爱!

整理归纳不易,点赞❤关注+私信博主,免费领取项目源码,谢谢


附 录

系统关键代码

登录代码如下:

  /**

     * 登录

     * @param data

     * @param httpServletRequest

     * @return

     */

    @PostMapping("login")

    public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {

        log.info("[执行登录接口]");

        String username = data.get("username");

        String email = data.get("email");

        String phone = data.get("phone");

        String password = data.get("password");

        List resultList = null;

        Map<String, String> map = new HashMap<>();

        if(username != null && "".equals(username) == false){

            map.put("username", username);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(email != null && "".equals(email) == false){

            map.put("email", email);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(phone != null && "".equals(phone) == false){

            map.put("phone", phone);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }else{

            return error(30000, "账号或密码不能为空");

        }

        if (resultList == null || password == null) {

            return error(30000, "账号或密码不能为空");

        }

        //判断是否有这个用户

        if (resultList.size()<=0){

            return error(30000,"用户不存在");

        }

        User byUsername = (User) resultList.get(0);

        Map<String, String> groupMap = new HashMap<>();

        groupMap.put("name",byUsername.getUserGroup());

        List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));

        if (groupList.size()<1){

            return error(30000,"用户组不存在");

        }

        UserGroup userGroup = (UserGroup) groupList.get(0);

        //查询用户审核状态

        if (!StringUtils.isEmpty(userGroup.getSourceTable())){

            String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());

            if (res==null){

                return error(30000,"用户不存在");

            }

            if (!res.equals("已通过")){

                return error(30000,"该用户审核未通过");

            }

        }

        //查询用户状态

        if (byUsername.getState()!=1){

            return error(30000,"用户非可用状态,不能登录");

        }

        String md5password = service.encryption(password);

        if (byUsername.getPassword().equals(md5password)) {

            // 存储Token到数据库

            AccessToken accessToken = new AccessToken();

            accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));

            accessToken.setUser_id(byUsername.getUserId());

            Duration duration = Duration.ofSeconds(7200L);

            redisTemplate.opsForValue().set(accessToken.getToken(), accessToken,duration);

            // 返回用户信息

            JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));

            user.put("token", accessToken.getToken());

            JSONObject ret = new JSONObject();

            ret.put("obj",user);

            return success(ret);

        } else {

            return error(30000, "账号或密码不正确");

        }

    }

注册代码如下:

      /**

     * 注册

     * @param user

     * @return

     */

    @PostMapping("register")

    public Map<String, Object> signUp(@RequestBody User user) {

        // 查询用户

        Map<String, String> query = new HashMap<>();

        Map<String,Object> map = JSON.parseObject(JSON.toJSONString(user));

        query.put("username",user.getUsername());

        List list = service.selectBaseList(service.select(query, new HashMap<>()));

        if (list.size()>0){

            return error(30000, "用户已存在");

        }

        map.put("password",service.encryption(String.valueOf(map.get("password"))));

        service.insert(map);

        return success(1);

}  

找回密码代码如下:

 /**

     * 找回密码

     * @param form

     * @return

     */

    @PostMapping("forget_password")

    public Map<String, Object> forgetPassword(@RequestBody User form,HttpServletRequest request) {

        JSONObject ret = new JSONObject();

        String username = form.getUsername();

        String code = form.getCode();

        String password = form.getPassword();

        // 判断条件

        if(code == null || code.length() == 0){

            return error(30000, "验证码不能为空");

        }

        if(username == null || username.length() == 0){

            return error(30000, "用户名不能为空");

        }

        if(password == null || password.length() == 0){

            return error(30000, "密码不能为空");

        }

        // 查询用户

        Map<String, String> query = new HashMap<>();

        query.put("username",username);

        List list = service.selectBaseList(service.select(query, service.readConfig(request)));

        if (list.size() > 0) {

            User o = (User) list.get(0);

            JSONObject query2 = new JSONObject();

            JSONObject form2 = new JSONObject();

            // 修改用户密码

            query2.put("user_id",o.getUserId());

            form2.put("password",service.encryption(password));

            service.update(query, service.readConfig(request), form2);

            return success(1);

        }

        return error(70000,"用户不存在");

    }

修改密码代码如下:

 /**

     * 修改密码

     * @param data

     * @param request

     * @return

     */

    @PostMapping("change_password")

    public Map<String, Object> change_password(@RequestBody Map<String, String> data, HttpServletRequest request){

        // 根据Token获取UserId

        String token = request.getHeader("x-auth-token");

        Integer userId = tokenGetUserId(token);

        // 根据UserId和旧密码获取用户

        Map<String, String> query = new HashMap<>();

        String o_password = data.get("o_password");

        query.put("user_id" ,String.valueOf(userId));

        query.put("password" ,service.encryption(o_password));

        int count = service.selectBaseCount(service.count(query, service.readConfig(request)));

        if(count > 0){

            // 修改密码

            Map<String,Object> form = new HashMap<>();

            form.put("password",service.encryption(data.get("password")));

            service.update(query,service.readConfig(request),form);

            return success(1);

        }

        return error(10000,"密码修改失败!");

    }

增删查改代码如下:

 @PostMapping("/add")

    @Transactional

    public Map<String, Object> add(HttpServletRequest request) throws IOException {

        service.insert(service.readBody(request.getReader()));

        return success(1);

    }

public Map<String, Object> addMap(Map<String,Object> map){

    service.insert(map);

     return success(1);

 }

 @RequestMapping(value = "/del")

    @Transactional

    public Map<String, Object> del(HttpServletRequest request) {

        service.delete(service.readQuery(request), service.readConfig(request));

        return success(1);

    }

    public void delete(Map<String,String> query,Map<String,String> config){

        QueryWrapper wrapper = new QueryWrapper<E>();

        toWhereWrapper(query, "0".equals(config.get(FindConfig.GROUP_BY)),wrapper);

        baseMapper.delete(wrapper);

        log.info("[{}] - 删除操作:{}",wrapper.getSqlSelect());

    }

    @PostMapping("/set")

@Transactional

    public Map<String, Object> set(HttpServletRequest request) throws IOException {

        service.update(service.readQuery(request), service.readConfig(request), service.readBody(request.getReader()));

        return success(1);

    }

图片/文件/视频等的上传方法通过MultipartFile,代码如下:

   @PostMapping("/upload")

    public Map<String, Object> upload(@RequestParam("file") MultipartFile file) {

        log.info("进入方法");

        if (file.isEmpty()) {

            return error(30000, "没有选择文件");

        }

        try {

            //判断有没路径,没有则创建

            String filePath = System.getProperty("user.dir") + "/src/main/resources/static/";

            File targetDir = new File(filePath);

            if (!targetDir.exists() && !targetDir.isDirectory()) {

                if (targetDir.mkdirs()) {

                    log.info("创建目录成功");

                } else {

                    log.error("创建目录失败");

                }

            }

            String fileName = file.getOriginalFilename();

            File dest = new File(filePath + fileName);

            log.info("文件路径:{}", dest.getPath());

            log.info("文件名:{}", dest.getName());

            file.transferTo(dest);

            JSONObject jsonObject = new JSONObject();

            jsonObject.put("url", "/api/upload/" + fileName);

            return success(jsonObject);

        } catch (IOException e) {

            log.info("上传失败:{}", e.getMessage());

        }

        return error(30000, "上传失败");

    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值