推荐一款优秀电商开源项目

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 推荐一款优秀电商开源项目

image.png

一、简介

本文给大家推荐博主自己开源的电商项目newbee-mall-pro。在newbee-mall项目的基础上搭建而来, 使用 mybatis-plus 作为 orm 层框架,并添加了一系列高级功能以及代码优化并且已经升级至 Spring Boot3.0,项目功能特性如下:

  1. 商城首页 【为你推荐】 栏目添加协同过滤算法。按照 UserCF 基于用户的协同过滤、ItemCF 基于物品的协同过滤,实现了两种不同的推荐逻辑。
  2. RedisSearch:支持中文分词搜索,支持商品名称、简介、标签作为搜索项,以及新品、价格排序。

RediSearch 是一个源码可用的 Redis 模块,可以对 Redis 进行查询、二级索引和全文搜索。这些功能支持在文本查询之上进行多字段查询、聚合、精确短语匹配、数字过滤、地理过滤和矢量相似性语义搜索。

  1. 秒杀专区:支持功能完备,生产可用的高级秒杀功能。
  2. 优惠卷专区:支持优惠卷后台配置、用户注册赠卷、下单页面优惠卷使用等功能。
  3. 商城首页支持使用滑块验证码登录。
  4. 支付时集成了支付宝沙箱支付,可以在开发环境体验支付宝支付效果。
  5. 集成 Pace 页面,添加网页进度条,页面跳转美化。
  6. 添加 Spring 事件监听机制,异步解耦下单流程。
  7. 集成spring-session-redis,支持分布式部署。
  8. 集成mybatis-xmlreload,支持xml文件热加载。

newbee-mall-pro 项目地址:


二、特性简介

2.1 推荐算法

商城首页  【为你推荐】  栏目添加协同过滤算法。按照UserCF基于用户的协同过滤、ItemCF基于物品的协同过滤。 实现了两种不同的推荐逻辑。

  • UserCF:基于用户的协同过滤。当一个用户A需要个性化推荐的时候,我们可以先找到和他有相似兴趣的其他用户,然后把那些用户喜欢的,而用户A没有听说过的物品推荐给A。

image.png

  • 假设用户 A 喜欢物品 A、物品 C,用户 B 喜欢物品 B,用户 C 喜欢物品 A 、物品 C 和物品 D;从这些用户的历史喜好信息中,我们可以发现用户 A 和用户 C 的口味和偏好是比较类似的,同时用户 C 还喜欢物品 D,那么我们可以推断用户 A 可能也喜欢物品 D,因此可以将物品 D 推荐给用户 A。 具体代码在 ltd.newbee.mall.recommend.core.UserCF 中。
  • itemCF:基于物品的协同过滤。预先根据所以用户的历史偏好数据计算物品之间的相似度,然后把与用户喜欢的物品相类似的物品推荐给用户。

image.png

  • 假如用户A喜欢物品A和物品C,用户B喜欢物品A、物品B和物品C,用户C喜欢物品A,从这些用户的历史喜好中可以认为物品A与物品C比较类似,喜欢物品A的都喜欢物品C,基于这个判断用户C可能也喜欢物品C,所以推荐系统将物品C推荐给用户C。 具体代码在 ltd.newbee.mall.recommend.core.ItemCF 中。

2.2 中文分词

商城添加RedisSearch搜索,支持中文分词搜索,推荐、新品、价格排序搜索

  1. 添加RedisSearch测试用例
  2. 后台添加RedisSearch同步按钮
  3. 商城支持RedisSearch中文分词搜索

2.3 依赖集成、升级

  1. 集成tianai-captcha滑块验证码,支持后端验证码校验
  2. image.png
  3. 添加 Spring 事件监听机制,解耦下单流程,将下单流程拆解为订单校验、生成订单号、发送事件异步保存订单流程
  1. 集成spring-session-redis,支持分布式部署

2.3 秒杀专区

秒杀功能如下:

  • 秒杀页面静态化
  • 添加了秒杀接口限流,基于springAOP实现
  • 添加了秒杀接口防止重复提交,基于spring拦截器实现
  • 使用令牌桶算法过滤用户请求
  • 使用redis-set数据结构判断用户是否买过秒杀商品
  • 使用redis配合lua脚本进行原子自减,判断商品缓存库存是否大于0
  • 获取商品缓存,判断秒杀商品是否再有效期内
  • 执行存储过程(减库存 + 记录购买行为)
  • 使用redis-set数据结构记录购买过的用户
  • 返回用户秒杀成功VO
  • 下单后启用秒杀订单5分钟未支付超期任务
  • 订单5分钟内未支付则自动取消订单并回退库存

image.png

image.png

image.png

image.png

秒杀专区为用户展示了后台设置的秒杀商品,在秒杀有效期内可以进行商品秒杀操作。


三、在线截图

image.png

image.png

image.png

总结

欢迎大家参与使用newbee-mall-pro项目,使用中遇到问题欢迎大家提出。我都会一一查看并回复。再附newbee-mall-pro项目地址:

最后再说一句,感兴趣的朋友可以点赞加关注,你的支持将是我更新动力😘。

本文正在参加「金石计划」



相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
打赏
0
0
0
0
10
分享
相关文章
电商4.0项目【二】: 架构搭建
电商4.0项目【二】: 架构搭建
82 0
【电商新机遇】支付宝小程序如何助你打造爆款电商解决方案?揭秘背后的技术奥秘!
【8月更文挑战第27天】本文详细介绍如何利用支付宝小程序构建电商应用,覆盖从项目初始化、页面设计、功能开发到数据分析的全流程。首先,需注册开发者账号并安装相关工具;随后创建项目,并按示例配置基本页面结构;接着设计商品列表等界面布局;再实现商品展示等功能;最后运用支付宝提供的工具进行数据分析,以优化用户体验及营销策略。跟随本教程,您将能打造出一款完整的电商小程序。
113 1
2023云栖陈守元,阿里云开源大数据产品年度发布
阿里云计算平台事业部开源大数据产品总监陈守元围绕EMR、Flink Streaming Lakehouse、 Elasticsearch、Milvus等产品发布展开分享介绍。
493 3
京东JDAPI:电商行业的得力助手
在当今电商行业中,数据的获取与利用显得尤为重要。作为中国领先的电商平台,京东提供了丰富的API接口,其中JD商品详情API是关键之一,它允许第三方开发者获取京东平台上的商品详情信息。本文将深入探讨京东JD商品详情API在电商行业中的重要性,以及如何通过该API实现实时数据获取。
电商小白想入门电商运营,应该先学什么?
电商行业激动人心且充满机遇,如今越来越多的人想要进入这个领域,成为一个成功的电商运营者。然而,作为一个电商小白,你可能不知道从何处开始学习。在这篇文章中,我将为你提供一些建议,帮助你入门电商运营。
开发搭建体育直播赛事平台,三个核心要素
开发并搭建一套完整的体育直播赛事平台并非易事。本文将重点探讨三个核心要素,以帮助您更好地了解这个领域。
阿里云开源大数据产品年度发布
阿里云开源大数据一直坚持兼容并蓄,百花齐放的产品理念,面向大数据的未来进行投资和发展。今年开源大数据E-MapReduce、Flink、Elasticsearch 等产品矩阵再次升级,向着开放化、现代化、智能化和云原生的高质量发展迈进。
阿里云开源大数据产品年度发布
电商/直播从业者、开发者,好消息来啦
电商、直播行业光速发展,阿里云企航专属云上园区逐渐开放
459 0
电商/直播从业者、开发者,好消息来啦
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等