谷粒商城笔记+踩坑(1)——架构、项目环境搭建、代码生成器

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 项目介绍、项目环境搭建、docker配置mysql,redis,jdk,maven、人人开源、快速开发、安装nodejs、逆向工程搭建,人人开源代码生成器

  导航:

谷粒商城笔记+踩坑汇总篇_谷粒商城笔记踩坑6_vincewm的博客-CSDN博客

Java笔记汇总:

【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析-CSDN博客

目录

1、项目介绍

1.1 微服务架构图

1.2. 微服务划分图

2、项目环境搭建

2.1. 虚拟机搭建环境

2.2. Linux安装docker、配置镜像加速

2.3. docker配置mysql、设置自启动

2.3.1、安装mysql5.7

2.3.2、修改mysql配置文件

2.4. docker配置redis并设置持久化

2.5. jdk、maven镜像、idea插件

2.6. vscode的安装、插件、配置

2.6.1、安装vscode和插件

2.6.3、 禁止运行项目后自动打开浏览器

2.7. 初始化项目架构、创建仓库并提交GitHub

2.7.1、码云创建Maven仓库,git克隆父工程

2.7.2、新建子模块、

2.7.3、过滤上传git的垃圾文件

2.7.4、右键项目提交

2.7.5、创建仓库并推送GitHub

2.8. 导入MySQL数据库表

3、快速开发

3.1. “人人开源”,快速构建后台管理系统

3.1.1、克隆人人开源fast项目

3.1.2、删掉两个文件夹里的.git文件夹

3.1.3、把renren-fast复制到子模块,并加入父工程

3.1.4、renren-fast的pom修改

3.1.5、创建后台管理系统的数据库gulimall_admin

3.1.6、修改renren-fast的配置文件,设置数据库

3.1.7、启动和访问

3.1.8、node.js运行前端项目

3.2. product模块的逆向工程搭建,人人开源代码生成器

3.2.1、克隆renren-generator

3.2.2、删除.git文件并导入到父工程中

3.2.3、修改生成器模块的pom

3.2.4、修改生成器模块配置文件的数据库信息

3.2.5、修改生成信息generator.properties

3.2.6、controller模板中去掉@RequiresPermissions注解

3.2.7、运行项目并生成代码

3.2.8、解压生成代码并复制到guli-product

3.2.9、新建common模块,解决生成代码报错问题

3.2.10、结果类R使用方式

3.2.11、配置yml和添加mysql依赖,测试CRUD

3.3 其他模块的逆向工程搭建,人人开源

3.3.6、各模块创建yml,设置端口号

3.3.1、修改生成器properties和yml,生成coupon模块代码

3.3.2、复制粘贴生成代码,引入common模块依赖

3.3.3、创建yml,删除resources的src文件夹

3.3.4、运行测试

3.3.5、同方法生成gulimall-member/gulimall-order/gulimall-ware的代码


1、项目介绍

1.1 微服务架构图

image.gif

1.2. 微服务划分图

image.gif

2、项目环境搭建

2.1. 虚拟机搭建环境

虚拟机VMware、centos7.

2.2. Linux安装docker、配置镜像加速

0.查看是否安装docker:

docker
image.gif

卸载之前的docker

# 1. 卸载之前的docker
 sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine
image.gif

1.需要的安装包

# 2.需要的安装包
yum install -y yum-utils

image.gif

2.设置镜像的仓库

# 3.设置镜像的仓库
# 推荐使用国内的
yum-config-manager \
    --add-repo \
    https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# 默认是从国外的,不推荐
# yum-config-manager \
#     --add-repo \
#     https://download.docker.com/linux/centos/docker-ce.repo

image.gif

3.更新yum软件包索引

# 更新yum软件包索引
yum makecache

image.gif

4.安装docker相关的 docker-ce 社区版 而ee是企业版

# 4.安装docker相关的 docker-ce 社区版 而ee是企业版
yum install docker-ce docker-ce-cli containerd.io

image.gif

5、启动docker

# 5、启动docker
docker systemctl start docker

image.gif

6. 使用docker version查看是否按照成功

# 6. 使用docker version查看是否按照成功
docker version

image.gif

docker详解:SpringCloud基础3——Docker_vincewm的博客-CSDN博客

配置阿里云镜像加速

因为docker hub是国外网站,需要配置国内镜像进行加速。

1、登录阿里云找到容器服务

image.gif

2、找到镜像加速器

image.gif

3、配置使用,输入到ssh回车

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://2lxyghvy.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

image.gif

2.3. docker配置mysql、设置自启动

2.3.1、安装mysql5.7

docker pull mysql:5.7.25
# 运行容器
sudo docker run -p 3306:3306 --name mysql01 \
-v /mydata/mysql/log:/var/log/mysql \
-v /mydata/mysql/data:/var/lib/mysql \
-v /mydata/mysql/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=1234 \
-d mysql:5.7.25
# 参数说明 -p 3312:3306 将容器的3306端口映射到主机的3312端口
# -v 宿主机文件目录:容器内目录  将容器内文件挂载到宿主机上
# -e MYSQL_ROOT_PASSWORD=root 设置mysql密码为root
# -d 后台启动
# --name 给启动容器起名字
# 使用docker ps 查看启动的容器

image.gif

2.3.2、修改mysql配置文件

# 进入配置文件挂载的目录下
cd /mydata/mysql/conf
# 配置文件my.cnf
vim my.cnf

image.gif

主要修改编码为utf8

# 新增配置文件内容
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
init_connect='SET collation_connection = utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
skip-name-resolve

image.gif

# 修改配置文件之后,重启容器
docker restart mysql01

image.gif

设置自启动:

docker update mysql01 --restart=always

image.gif

2.4. docker配置redis并设置持久化

如果直接挂载的话docker会以为挂载的是一个目录,所以我们先创建一个文件然后再挂载,在虚拟机中。

# 1、创建配置文件
mkdir -p /mydata/redis/conf
touch /mydata/redis/conf/redis.conf

image.gif

# 2、下载镜像
docker pull redis

image.gif

# 3、启动容器
docker run -p 6379:6379 --name redis \
-v /mydata/redis/data:/data  \
-v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf \
-d redis redis-server /etc/redis/redis.conf

image.gif

# 4、进入redis客户端
docker exec -it redis redis-cli

image.gif

修改redis配置文件

vi /mydata/redis/conf/redis.conf

image.gif

aof持久化方式、或设置密码,如果配置后无法打开redis,尝试删除注释

appendonly yes
#requirepass xxxxxx # 配置redis密码

image.gif

# 保存
docker restart redis
# 进入redis客户端
docker exec -it redis redis-cli
#auth xxxxxx #如果有设置密码

image.gif

回顾aof和rdb持久化方式:

SpringCloud基础7——Redis分布式缓存_vincewm的博客-CSDN博客

设置redis容器在docker启动的时候启动

docker update redis --restart=always

image.gif

安装redis-desktop-manager-0.8.8.384并连接

image.gif

2.5. jdk、maven镜像、idea插件

首先安装jdk11、maven

java -version
mvn -version

image.gif

maven3.6.1下载:

https://maven.apache.org/download.cgi

image.gif

image.gif

在/usr/local/ 下上传:

cd /usr/local/

image.gif

解压:

tar -zxvf apache-maven-3.6.1-bin.tar.gz

image.gif

配置maven的阿里云镜像、jdk11

cd apache-maven-3.6.1   #进入apache-maven-3.6.1目录
mkdir ck    #创建ck目录
cd conf            # 进入conf目录
vi settings.xm # settings.xm文件

image.gif

修改对应标签:

<mirrors> 
  <mirror>
  <id>nexus-aliyun</id>
  <mirrorOf>central</mirrorOf>
  <name>Nexus aliyun</name>
  <url>http://maven.aliyun.com/nexus/content/groups/public</url>
  </mirror>
  </mirrors>
 <profiles>
    <id>jdk-11</id>
    <activation>
        <activeByDefault>true</activeByDefault>
        <jdk>11</jdk>
    </activation>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
        <maven.compiler.compilerVersion>11</maven.compiler.compilerVersion>
    </properties>
  </profiles>

image.gif

IDEA安装插件mybatisX。

2.6. vscode的安装、插件、配置

2.6.1、安装vscode和插件

下载地址Download Visual Studio Code - Mac, Linux, Windows

vscode用于前端管理系统,在vsCode里安装以下插件

  • Auto Close Tag
  • Auto Rename Tag
  • Chinese
  • ESlint
  • HTML CSS Support
  • HTML Snippets
  • JavaScript ES6
  • Live Server
  • open in brower
  • Vetur

2.6.2、关闭Eslink强检查

打开vue项目/build/webpack.base.conf.js,注释:

image.gif

这样就能少去很多没必要的报错,例如.vue注释空格报错

2.6.3、 禁止运行项目后自动打开浏览器

vue项目运行命令npm run dev导致自动打开浏览器

解决办法:

1、在config文件夹找到index.js文件夹

2、把autoOpenBrowser: true

3、改为autoOpenBrowser: false

image.gif

2.7. 初始化项目架构、创建仓库并提交GitHub

我项目初始化的时候,没有按照雷神用Spring Boot Initilizr。而是按照周阳在springcloud课程里面手动依赖管理的方式初始化的项目。

2.7.1、码云创建Maven仓库,git克隆父工程

码云创建Maven仓库

设置Maven开发模板;分支类型为“生产、开发模型” ,使开发分支时用dev分支,发布后使用master分支:

image.gif

通过仓库地址克隆项目到本地:

image.gif

image.gif

2.7.2、新建子模块

  • gulimall-xxx(product/order/ware/coupon/member)
  • 每一个子模块的包名为com.xmh.gulimall.xxx(product/order/ware/coupon/member)
  • 并在每个子模块下引入web、openfegin

新建maven模块 gulimall-xxx,导入依赖pom.xml

image.gif

如果报错:

'https://start.spring.io' 的初始化失败
请检查 URL、网络和代理设置。
错误消息:
Cannot download 'https://start.spring.io': Connection reset
image.gif

则需要设置代理:

image.gif

https://plugins.jetbrains.com/
image.gif

image.gif

如果是idea2023,只能选java 17,那么替换URL:

https://start.aliyun.com/
image.gif

image.gif

image.gif

image.gif

导入依赖

<dependencies>
        <!--openfeign-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <!--web-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
    </dependencies>

image.gif

父工程的pom.xml,并把父工程添加到maven

image.gif

2.7.3、过滤上传git的垃圾文件

  • 点开父工程的.gitignore文件,添加如下内容
**/mvnw
**/mvnw.cmd
**/.mvn
**/target/
.idea
**/.gitignore

image.gif

也可以直接把这些文件删除,这些文件是用不到的

2.7.4、右键项目提交

先右键项目-git-add,然后提交本地库 image.gif

填写提交信息、点击commit

2.7.5、创建仓库并推送GitHub

image.gif

image.gif

2.8. 导入MySQL数据库表

注意:所有数据库表是没有外键的,商城项目外键复杂影响性能。

0.使用powerDesigner设计表:

image.gif

1.创建数据库gulimall_oms,gulimall_pms,gulimall_sms,gulimall_ums,gulimall_wms,基字符集选择utf8mb4

2.使用Navicat或SQLyog分别创建五个数据库,编码utf8mb4。

image.gif

3.双击打开数据库,新建查询,将sql语句复制粘贴运行:

image.gif

image.gif

随便点开一个表,发现没有中文乱码:

image.gif

注意:不能将对应sql文件拉进点开的数据库自动运行sql语句,因为sql文件编码是gbk,直接拖进去会导致中文乱码

3、快速开发

3.1. “人人开源”,快速构建后台管理系统

3.1.1、克隆人人开源fast项目

码云上搜索人人开源,找到renren-fast(后台管理系统的后端),renren-fast-vue(后台管理系统的前端), 克隆到本地。

人人开源

image.gif

  • renren-fast是一个轻量级的,前后端分离的Java快速开发平台,能快速开发项目并交付
  • renren-fast-vue基于vue、element-ui构建开发,实现renren-fast后台管理前端功能,提供一套更优的前端解决方案
  • renren-security是一个轻量级的,前后端分离的Java快速开发平台,能快速开发项目并交付
  • renren-generator是人人开源项目的代码生成器,可在线生成基础增删改查相关的entity、xml、dao、service、html、js、sql代码,减少70%以上的开发任务,

克隆:

桌面右键git bash克隆两个项目:

git clone https://gitee.com/renrenio/renren-fast.git
git clone https://gitee.com/renrenio/renren-fast-vue.git

image.gif

3.1.2、删掉两个文件夹里的.git文件夹

3.1.3、把renren-fast复制到子模块,并加入父工程

把后端renren-fast文件夹复制到谷粒商城项目中并加入父工程:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.vince.gulimall</groupId>
    <artifactId>gulimall</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>gulimall</name>
    <description>聚合服务</description>
    <packaging>pom</packaging>
    <modules>
        <module>guli-coupon</module>
        <module>guli-member</module>
        <module>guli-order</module>
        <module>guli-product</module>
        <module>guli-ware</module>
        <module>renren-fast</module>
    </modules>
</project>

image.gif

然后在idea项目结构里设置项目jdk为11,把renren_fast的pom里jdk改为11:

image.gif

3.1.4、renren-fast的pom修改

  • pom.xml报错
'parent.relativePath' of POM io.renren:renren-fast:3.0.0

image.gif

报错原因:子模块的parent写的并不是子模块的上一级,而是继承了springboot

解决方法:将其他模块pom的parent复制粘贴到renren-fast的pom

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.7.3</version>
    <relativePath/> <!-- lookup parent from repository -->
  </parent>

image.gif

  • 如果pom.xml之中的plugin地方报错,引入相关依赖
<!-- https://mvnrepository.com/artifact/com.spotify/docker-maven-plugin -->
<dependency>
   <groupId>com.spotify</groupId>
   <artifactId>docker-maven-plugin</artifactId>
   <version>0.4.14</version>
</dependency>
<dependency>
  <groupId>org.codehaus.mojo</groupId>
  <artifactId>wagon-maven-plugin</artifactId>
  <version>1.0</version>
</dependency>

image.gif

3.1.5、创建后台管理系统的数据库gulimall_admin

sql文件在renren-fast/db/ 目录下,找到其中的mysql.sql 复制,运行。

image.gif

3.1.6、修改renren-fast的配置文件,设置数据库

查看application.yml,发现当前环境为dev

image.gif

修改application-dev.yml, 配置成自己的linux的数据库信息,别忘了数据库名为gulimall_admin:

image.gif

如果报错ssl错误,在url后面加&useSSL=false

3.1.7、启动和访问

http://localhost:8080/renren-fast/

image.gif

image.gif

测试成功

3.1.8、node.js运行前端项目

安装node.js

下载地址https://nodejs.org/dist/v10.16.3/,下载之后直接安装即可。安装后检查node.js

image.gif

image.gif

配置淘宝镜像

npm config set registry http://registry.npm.taobao.org/

image.gif

设置node-sass版本:

npm install  node-sass@4.14

image.gif

注意:一定要保证nodejs版本和node-sass匹配,不想浪费时间就下载我前面指定的版本。

image.gif

加载项目依赖并运行项目:

运行vue项目之前,运行npm install命令,加载项目依赖

点击左下角打开控制台、点击终端 :

image.gif

安装npm依赖

npm install

image.gif

运行项目

npm run dev

image.gif

报错解决:

如果npm install卡着不动,重启windows、管理员cmd窗口试试。

版本很重要,建议下载我前面的版本。

为什么运行命令是npm run dev?

在项目目录下,我们可以看到一个名为package.json的文件,该文件是对项目、模块包的描述,在package.json文件中,有一个scripts的字段:

"scripts": {
    "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
    "start": "npm run dev",
    "build": "node build/build.js"
  },
image.gif

修改后运行命令就是npm run serve:

// 运行npm run serve的scripts字段
  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lint": "vue-cli-service lint"
  },
image.gif

运行成功:

image.gif

访问http://localhost:8001,测试成功,账号密码是admin、admin。

报错解决:

如果不显示验证码是因为后台没有运行成功、检查idea是否数据库报错、检查虚拟机docker ps数据库是否运行。

另外centos默认会隔一两天自动改ip地址,想关闭参考下面文章的2.6:

Linux基础_vincewm的博客-CSDN博客_finalshell 进程查看

image.gif

image.gif

3.2. product模块的逆向工程搭建,人人开源代码生成器

3.2.1、克隆renren-generator

image.gif

git clone https://gitee.com/renrenio/renren-generator.git

image.gif

3.2.2、删除.git文件并导入到父工程中

删除其中的.git文件,复制到父工程中,父工程pom.xml中添加代码生成器为子模块

image.gif

3.2.3、修改生成器模块的pom

image.gif

3.2.4、修改生成器模块配置文件的数据库信息

修改renren-generator的配置文件application.yml,配置自己的数据源,注意修改数据库名gulimall_pms(生成商品系统)

先生成gulimall-pms商品系统,就数据库名为商品系统的数据库表

spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    #MySQL配置
    driverClassName: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.xxx.xxx:3306/gulimall_pms?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&useSSL=false
    username: root
    password: 1234

image.gif

踩坑:ssl报错就在url后面加&useSSL=false、数据库连接出错检查虚拟机开机情况、数据库信息填写错误

3.2.5、修改生成信息generator.properties

这里先配置商品的相关信息:

注意只修改下面内容,其他内容不用变。

#代码生成器,配置信息
mainPath=com.vince
#包名
package=com.vince.gulimall
moduleName=product
#作者
author=vince
#Email
email=xxxxx@qq.com
#表前缀(类名不会包含表前缀)
tablePrefix=pms_

image.gif

如果引入spring-boot-starter-parent 2.2.6.RELEASE爆红,参考问题2

3.2.6、controller模板中去掉@RequiresPermissions注解

修改src/main/resources/template/Controller.java.vm

删除导入@RequiresPermissions注解的语句

image.gif

注释掉该位置,此处的注释是shiro提供的,我们以后要用spring security

image.gif

注意:这里注释要用//,ctrl+/的注释是#。

3.2.7、运行项目并生成代码

访问localhost:80,选中所有表,生成代码

选择每页显示30条后,再全选生成

image.gif

注意:如果表备注里中文乱码,重写运行sql文件里的语句, 复制粘贴运行,因为sql文件编码是gbk

3.2.8、解压生成代码并复制到guli-product

解压生成的代码,把mian文件夹复制到guli-product/src下

删除前端代码:\resources\src\(前端文件,用不到)

image.gif

如果之前没有创建application.yml和启动类,手动创建

3.2.9、新建common模块,解决生成代码报错问题

新建gulimall-common的Maven模块,用来引入每一个微服务公共的依赖、bean、工具类等

image.gif

让所有gulimall-xxx的pom引用guli-common的依赖:

 

<dependency>
            <groupId>com.vince.gulimall</groupId>
            <artifactId>gulimall-common</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>

image.gif

在gulimall-common引入公共依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>gulimall</artifactId>
        <groupId>com.vince.gulimall</groupId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.vince.gulimall</groupId>
    <artifactId>gulimall-common</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <!-- 统一管理jar包版本 -->
    <properties>
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
        <mybatis-plus.version>3.4.1</mybatis-plus.version>
        <lombok.version>1.18.8</lombok.version>
        <httpcore.version>4.4.14</httpcore.version>
        <commons.lang.version>2.6</commons.lang.version>
        <jakarta.validation.api>2.0.2</jakarta.validation.api>
    </properties>
    <dependencies>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>${mybatis-plus.version}</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>${lombok.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpcore</artifactId>
            <version>${httpcore.version}</version>
        </dependency>
        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>${commons.lang.version}</version>
        </dependency>
        <dependency>
            <groupId>jakarta.validation</groupId>
            <artifactId>jakarta.validation-api</artifactId>
            <version>${jakarta.validation.api}</version>
            <scope>compile</scope>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.28</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2021.0.1.0</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
</project>

image.gif

注意SpringCloud和springboot和版本兼容问题,不匹配就是给后面埋雷,建议用老师的版本或我的版本。我这里版本都是最新的,springboot版本2.7.4,SpringCloud版本2021.0.4,SpringCloudAlibaba版本2021.0.1.0
Release Train Boot Version
2021.0.x aka Jubilee 2.6.x, 2.7.x (Starting with 2021.0.3)
2020.0.x aka Ilford 2.4.x, 2.5.x (Starting with 2020.0.3)
Hoxton 2.2.x, 2.3.x (Starting with SR5)
Greenwich 2.1.x
Finchley 2.0.x
Edgware 1.5.x
Dalston 1.5.x
Spring Cloud Alibaba Version Spring Cloud Version Spring Boot Version
2021.0.4.0* Spring Cloud 2021.0.4 2.6.11
2021.0.1.0 Spring Cloud 2021.0.1 2.6.3
2021.1 Spring Cloud 2020.0.1 2.4.2

从renren-fast模块的common包下,复制粘贴这些包和类:

image.gif

然后把引入上面这些类的报错文件中,重新导入,例如:

import io.renren.common.xss.SQLFilter;

image.gif

改成

import com.vince.common.xss.SQLFilter;

image.gif

如果第六步没有删除在controller模板中删除@RequiresPermissions注解:

ctrl+x删除gulimall-product里所有controller中的@RequiresPermissions注解

import org.apache.shiro.authz.annotation.RequiresPermissions;
@RequiresPermissions("product:attr:list")
image.gif

现在所有报错都已经清理完毕。

如果之前注释了controller模板(在renren-generator的resources-template-Controller.java.vm里)里的@RequiresPermissions注解,这里就不用删除了。

3.2.10、结果类R使用方式

上面解决报错问题后,common模块的utils包下有个结果类R:

public class R extends HashMap<String, Object> {
  private static final long serialVersionUID = 1L;
  
  public R() {
    put("code", 0);
    put("msg", "success");
  }
  
  public static R error() {
    return error(HttpStatus.SC_INTERNAL_SERVER_ERROR, "未知异常,请联系管理员");
  }
  
  public static R error(String msg) {
    return error(HttpStatus.SC_INTERNAL_SERVER_ERROR, msg);
  }
  
  public static R error(int code, String msg) {
    R r = new R();
    r.put("code", code);
    r.put("msg", msg);
    return r;
  }
  public static R ok(String msg) {
    R r = new R();
    r.put("msg", msg);
    return r;
  }
  
  public static R ok(Map<String, Object> map) {
    R r = new R();
    r.putAll(map);
    return r;
  }
  
  public static R ok() {
    return new R();
  }
  public R put(String key, Object value) {
    super.put(key, value);
    return this;
  }
}

image.gif

controller使用方法:

返回成功数据:

return R.ok().put("data", (Object)"响应的数据");

image.gif

返回错误数据:

return R.error(500,"错误消息,在msg里").put("data",(Object)"错误数据,在data里,常为List<String>,存多个错误原因");

image.gif

3.2.11、配置yml和添加mysql依赖,测试CRUD

common模块的pom.xml加入依赖:

<dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.28</version>
        </dependency>

image.gif

product模块的application.yml

server:
  port: 10000
spring:
  datasource:
    username: root
    password: 1234
    url: jdbc:mysql://xxxx:3306/gulimall_pms?userUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.jdbc.Driver
mybatis-plus:
  configuration:
    #数据库下划线和实体类驼峰统一
    map-underscore-to-camel-case: true
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  global-config:
    db-config:
      id-type: auto
    banner: false
  #告诉mp,sql映射文件的位置,默认值classpath*:/mapper/**/*.xml。
#  classpath表示只引用现在模块的类路径。lasspath*表示不止引用现在模块的类路径,还包括依赖jar包的类路径
  mapper-locations: classpath:/mapper/**/*.xml

image.gif

3、测试

  • 新建测试类

image.gif

  • 测试
@SpringBootTest
class GulimallProductApplicationTests {
    @Autowired
    BrandService brandService;
    @Test
    public void testBrand(){
        BrandEntity brandEntity = new BrandEntity();
        brandEntity.setName("华为");
        brandService.save(brandEntity);
        System.out.println("保存成功");
        List<BrandEntity> list = brandService.list(new LambdaQueryWrapper<BrandEntity>().eq(BrandEntity::getName, "华为"));
        System.out.println(list);
    }
}

3.3 其他模块的逆向工程搭建,人人开源

3.3.6、各模块创建yml,设置端口号

按照字母序从上往下配置,coupon是7000,member是8000,order是9000,product是10000,ware是11000。

3.3.1、修改生成器properties和yml,生成coupon模块代码

修改生成器配置,模块名和表前缀:

image.gif

#代码生成器,配置信息
mainPath=com.vince
#包名
package=com.vince.gulimall
moduleName=coupon
#作者
author=vince
#Email
email=xxx@qq.com
#表前缀(类名不会包含表前缀)
tablePrefix=sms_

image.gif

修改yml的数据库名

image.gif

运行生成器模块,访问http://localhost/

每页显示100条、全选生成:

image.gif

3.3.2、复制粘贴生成代码,引入common模块依赖

生成coupon的代码,main文件夹复制到工程中,并在gulimall-coupon工程中引入gulimall-common依赖

<dependency>
            <groupId>com.vince.gulimall</groupId>
            <artifactId>gulimall-common</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>

image.gif

3.3.3、创建yml,删除resources的src文件夹

从product复制过去,只需要修改数据库名字。

server:
  port: 7000
spring:
  datasource:
    username: root
    password: 1234
    url: jdbc:mysql://xxxx.134:3306/gulimall_sms?userUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.jdbc.Driver
mybatis-plus:
  configuration:
    #数据库下划线和实体类驼峰统一
    map-underscore-to-camel-case: true
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  global-config:
    db-config:
      id-type: auto
    banner: false
  #告诉mp,sql映射文件的位置,默认值classpath*:/mapper/**/*.xml。
  #  classpath表示只引用现在模块的类路径。lasspath*表示不止引用现在模块的类路径,还包括依赖jar包的类路径
  mapper-locations: classpath:/mapper/**/*.xml

image.gif

删除resources下的src

image.gif

3.3.4、运行测试

访问http://localhost:7000/coupon/coupon/list测试

image.gif

测试成功!

3.3.5、同方法生成gulimall-member/gulimall-order/gulimall-ware的代码

生成:

修改generator.properties的模块名和表前缀(ums_,oms_,wms_)、yml数据库名、运行生成器模块,访问http://localhost/

每页显示100条、全选生成。

配置生成后的模块:

复制粘贴生成代码,pom引入common模块依赖、yml修改数据库名、删除resources下的src

ware模块多一条,删除这三个实体类和对应的dao、service、controller、resources.mapper.ware

image.gif

测试:

测试member、ums:http://localhost:8000/member/growthchangehistory/list

测试order、oms:http://localhost:9000/order/order/list

测试ware、wms: http://localhost:11000/ware/wareinfo/list

相关文章
|
2月前
|
消息中间件 监控 前端开发
如何开发项目管理系统中的项目结项板块?(附架构图+流程图+代码参考)
在企业项目管理中,“项目结项”是关键环节,常因流程不清、文档不全、审批滞后等问题导致交付困难。本文介绍如何通过“项目结项”模块实现线上化管理,涵盖结项申请、审批流程、成果上传、权限控制等功能,帮助团队高效完成项目收尾,避免成果丢失与流程混乱。内容包括功能设计、业务流程、系统架构、数据库设计、核心代码实现、前端交互及优化建议,助力项目管理系统快速落地并稳定运行。
|
1月前
|
人工智能 自然语言处理 JavaScript
Github又一AI黑科技项目,打造全栈架构,只需一个统一框架?
Motia 是一款现代化后端框架,融合 API 接口、后台任务、事件系统与 AI Agent,支持 JavaScript、TypeScript、Python 多语言协同开发。它提供可视化 Workbench、自动观测追踪、零配置部署等功能,帮助开发者高效构建事件驱动的工作流,显著降低部署与运维成本,提升 AI 项目落地效率。
217 0
|
6月前
|
网络协议 Java 应用服务中间件
框架源码私享笔记(01)Tomcat核心架构功能 | 配置详解
本文首先分享了《活出意义来》一书序言中的感悟,强调成功如同幸福,不是刻意追求就能得到,而是全心投入时的副产品。接着探讨了Tomcat的核心功能与架构解析,包括网络连接器(Connector)和Servlet容器(Container),并介绍了其处理HTTP请求的工作流程。文章还详细解释了Tomcat的server.xml配置文件,涵盖了从顶级容器Server到子组件Connector、Engine、Host、Context等的配置参数及作用,帮助读者理解Tomcat的内部机制和配置方法。
|
2月前
|
数据挖掘 项目管理 Python
如何开发项目管理系统中的项目启动板块?(附架构图+流程图+代码参考)
本文介绍了项目管理系统中“项目启动”板块的设计与实现,涵盖功能模块、业务流程、开发技巧及效果展示,并提供代码参考和常见问题解答,助力企业高效搭建项目管理平台。
|
2月前
|
存储 Java 数据库连接
简单学Spring Boot | 博客项目的三层架构重构
本案例通过采用三层架构(数据访问层、业务逻辑层、表现层)重构项目,解决了集中式开发导致的代码臃肿问题。各层职责清晰,结合依赖注入实现解耦,提升了系统的可维护性、可测试性和可扩展性,为后续接入真实数据库奠定基础。
266 0
|
2月前
|
缓存 Java 数据库
Java 项目分层架构实操指南及长尾关键词优化方案
本指南详解基于Spring Boot与Spring Cloud的Java微服务分层架构,以用户管理系统为例,涵盖技术选型、核心代码实现、服务治理及部署实践,助力掌握现代化Java企业级开发方案。
146 2
|
2月前
|
监控 前端开发 BI
如何开发项目管理系统中的项目收支板块?(附架构图+流程图+代码参考)
本文深入讲解项目管理系统中项目收支模块的设计与实现,涵盖预算、收入与支出管理,以及报表分析功能。内容包括模块功能概述、业务流程、开发技巧与实现方法,并提供数据库设计及前后端代码示例,助力企业打造高效的项目财务管控系统。
|
2月前
|
SQL 前端开发 项目管理
如何开发项目管理系统中的项目执行板块?(附架构图+流程图+代码参考)
随着企业项目规模扩大,传统管理方式已难以满足需求。本文介绍项目管理系统中“项目执行”板块的开发,涵盖任务管理、创建、验收及进度汇报等核心环节。通过功能设计、业务流程和开发技巧,结合代码示例,帮助企业高效推进项目执行,提升管理效率。
|
3月前
|
设计模式 开发者
一、HarmonyOS Next 开发者手册项目之项目架构设计
该项目是一个基于HarmonyOS Next的开发者学习手册应用,旨在帮助开发者系统学习HarmonyOS开发知识。项目采用分级学习方式,从基础到高级逐步深入讲解技术与实践案例。前四章重点介绍应用架构相关内容,助力快速掌握应用核心。 项目结构清晰,包含主入口、源代码目录、公共资源和工具等。页面导航分为多个阶段:萌新小白(基础入门)、登堂入室(进阶学习)、进阶高手(高级开发)。支持Markdown解析,使用`@luvi/lv-markdown-in`插件展示内容,并定义了多种数据结构以规范开发流程。 源码已开源,持续更新中
88 1
|
10月前
|
前端开发 测试技术 数据处理
Kotlin教程笔记 - MVP与MVVM架构设计的对比
Kotlin教程笔记 - MVP与MVVM架构设计的对比
308 4

热门文章

最新文章