六年专注于网络推广、网络营销研究

作者:淘小白2020-9-2 10:51分类: SEO知识

昨天和一个培训机构的朋友吃饭,他在培训机构已经当老师三年,是某鸟的。



当天回去后,发我一个他们教学的电商系统,我看了下这个系统,感觉真的一般般。



而他们的收费是两万,简直太坑了。今天孟哥推荐个电商系统,技术层面比他2万的要好的多。




源码获取见文章底部。



















基于SOA架构的分布式购物电商商城
  • 后台管理系统:管理商品、订单、类目、商品规格属性、用户、权限、系统统计、系统日志以及前台内容等功能
  • 前台系统:用户可以在前台系统中进行注册、登录、浏览商品、首页、下单等操作
  • 会员系统:用户可以在该系统中查询已下的订单、管理订单、我的优惠券等信息
  • 订单系统:提供下单、查询订单、修改订单状态、定时处理订单
  • 搜索系统:提供商品的搜索功能
  • 单点登录系统:为多个系统之间提供用户登录凭证以及查询登录用户的信息



前端所用技术
  • 后台页面
    • 感谢 H-ui、FlatLab 提供静态页面支持
    • Ztree:jQuery树插件
    • DataTables:jQuery表格插件
    • Layer:web弹层组件
    • Distpicker:中国省市区地址三级联动插件
    • KindEditor:富文本编辑器 简洁方便 没UEditor那么多坑
    • WebUploader:百度文件上传插件
    • HighCharts:图表库
    • 不蒜子:极简网页计数器
  • 前台页面
    • 详情请跳转至 xmall-front 项目仓库
    • 感谢 yucccc 的开源 vue-mall 项目提供前端页面及框架支持
    • Vue2 + Vuex + Vue Router + Element UI + ES6 + webpack + axios + Node.js
后端所用技术各框架依赖版本皆使用目前最新版本 可进入xmall-parent中 pom.xml 查看
  • Spring
  • SpringMVC
  • MyBatis
  • Dubbo
  • ZooKeeper
  • MySQL
  • Mycat:数据库分库分表中间件
  • Redis:缓存
  • Elasticsearch:基于Lucene分布式搜索引擎
  • ActiveMQ:消息队列
  • Druid:阿里高性能数据库连接池
  • Shiro:安全框架
  • Swagger2:Api文档生成
  • Docker
  • Nginx
  • Tomcat
  • Maven
  • 第三方SDK
    • 七牛云文件存储服务
    • 极验Test-button人机验证码 因其收费见极验验证码移除文档
  • 第三方插件
    • hotjar:一体化分析和反馈
    • 搜狐畅言评论插件
  • 第三方接口
    • Mob全国天气预报接口:需注册账号创建应用后申请填入AppKey
  • 其它开发工具
    • Jenkins:持续集成
    • JRebel:开发热更新
    • 阿里JAVA开发规约插件
文件说明
  • xmall 文件夹提供部分依赖与sql文件
    • xmall.sql:数据库文件
    • dubbo.xsd:需手动配置避免报错
    • redis-3.0.0.gem:Redis集群搭建所需Ruby库
  • generatorSqlmapCustom 文件夹为 Mybatis Generator 逆向生成工具,且已配置好Maven插件
本地开发运行部署
  • 下载zip直接解压或安装git后执行克隆命令 git clone https://github.com/Exrick/xmall.git
  • 安装各中间件并启动:ZooKeeper、Redis、ActiveMQ、Elasticsearch
  • 修改各配置文件相应依赖IP配置(默认本地127.0.0.1),以及七牛云、极验配置、天气接口在 xmall-common - utils 中找到修改,XPay邮箱配置在 manager-service与sso-service 中
  • Maven安装和在IDEA中配置
  • 使用IDEA(破解/免费注册) File-Open 直接打开xmall项目,点击右下角 Import Changes 等待安装完依赖即可
  • MySQL数据库新建 xmall 数据库,运行sql文件,注意在有 db.properties 的模块中修改你的数据库连接配置
  • 按照依赖顺序分别在每个模块文件夹根目录执行 mvn install 命令
  • 项目需运行除 xmall-parent xmall-common 以外其它所有6个服务,且都已配置好Tomcat插件, 执行命令 mvn tomcat7:run 或在IDEA中使用插件(View - Tool Buttons - 右侧菜单Maven Projects - tomcat7 - tomcat7:run)运行即可,当然可自行配置
  • 后端管理系统默认端口8888 http://localhost:8888 管理员账密admin|123456
  • 前端项目接口默认端口7777 前台页面请启动基于Vue的 xmall-front 项目,并修改其接口配置
相关技术点说明
  • ES-IK分词插件词典库扩展<?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">
    <properties>
    <comment>IK Analyzer 扩展配置</comment>
    <!--用户可以在这里配置远程扩展字典 -->
    <entry key="remote_ext_dict">http://localhost:8888/getDictList</entry>
    <!--用户可以在这里配置远程扩展停止词字典-->
    <entry key="remote_ext_stopwords">http://localhost:8888/getStopDictList</entry>
    </properties>
    • 详见 elasticsearch-analysis-ik插件作者项目README说明
    • 本项目中扩展接口和禁用词接口分别为 http://localhost:8888/getDictList 和 http://localhost:8888/getStopDictList,将以上2个接口配置进IK插件扩展配置文件{conf}/analysis-ik/config/IKAnalyzer.cfg.xml 或者 {plugins}/elasticsearch-analysis-ik-*/config/IKAnalyzer.cfg.xml中即可,示例:
  • 限流
    • xmall-front-web 中已配置限流,配置文件 resource.properties 中可配置全局限流,示例:#启用全局限流
      xmall.rateLimit.enable=true
      #每1秒内
      xmall.rateLimit.timeout=1000
      #限制10个请求
      xmall.rateLimit.limit=10
    • 指定方法限流注解@RateLimiter(limit = 1, timeout = 5000)
    • 支持多维度IP、uid等限流 详见代码



关注我,助你早日全栈工程师、架构师。


转发+评论,然后私信我:高端商城源码

温馨提示如有转载或引用以上内容之必要,敬请将本文链接作为出处标注,谢谢合作!

已有 0/35 人参与

发表评论:



微信扫一扫,加我好友