学习地址:https://download.csdn.net/download/Q2802020/12883464

第1章 框架搭建

学习目标

  • 了解电商
  • 了解畅购架构
  • 了解畅购工程结构
  • 畅购工程搭建
  • 商品微服务搭建
  • 品牌增删改查

1. 走进电商

1.1 电商行业分析

近年来,世界经济正向数字化转型,大力发展数字经济成为全球共识。党的十九大报告明确提出要建设“数字中国”“网络强国”,我国数字经济发展进入新阶段,市场规模位居全球第二,数字经济与实体经济深度融合,有力促进了供给侧结构性改革。电子商务是数字经济的重要组成部分,是数字经济最活跃、最集中的表现形式之一。2017年,在政府和市场共同推动下,我国电子商务发展更加注重效率、质量和创新,取得了一系列新的进展,在壮大数字经济、共建“一带一路”、助力乡村振兴、带动创新创业、促进经济转型升级等诸多方面发挥了重要作用,成为我国经济增长的新动力。
2017年,我国电子商务交易规模继续扩大,并保持高速增长态势。国家统计局数据显示,2017年全国电子商务交易额达29.16万亿元,同比增长11.7%;网上零售额7.18万亿元,同比增长32.2%。我国电子商务优势进一步扩大,网络零售规模全球最大、产业创新活力世界领先。数据显示,截止2017年底,全国网络购物用户规模达5.33亿,同比增长14.3%;非银行支付机构发生网络支付金额达143.26万亿元,同比增长44.32%;全国快递服务企业业务量累计完成400.6亿件,同比增长28%;电子商务直接从业人员和间接带动就业达4250万人。

2018天猫全天成交额记录

1.2 电商系统技术特点

  • 技术新

  • 技术范围广

  • 分布式

  • 高并发、集群、负载均衡、高可用

  • 海量数据

  • 业务复杂

  • 系统安全

1.3 主要电商模式

B2B

1
2
3
B2B ( Business to Business)是指进行电子商务交易的供需双方都是商家(或企业、公司),她(他)们使用了互联网的技术或各种商务网络平台,完成商务交易的过程。电子商务是现代 B2B marketing的一种具体主要的表现形式。案例:阿里巴巴、慧聪网

C2C

1
2
3
C2C即 Customer(Consumer) to Customer(Consumer),意思就是消费者个人间的电子商务行为。比如一个消费者有一台电脑,通过网络进行交易,把它出售给另外一个消费者,此种交易类型就称为C2C电子商务。案例:淘宝、易趣、瓜子二手车

B2C

1
2
3
B2C是Business-to-Customer的缩写,而其中文简称为“商对客”。“商对客”是电子商务的一种模式,也就是通常说的直接面向消费者销售产品和服务商业零售模式。这种形式的电子商务一般以网络零售业为主,主要借助于互联网开展在线销售活动。B2C即企业通过互联网为消费者提供一个新型的购物环境——网上商店,消费者通过网络在网上购物、网上支付等消费行为。案例:唯品会、乐蜂网

C2B

1
2
3
4
5
C2B(Consumer to Business,即消费者到企业),是互联网经济时代新的商业模式。这一模式改变了原有生产者(企业和机构)和消费者的关系,是一种消费者贡献价值(Create Value), 企业和机构消费价值(Consume Value)。C2B模式和我们熟知的供需模式(DSM, Demand SupplyModel)恰恰相反,真正的C2B 应该先有消费者需求产生而后有企业生产,即先有消费者提出需求,后有生产企业按需求组织生产。通常情况为消费者根据自身需求定制产品和价格,或主动参与产品设计、生产和定价,产品、价格等彰显消费者的个性化需求,生产企业进行定制化生产。案例:海尔商城、 尚品宅配

O2O

1
2
3
O2O即Online To Offline(在线离线/线上到线下),是指将线下的商务机会与互联网结合,让互联网成为线下交易的平台,这个概念最早来源于美国。O2O的概念非常广泛,既可涉及到线上,又可涉及到线下,可以通称为O2O。主流商业管理课程均对O2O这种新型的商业模式有所介绍及关注。案例:美团、饿了吗

F2C

F2C指的是Factory to customer,即从厂商到消费者的电子商务模式。

B2B2C

1
2
3
4
B2B2C是一种电子商务类型的网络购物商业模式,B是BUSINESS的简称,C是CUSTOMER的简称,第一个B指的是商品或服务的供应商,第二个B指的是从事电子商务的企业,C则是表示消费者。案例:京东商城、天猫商城
注:我们《畅购电商系统开发》课程采用B2C模式,之后的项目实战《品优购电商系统开发实战》采用B2B2C模式。

2. 畅购-需求分析与系统设计

2.1 需求分析

网站前台静态原型演示,打开资料\页面\前台\project-changgou-portal-fis3-master,首页index.html

网站管理后台静态原型演示:http://czpm.itcast.cn/青橙后台/#g=1&p=后台首页

打开资料\页面\后台\project-changgou-cmm-fis3-master\pages,首页all-medical-main.html

2.2 系统设计

畅购商城属于B2C电商模式,运营商将自己的产品发布到网站上,会员注册后,在网站上将商品添加到购物车,并且下单,完成线上支付,用户还可以参与秒杀抢购。

2.2.1 前后端分离

网站后台的部分采用前后端分离方式。

以前的JavaWeb项目大多数都是java程序员又当爹又当妈,又搞前端,又搞后端。随着时代的发展,渐渐的许多大中小公司开始把前后端的界限分的越来越明确,前端工程师只管前端的事情,后端工程师只管后端的事情。正所谓术业有专攻,一个人如果什么都会,那么他毕竟什么都不精。

对于后端java工程师:

把精力放在设计模式,spring+springmvc,linux,mysql事务隔离与锁机制,mongodb,http/tcp,多线程,分布式架构,弹性计算架构,微服务架构,java性能优化,以及相关的项目管理等等。

对于前端工程师:

把精力放在html5,css3,vuejs,webpack,nodejs,Google V8引擎,javascript多线程,模块化,面向切面编程,设计模式,浏览器兼容性,性能优化等等。

我们在本课程中提供与项目课程配套的管理后台的前端代码,但是不讲解前端的内容。这样我们会将更多的精力放在**后端代码**的开发上!

2.2.2 技术架构

2.2.3 系统架构图

3 畅购-框架搭建

3.1 环境准备

(1)VMware Workstation Pro安装centos7 镜像

(2)安装docker

(3)拉取mySQL镜像,并创建容器

(4)客户端连接mysql容器,建库建表(建库建表语句在资源文件夹中提供)

虚拟机数据:

  • 虚拟机IP:192.168.211.132

  • 虚拟机账号:root 密码:123456

  • 数据库端口:3306
  • 数据库账号:root 密码:123456

数据库脚本:资料\数据库脚本

3.2 项目结构说明

结构说明:

changgou-gateway

网关模块,根据网站的规模和需要,可以将综合逻辑相关的服务用网关路由组合到一起。在这里还可以做鉴权和限流相关操作。

changgou-service

微服务模块,该模块用于存放所有独立的微服务工程。

changgou-service_api

对应工程的JavaBean、Feign、以及Hystrix配置,该工程主要对外提供依赖。

changgou-transaction-fescar

分布式事务模块,将分布式事务抽取到该工程中,任何工程如需要使用分布式事务,只需依赖该工程即可。

changgou-web

web服务工程,对应功能模块如需要调用多个微服务,可以将他们写入到该模块中,例如网站后台、网站前台等

3.3 公共工程搭建

3.3.1 父工程搭建

创建父工程 changgou-parent ,pom.xml文件中增加配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
<?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"><modelVersion>4.0.0</modelVersion><groupId>com.changgou</groupId><artifactId>changgou-parent</artifactId><version>1.0-SNAPSHOT</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.4.RELEASE</version></parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target><skipTests>true</skipTests></properties><!--依赖包--><dependencies><!--测试包--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId></dependency><!--fastjson--><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.51</version></dependency><!--swagger文档--><dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId><version>2.6.1</version></dependency><dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger-ui</artifactId><version>2.6.1</version></dependency><!--http://localhost:9011/swagger-ui.html--></dependencies><dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Greenwich.SR1</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>
</project>

删除src文件夹

3.3.2 其他公共模块搭建

创建changgou-gateway、changgou-service、changgou-service-api、changgou-web工程,工程全部为pom工程,并将所有工程的src文件删除。

pom.xml中打pom包

<packaging>pom</packaging>

项目结构如下:

3.4 Eureka微服务搭建

3.4.1 pom.xml依赖

创建模块changgou-eureka ,pom.xml引入依赖

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?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>changgou_parent</artifactId><groupId>com.changgou</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>changgou_eureka</artifactId><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></dependency></dependencies>
</project>

3.4.2 appliation.yml配置

创建配置文件application.yml

1
2
3
4
5
6
7
8
9
10
server:port: 7001
eureka:instance:hostname: 127.0.0.1client:register-with-eureka: false   #是否将自己注册到eureka中fetch-registry: false         #是否从eureka中获取信息service-url:defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

3.4.3 启动类配置

创建包com.changgou 包下创建启动类EurekaApplication,代码如下:

上图代码如下:

1
2
3
4
5
6
7
8
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {public static void main(String[] args) {SpringApplication.run(EurekaApplication.class);}
}

测试访问http://localhost:7001/,效果如下:

3.5 公共模块搭建

3.5.1 pom.xml依赖

创建公共子模块changgou-common,pom.xml引入依赖

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
<?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>changgou-parent</artifactId><groupId>com.changgou</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>changgou-common</artifactId><dependencies><!--web起步依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- redis 使用--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><!--eureka-client--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency><!--openfeign--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency><!--微信支付--><dependency><groupId>com.github.wxpay</groupId><artifactId>wxpay-sdk</artifactId><version>0.0.3</version></dependency><!--httpclient支持--><dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpclient</artifactId></dependency></dependencies>
</project>

公共子模块引入这些依赖后,其他微服务引入changgou-common后也自动引入了这些依赖

3.5.2 常用对象

创建entity包 ,在entity包下创建返回状态码实体类

1
2
3
4
5
6
7
8
9
10
11
12
/*** 返回码*/
public class StatusCode {public static final int OK = 20000;//成功public static final int ERROR = 20001;//失败public static final int LOGINERROR = 20002;//用户名或密码错误public static final int ACCESSERROR = 20003;//权限不足public static final int REMOTEERROR = 20004;//远程调用失败public static final int REPERROR = 20005;//重复操作public static final int NOTFOUNDERROR = 20006;//没有对应的抢购数据
}

包下建立类Result用于微服务返回结果给前端

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
/*** 返回结果实体类*/
public class Result<T> {private boolean flag;//是否成功private Integer code;//返回码private String message;//返回消息private T data;//返回数据public Result(boolean flag, Integer code, String message, Object data) {this.flag = flag;this.code = code;this.message = message;this.data = (T) data;}public Result(boolean flag, Integer code, String message) {this.flag = flag;this.code = code;this.message = message;}public Result() {this.flag = true;this.code = StatusCode.OK;this.message = "操作成功!";}// getter and setter.....
}

在entity包下建立类用于承载分页的数据结果

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/*** 分页结果类*/
public class PageResult<T> {private Long total;//总记录数private List<T> rows;//记录public PageResult(Long total, List<T> rows) {this.total = total;this.rows = rows;}public PageResult() {}//getter and setter ......
}

当然,我们还可以将其他工具类都一起倒入到工程中,以后会用到,将资料\工具类中的所有类直接导入到entity包下。

3.6 数据访问工程搭建

创建公共模块changgou-common-db ,pom文件引入依赖

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<?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>changgou-parent</artifactId><groupId>com.changgou</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>changgou-common-db</artifactId><!--依赖--><dependencies><!--对changgou-common的依赖--><dependency><groupId>com.changgou</groupId><artifactId>changgou-common</artifactId><version>1.0-SNAPSHOT</version></dependency><!--通用mapper起步依赖--><dependency><groupId>tk.mybatis</groupId><artifactId>mapper-spring-boot-starter</artifactId><version>2.0.4</version></dependency><!--MySQL数据库驱动--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><!--mybatis分页插件--><dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>1.2.3</version></dependency></dependencies>
</project>

这个公共模块是连接mysql数据库的公共微服务模块,所以需要连接mysql的微服务都继承自此工程。

3.7 商品微服务搭建

商品微服务主要是实现对商品的增删改查相关操作,以及商品相关信息的增删改查。

3.7.1 公共组件工程搭建

创建changgou-service-api子模块changgou-service-goods-api,并将资料\javabean\changgou-service-goods-api中的Pojo导入到工程中。

修改父工程changgou-service-api的pom.xml,添加persistence-apichanggou-common的依赖,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<dependencies><!--通用的common--><dependency><groupId>com.changgou</groupId><artifactId>changgou-common</artifactId><version>1.0-SNAPSHOT</version></dependency><!--每个工程都有Pojo,都需要用到该包对应的注解--><dependency><groupId>javax.persistence</groupId><artifactId>persistence-api</artifactId><version>1.0</version><scope>compile</scope></dependency>
</dependencies>

3.7.2 微服务工程搭建

修改changgou-service的pom.xml引入changgou-common-db的依赖,代码如下:

1
2
3
4
5
6
7
8
<!--依赖-->
<dependencies><dependency><groupId>com.changgou</groupId><artifactId>changgou-common-db</artifactId><version>1.0-SNAPSHOT</version></dependency>
</dependencies>

在changgou-service中创建changgou-service-goods ,pom.xml引入依赖

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<?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>changgou-service</artifactId><groupId>com.changgou</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>changgou-service-goods</artifactId><!--依赖--><dependencies><dependency><groupId>com.changgou</groupId><artifactId>changgou-service-goods-api</artifactId><version>1.0-SNAPSHOT</version></dependency></dependencies>
</project>

在resources下创建配置文件application.yml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
server:port: 18081
spring:application:name: goodsdatasource:driver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://192.168.211.132:3306/changgou_goods?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTCusername: rootpassword: 123456
eureka:client:service-url:defaultZone: http://127.0.0.1:7001/eurekainstance:prefer-ip-address: true
feign:hystrix:enabled: true
mybatis:configuration:map-underscore-to-camel-case: truemapper-locations: classpath:mapper/*Mapper.xmltype-aliases-package: com.changgou.goods.pojo

在包com.changgou.goods 包下创建启动类GoodsApplication,代码如下:

上图代码如下:

1
2
3
4
5
6
7
8
@SpringBootApplication
@EnableEurekaClient
@MapperScan(basePackages = {"com.changgou.goods.dao"})
public class GoodsApplication {public static void main(String[] args) {SpringApplication.run(GoodsApplication.class);}
}

注意 :@MapperScan是tk.mybatis.spring.annotation包下的,用于扫描Mapper接口

启动changgou-service-goods 再访问<http://localhost:7001/>效果如下:

==4 商品微服务-品牌增删改查==

4.1 需求分析

创建商品微服务,实现对品牌表的增删改查功能。具体包括

(1)查询全部列表数据

(2)根据ID查询实体数据

(3)增加

(4)修改

(5)删除

(6)条件查询

(7)分页查询

(8)分页+条件查询

(9)公共异常处理

4.2 表结构分析

品牌表:tb_brand

字段名称 字段含义 字段类型 字段长度 备注
id 品牌id INT    
name 品牌名称 VARCHAR    
image 品牌图片地址 VARCHAR    
letter 品牌的首字母 CHAR    
seq 排序 INT    

4.3 代码实现

上面品牌表对应Brand实体类

1
2
3
4
5
6
7
8
9
10
11
@Table(name="tb_brand")
public class Brand implements Serializable{@Idprivate Integer id;//品牌idprivate String name;//品牌名称private String image;//品牌图片地址private String letter;//品牌的首字母private Integer seq;//排序// getter and setter  .....(省略)
}

@Table和@Id都是JPA注解,@Table用于配置表与实体类的映射关系,@Id用于标识主键属性。

4.3.1 品牌列表

(1)Dao创建

在changgou-service-goods微服务下创建com.changgou.goods.dao.BrandMapper接口,代码如下:

1
2
public interface BrandMapper extends Mapper<Brand> {
}

继承了Mapper接口,就自动实现了增删改查的常用方法。

(2)业务层

创建com.changgou.goods.service.BrandService接口,代码如下:

1
2
3
4
5
6
7
8
public interface BrandService {/**** 查询所有品牌* @return*/List<Brand> findAll();
}

创建com.changgou.goods.service.impl.BrandServiceImpl实现类,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
@Service
public class BrandServiceImpl {@Autowiredprivate BrandMapper brandMapper;/*** 全部数据* @return*/public List<Brand> findAll(){return brandMapper.selectAll();}
}

(3)控制层

控制层 com.changgou.goods包下创建controller包 ,包下创建类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
@RestController
@RequestMapping("/brand")
@CrossOrigin
public class BrandController {@Autowiredprivate BrandService brandService;/**** 查询全部数据* @return*/@GetMappingpublic Result<Brand> findAll(){List<Brand> brandList = brandService.findAll();return new Result<Brand>(true, StatusCode.OK,"查询成功",brandList) ;}
}

测试:http://localhost:18081/brand

4.3.2 根据ID查询品牌

(1)业务层

修改com.changgou.goods.service.BrandService接口,添加根据ID查询品牌数据方法,代码如下:

1
2
3
4
5
6
/*** 根据ID查询* @param id* @return*/
Brand findById(Integer id);

修改com.changgou.goods.service.impl.BrandServiceImpl新增方法,代码如下:

1
2
3
4
5
6
7
8
9
/*** 根据ID查询* @param id* @return*/
@Override
public Brand findById(Integer id){return  brandMapper.selectByPrimaryKey(id);
}

(2)控制层

BrandController新增方法

1
2
3
4
5
6
7
8
9
10
11
/**** 根据ID查询品牌数据* @param id* @return*/
@GetMapping("/{id}")
public Result<Brand> findById(@PathVariable Integer id){//根据ID查询Brand brand = brandService.findById(id);return new Result<Brand>(true,StatusCode.OK,"查询成功",brand);
}

测试:http://localhost:18081/brand/14026

4.3.3 新增品牌

(1)业务层

修改com.changgou.goods.service.BrandService,新增方法

1
2
3
4
5
/**** 新增品牌* @param brand*/
void add(Brand brand);

修改com.changgou.goods.service.impl.BrandServiceImpl,新增增加品牌方法代码如下:

1
2
3
4
5
6
7
8
/*** 增加* @param brand*/
@Override
public void add(Brand brand){brandMapper.insertSelective(brand);
}

(2) 控制层

BrandController新增方法

1
2
3
4
5
6
7
8
9
10
/**** 新增品牌数据* @param brand* @return*/
@PostMapping
public Result add(@RequestBody Brand brand){brandService.add(brand);return new Result(true,StatusCode.OK,"添加成功");
}

测试:http://localhost:18081/brand

4.3.4 修改品牌

(1)业务层

需改com.changgou.goods.service.BrandService,添加修改品牌方法,代码如下:

1
2
3
4
5
/**** 修改品牌数据* @param brand*/
void update(Brand brand);

修改com.changgou.goods.service.impl.BrandServiceImpl,添加修改品牌方法,代码如下:

1
2
3
4
5
6
7
8
/*** 修改* @param brand*/
@Override
public void update(Brand brand){brandMapper.updateByPrimaryKeySelective(brand);
}

(2)控制层

BrandController新增方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
/**** 修改品牌数据* @param brand* @param id* @return*/
@PutMapping(value="/{id}")
public Result update(@RequestBody Brand brand,@PathVariable Integer id){//设置IDbrand.setId(id);//修改数据brandService.update(brand);return new Result(true,StatusCode.OK,"修改成功");
}

测试:http://localhost:18081/brand/325415

4.3.5 删除品牌

(1)业务层

修改com.changgou.goods.service.BrandService,添加删除品牌方法,代码如下:

1
2
3
4
5
/**** 删除品牌* @param id*/
void delete(Integer id);

修改com.changgou.goods.service.impl.BrandServiceImpl,新增删除品牌方法,代码如下:

1
2
3
4
5
6
7
8
/*** 删除* @param id*/
@Override
public void delete(Integer id){brandMapper.deleteByPrimaryKey(id);
}

(2)控制层

BrandController新增方法

1
2
3
4
5
6
7
8
9
10
/**** 根据ID删除品牌数据* @param id* @return*/
@DeleteMapping(value = "/{id}" )
public Result delete(@PathVariable Integer id){brandService.delete(id);return new Result(true,StatusCode.OK,"删除成功");
}

测试:http://localhost:18081/brand/325415

4.3.6 品牌列表条件查询

(1)业务层

修改com.changgou.goods.service.BrandService,增加根据条件搜索品牌方法,代码如下:

1
2
3
4
5
6
/**** 多条件搜索品牌方法* @param brand* @return*/
List<Brand> findList(Brand brand);

修改com.changgou.goods.service.impl.BrandServiceImpl,添加根据多条件搜索品牌方法的实现,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/*** 条件查询* @param brand* @return*/
@Override
public List<Brand> findList(Brand brand){//构建查询条件Example example = createExample(brand);//根据构建的条件查询数据return brandMapper.selectByExample(example);
}/*** 构建查询对象* @param brand* @return*/
public Example createExample(Brand brand){Example example=new Example(Brand.class);Example.Criteria criteria = example.createCriteria();if(brand!=null){// 品牌名称if(!StringUtils.isEmpty(brand.getName())){criteria.andLike("name","%"+brand.getName()+"%");}// 品牌图片地址if(!StringUtils.isEmpty(brand.getImage())){criteria.andLike("image","%"+brand.getImage()+"%");}// 品牌的首字母if(!StringUtils.isEmpty(brand.getLetter())){criteria.andLike("letter","%"+brand.getLetter()+"%");}// 品牌idif(!StringUtils.isEmpty(brand.getLetter())){criteria.andEqualTo("id",brand.getId());}// 排序if(!StringUtils.isEmpty(brand.getSeq())){criteria.andEqualTo("seq",brand.getSeq());}}return example;
}

(2) 控制层

BrandController新增方法

1
2
3
4
5
6
7
8
9
10
/**** 多条件搜索品牌数据* @param brand* @return*/
@PostMapping(value = "/search" )
public Result<List<Brand>> findList(@RequestBody(required = false) Brand brand){List<Brand> list = brandService.findList(brand);return new Result<List<Brand>>(true,StatusCode.OK,"查询成功",list);
}

测试:http://localhost:18081/brand/search

4.3.7 品牌列表分页查询

(1)业务层

修改com.changgou.goods.service.BrandService添加分页方法,代码如下:

1
2
3
4
5
6
7
/**** 分页查询* @param page* @param size* @return*/
PageInfo<Brand> findPage(int page, int size);

修改com.changgou.goods.service.impl.BrandServiceImpl添加分页方法实现,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
/*** 分页查询* @param page* @param size* @return*/
@Override
public PageInfo<Brand> findPage(int page, int size){//静态分页PageHelper.startPage(page,size);//分页查询return new PageInfo<Brand>(brandMapper.selectAll());
}

(2)控制层

BrandController新增方法

1
2
3
4
5
6
7
8
9
10
11
12
/**** 分页搜索实现* @param page:当前页* @param size:每页显示多少条* @return*/
@GetMapping(value = "/search/{page}/{size}" )
public Result<PageInfo> findPage(@PathVariable  int page, @PathVariable  int size){//分页查询PageInfo<Brand> pageInfo = brandService.findPage(page, size);return new Result<PageInfo>(true,StatusCode.OK,"查询成功",pageInfo);
}

测试:http://localhost:18081/brand/search/1/3

4.3.8 品牌列表条件+分页查询

(1)业务层

修改com.changgou.goods.service.BrandService,增加多条件分页查询方法,代码如下:

1
2
3
4
5
6
7
8
/**** 多条件分页查询* @param brand* @param page* @param size* @return*/
PageInfo<Brand> findPage(Brand brand, int page, int size);

修改com.changgou.goods.service.impl.BrandServiceImpl,添加多条件分页查询方法代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
/*** 条件+分页查询* @param brand 查询条件* @param page 页码* @param size 页大小* @return 分页结果*/
@Override
public PageInfo<Brand> findPage(Brand brand, int page, int size){//分页PageHelper.startPage(page,size);//搜索条件构建Example example = createExample(brand);//执行搜索return new PageInfo<Brand>(brandMapper.selectByExample(example));
}

(2)控制层

BrandController新增方法

1
2
3
4
5
6
7
8
9
10
11
12
13
/**** 分页搜索实现* @param brand* @param page* @param size* @return*/
@PostMapping(value = "/search/{page}/{size}" )
public Result<PageInfo> findPage(@RequestBody(required = false) Brand brand, @PathVariable  int page, @PathVariable  int size){//执行搜索PageInfo<Brand> pageInfo = brandService.findPage(brand, page, size);return new Result(true,StatusCode.OK,"查询成功",pageInfo);
}

测试:http://localhost:18081/brand/search/1/3

4.3.9 公共异常处理

为了使我们的代码更容易维护,我们创建一个类集中处理异常,该异常类可以创建在changgou-common工程中,创建com.changgou.framework.exception.BaseExceptionHandler,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@ControllerAdvice
public class BaseExceptionHandler {/**** 异常处理* @param e* @return*/@ExceptionHandler(value = Exception.class)@ResponseBodypublic Result error(Exception e) {e.printStackTrace();return new Result(false, StatusCode.ERROR, e.getMessage());}
}

注意:@ControllerAdvice注解,全局捕获异常类,只要作用在@RequestMapping上,所有的异常都会被捕获。

黑马畅购商城---1.项目介绍-环境搭建相关推荐

  1. 体检预约系统(第一天_1.1 项目介绍 环境搭建 )

    一.医疗健康系统-day01 1.1 第一天内容介绍 项目概述 健康管理机构软件 用于用户预约 浏览 健康干预 等 maven项目搭建 PowerDesigner数据库建模工具 ElementUI快速 ...

  2. vuejs项目开发环境搭建(ESlint安装)

    vuejs项目开发环境搭建(ESlint安装) vuejs项目开发环境搭建,有时候需要安装ESlint! eslint对ES6语法支持更好,可以通过eslint在团队开发中快速统一ES6的语法,精简代 ...

  3. Eclipse+Tomcat+MAVEN+SVN项目完整环境搭建

    1.JDK的安装 首先下载JDK,这个从sun公司官网可以下载,根据自己的系统选择64位还是32位,安装过程就是next一路到底.安装完成之后当然要配置环境变量了. ----------------- ...

  4. VS中编译带Qt的他人项目,环境搭建及解决报错

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 VS中编译带Qt的他人项目,环境搭建及解决报错 一.安装VS及Qt及Qt VS Tools 二.报错及解决办法 1.未能找到程序集&q ...

  5. 0、Java项目开发环境搭建

    Java项目开发环境搭建详解   工欲善其事,必先利其器. 一.环境搭建 1.JDK安装及环境变量配置 点击查看 2.Maven安装及环境变量配置 点击查看 Maven配置远程仓库地址:   打开ma ...

  6. GuLi商城-简介-项目介绍、分布式基础概念、微服务架构图

    一.项目简介 1 .项目背景 1 ).电商模式 市面上有 5 种常见的电商模式 B2B.B2C.C2B.C2C.O2O: 1 . B2B 模式 B2B (Business to Business), ...

  7. 商城项目02_环境搭建、安装VAGRANT、DOCKER、MYSQL、REDIS、从0搭建各个微服务项目、数据库初始化、安装NGINX

    文章目录 ①. virtualBox - 管理虚拟机 ②. vagrant - 安装虚拟机 ③. 虚拟机安装 - docker ④. docker上安装mysql ⑤. docker上安装redis ...

  8. Reggie外卖项目 —— 开发环境搭建

    02.开发环境搭建 2.1.数据库搭建 1.创建数据库,名称为reggie 2.导入表结构(使用的是SQLyog软件) 导入文件:db_reggie.sql SET FOREIGN_KEY_CHECK ...

  9. 谷粒商城-分布式基础篇-环境搭建

    1.写在前面 既个人博客系统和Java虚拟机学习后,深感技术点过于零散,于是照着尚硅谷教程写了谷粒商城这个项目.谷粒商城是一个完整的大型分布式架构电商平台,这个项目将我目前学到的知识点,以及还未学到的 ...

最新文章

  1. 【PAT (Advanced Level) Practice】1149 Dangerous Goods Packaging (25 分)
  2. 【数字信号处理】线性时不变系统 LTI “ 输入 “ 与 “ 输出 “ 之间的关系 ( 周期性分析 | 卷积运算规律 | 交换律 | 结合律 | 分配率 | 冲击不变性 )
  3. Introduction to Machine Learning
  4. java str.split(quot;cquot;),你真的完全理解了String的split方法?之二
  5. 组态王7.5安装教程
  6. Elasticsearch安装(Linux)
  7. controller层没反应_热拉提一年做几次?热提拉的副作用根本没在怕的~
  8. 米聊PK微信:微信是一朵奇葩
  9. qt的项目中单个文件加载样式表
  10. 【elastic】ES启动选举主节点 RemoteTransportException CoordinationStateRejected became follower
  11. 《大话设计模式》笔记(1)——创建型模式
  12. pandas—总结(2) 数据读写 (更新中)
  13. 过半中国人是工具类 App 活跃用户,为什么变现却这么难?
  14. HTML学习总结(3)——标签a/head/style/img
  15. 进一步限塑!洲际酒店集团与联合利华达成合作,旗下酒店将提供大瓶装洗护用品替换一次性小包装 | 美通社头条...
  16. 区块链技术在现实生活中的主要应用有哪些?
  17. Chatgpt 指令收集
  18. 数组图像处理:直方图均衡化
  19. photoshop旋转图片
  20. Arduino云植物自动浇水

热门文章

  1. 监督学习笔记 - Datacamp
  2. react给div添加滚动条
  3. python怎样执行curl命令_如何使用python执行curl命令
  4. macOS “应用程序不能打开”
  5. 脉动进位计数器Verilog表述
  6. 计算机教研员讲座,卢美玉名师工作室
  7. Java-Spring MVC学习笔记
  8. 华为机试真题 Python 实现【任务调度】【2022.11 Q4 新题】
  9. 牛血清白蛋白修饰牛红细胞超氧化物歧化酶SOD/叶酸偶联2-ME白蛋白纳米粒的制备
  10. BUUCTF-[BJDCTF2020]EzPHP