【Lilishop商城】No3-7.模块详细设计,订单模块-1(购物车、收银台)的详细设计

2023-12-09 10:20

本文主要是介绍【Lilishop商城】No3-7.模块详细设计,订单模块-1(购物车、收银台)的详细设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   仅涉及后端,全部目录看顶部专栏,代码、文档、接口路径在: 

【Lilishop商城】记录一下B2B2C商城系统学习笔记~_清晨敲代码的博客-CSDN博客


全篇会结合业务介绍重点设计逻辑,其中重点包括接口类、业务类,具体的结合源代码分析,读起来也不复杂~

谨慎:源代码中有一些注释是错误的,有的注释意思完全相反,有的注释对不上号,我在阅读过程中就顺手更新了,并且在我不会的地方添加了新的注释,所以在读源代码过程中一定要谨慎啊!

目录

A1.购物车

B1.B端(属于显式操作) 

A2.收银台

B1. 订单选择第三方支付简单流程

B2. 订单支付简单业务逻辑调用

B3. B端(属于显式操作)

B4. M端(属于显式操作)


购物车属于买方B端的操作,是属于平台前台的,本来想说平台前台放在最后的,但是因为这里是业务中不可缺少的一环,所以按照正常的业务流程先设计这里~

A1.购物车

先说一下业务逻辑,从浏览商品sku到生成订单,有1.在浏览商品sku时立即购买;2.加入购物车,在购物车里面购买;第一种方式也能变相理解为加入购物车再购买。

在shop项目里面是将这两种方式添加到了购物车接口里面,并且通过类型区分,如果是立即购买就走立即购买的逻辑,如果是购物车购买就走购物车购买的逻辑;

随着上方的业务逻辑,当在B端购物车每添加一个商品SKU就会更新一下购物车列表,并存在redis缓存里面(不同类型的分开来缓存)。其中也会有一些别的逻辑,例如计算已勾选商品sku的总金额、计算优惠券等等。相当于提前进行操作,下次进入购物车时就不用计算了。

所以购物车信息是存在redis里面的,里面涉及到的业务逻辑复杂(各种处理,促销、优惠券、商品检验等等),后面开发时再讲解这一块儿~ 

B1.B端(属于显式操作) 

创建交易接口这里,会直接创建交易单、订单、子订单,然后等待付款,付款的就是在收银台~

  • 向购物车中添加一个商品sku、获取购物车页面购物车详情、获取购物车数量
  • 更新购物车中单个产品数量、更新购物车中单个产品是否被选中、更新购物车中所有产品是否被选中、更新购物车中某商家的商品为选中或不选中
  • 清空购物车、删除购物车中的一个或多个产品
  • 获取结算页面购物车详情、切换收货地址、编辑发票信息、选择优惠券
  • 创建交易

 

A2.收银台

收银台这里一方面涉及到了运营的收银配置,另一方面又涉及到了第三方支付方式

(支付方式应该算在架构里面的,后面在No2架构里面详细学习记录一下,这里先了解一下支付方式,具体的先不在这儿描述了)。

开始前需要先了解支付业务逻辑 ~

【支付这里会用到第三方支付,然后会与余额支付整合,所以需要先了解要使用的第三方支付工具是,一般来说都会是用支付宝、微信等,这些流程都相似~】

B1. 订单选择第三方支付简单流程

就不详细描述了,图挺清楚的,也可以看shop的流程

B2. 订单支付简单业务逻辑调用

这里先简单描述,后面再详细记录~ 

B3. B端(属于显式操作)

买方B端直接进行支付

  • 获取支付详情、获取某种支付方式的支付详情、支付回调、支付异步通知、查询支付结果

B4. M端(属于显式操作)

运营M端可以控制下线支付,在订单里面进行控制,这里就不说了,放到订单里面再说明~

这篇关于【Lilishop商城】No3-7.模块详细设计,订单模块-1(购物车、收银台)的详细设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/473429

相关文章

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的

Python3.6连接MySQL的详细步骤

《Python3.6连接MySQL的详细步骤》在现代Web开发和数据处理中,Python与数据库的交互是必不可少的一部分,MySQL作为最流行的开源关系型数据库管理系统之一,与Python的结合可以实... 目录环境准备安装python 3.6安装mysql安装pymysql库连接到MySQL建立连接执行S

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生