【微服务】143:商品分类业务的实现

今天是刘小爱自学Java的第143天。

感谢你的观看,谢谢你。

image

学习计划安排如下:

  • 商品分类业务的初步实现。
  • 数据模型的分析:数据表字段的设计,Java中对应的实体类,前端页面vue组件。
  • 业务模型的分析:请求路径是什么?根据什么去数据库查询?具体实现代码的编写。
  • 其中还有一个跨域问题未来得及解决,怎么感觉积累的问题越来越多了,这样下去可不行啊。

一、商品分类业务

我们的项目是刘小爱商城,其核心自然是商品了,所以就要涉及到一个商品分类业务。

1需求分析

我们先看看国内的主流网站上是如何做的?

image

比如说家用电器,这是一级类目。

它又分为很多种:比如说电视、空调、洗衣机、冰箱……等,这是二级类目。

并且还能够垂直细分,比如说电视又可以被分为:超薄电视、全面屏电视……等。

好,如何用代码实现这种需求?

一个需求拿到手中了,优先建立数据模型

  • 前端页面中的这些数据如何存放到数据库中?
  • 数据库中的表如何设计,有哪些字段?
  • 设计Java实体类和数据表对应?

这些问题解决了,方向也就定了,剩下的就是具体代码的编写了。

所以说数据模型是非常重要的,你想呀,方向都弄错了,写再多的代码有什么用?

2数据库表关系梳理

image

商品分类这是一个多级类目的关系。

家用电器是一个父节点,它有多个子节点,子节点往下又有子节点,所以表字段设计:

  • id和name表字段这不用多说。
  • 通过表字段parent_id指定对应父节点的id?
  • 通过表字段is_parent确定它是否是父节点?
  • 如果是true表示它是父节点,有子节点。
  • 如果是false表示它不是父节点,没有子节点。

这样就能把表数据自关联起来了,无论多少级关系,都能表示清楚了。

值得注意的是

  • 数据表字段单词之间用下划线“_”隔开。

  • is_parent是一个布尔值,但是在数据表中用0和1表示,0为false,1为true。

3前端vue代码的编写

好数据分析完成,先从前端页面开始编写,因为请求是从前端页面发出的。

当然实际开发中应该都是根据开发文档来各自完成,我这边的话都得自己来弄。

image

Category.vue是分类业务对应的具体vue,v-card:卡片,是vuetify框架中提供的组件。

至于具体的前端代码编写,我们不做详细介绍,但是有一点我们要搞清楚:

页面发送的请求路径是怎样的?

后台服务器得根据这个路径来接受请求。

我们可以发现:请求路径为baseUrl+url,也就是上述中两个url相连接。

同时再通过浏览器F12打开控制台确认其请求路径是否是这样的?

二、后台代码编写

1Java实体类

注意实体类是存放在微服务lxa-item的lxa-item-pojo子工程中:

image

数据库中的表tb_category,关于字段和我们一开始的分析基本一致,多了一个sort属性。

而Category实体类使用通用mapper将其和表tb_category一一对应起来。

2启动类及mapper层

该业务逻辑很简单,只涉及到了单表查询,所以使用通用mapper即可。

注意具体的业务代码是存放在微服务lxa-item的lxa-item-service子工程中:

image

①mapper层代码编写

因为是单表查询,所以直接使用通用mappe即可,继承通用mapper中的Mapper接口即可,泛型为对应的实体类Category。

②启动类编写

因为使用了通用mapper,所以要通过注解@MapperScan确定扫描mapper的路径。

另外两个注解一个开启eureka客户端,一个说明是SpringBoot启动类,写过很多遍了。

注意:通用mapper相关的包为tk开头,一定要注意导包不要导错了。

3Controller层和Service层

image

①Controller层代码

确认其请求路径:category/list?pid=0

先不考虑网关,直接把整个业务写出来。

请求路径中参数是以问号的形式拼接到路径中的,所以用注解@RequestParam接受参数。

如果是category/list/1这样直接出现在请求路径中,就用注解@Pathvarible接受参数。

②Servic层代码

因为pid并不是tb_category表中的主键,所以创建一个对象设定pid再查询。

注意,做一个提醒

关于通用mapper的使用我专门写过一篇教程,就不做赘述了。

其中还应该做结果判断的处理,如果查询到的数据为空要报错,我这边暂时没做处理。

三、网关测试

代码编写完毕做一个测试:

image

①直接访问

直接在浏览器上输入对应的路径,参数pid设置为0,可以从数据库中查询到对应数据。

其查询的数据结果上图右侧有显示。

②通过网关访问

回顾:网关的作用相当于加了一层保护,其本质还是会跳转直接访问时的那个路径。

  • prefix:添加路由前缀,网关访问时路径都要加上设置的这个路由前缀。
  • routes:添加路由,item/及其子路径全部都会跳转到item-service这个微服务。

再次强调:每新建一个微服务,我们都要以相同的方式配置其网关路由。

③通过域名访问

如果通过我们昨天设定的网关域名访问,会发现浏览器控制台上报错了,

具体什么原因呢?

涉及到了一个跨域问题,关于该问题,时间受限,我们明天再做说明。

最后

我是刘小爱,一个白天上班晚上学习的95后沪漂,不为其它,只为学会自律做好自己,也愿我的每日打卡能给你带来勇气,欢迎点赞关注和评论。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351