苍穹外卖学习笔记(一)
苍穹外卖学习笔记(一)
Jie开发环境搭建
首先把资料下载,网盘链接:黑马程序员苍穹外资料链接
鉴于很多 Windows 的朋友没有下载百度网盘客户端或者出现打不开、登录不上的问题,在这里推荐大家使用 Tampermonkey+IDM 的脚本管理器方式下载
首先在浏览器中下载 Tampermonkey 拓展
在其添加脚本中下载网盘直链下载助手下载多线程下载器 IDM(并且下载使用浏览器扩展)
IDM 全称为 Internet Download Manager,仅支持 Windows 平台,Mac 平台可使用 NDM 代替。- 打开 IDM 选项,将自己的浏览器加入 IDM 的捕获列表中。
- 把要支持 IDM 下载的后缀名添加到 IDM 选项 -> 文件类型里。
后缀:
1
3GP 7Z AAC ACE AI AIF ALZ APK APP APPX APPXBUNDLE ARC ARJ ASF AVI BH BIN BR BUNDLE BZ BZ2 CDA CSV DIF DLL DMG DOC DOCX EGG EPS EXE FLV GZ GZIP IMG IPA ISO ISZ JAR KEXT LHA LZ LZH LZMA M4A M4V MDB MID MKV MOV MP3 MP4 MPA MPE MPEG MPG MSI MSIX MSIXBUNDLE MSU MUI OGG OGV PDF PKG PPT PPTX PSD PST PUB QT R0* R1* RA RAR RM RMVB RTF SEA SIT SITX SLDM SLDX TAR TBZ TBZ2 TGZ TIF TIFF TLZ TXZ UDF VOB VSD VSDM VSDX VSS VSSM VST VSTM VSTX WAR WAV WBK WIM WKS WMA WMD WMS WMV WMZ WP5 WPD WPS XLS XLSX XPS XZ Z ZIP ZIPX ZPAQ ZSTD
打开网页版百度网盘就可以下载了
一. 前端环境搭建
前端工程基于 nginx 部署
注意:必须将 nginx 相关代码存放到英文目录下,否则 nginx 不能启动
启动之后打开浏览器搜索locatehost即可
鉴于之后要经常使用它,我能可以使用 edge 浏览器的应用功能,将该网站作为应用安装,快速使用
如图:
二. 后端环境搭建
后端工程基于 Maven <span style=color:red>
分模块开发构建该 spring 项目
1.进入 idea 项目
用 idea 打开项目在 pom.xml 文件中引入依赖
直接 clean 然后 install 即可
该项目结构比较简单,就是一个父工程聚合三个子模块的单体架构,可以说是当前主流的前后端中的必过项目了
这里对具体项目结构不再详细阐述
2.提交 git 仓库(+推送 github 远程仓库)
具体配置 idea 的 github 远程仓库这里不再描述
3.数据库环境搭建
复制 sky.sql 代码到数据库控制台中运行即可
共有 11 张表
4.前后端联调(在源代码中项目已经实现登录功能)
具体流程如下:
启动之前先使用 maven 工具中 compile 进行编译
注意在这里把数据库配置改成自己的
启动项目:
运行结果:
nginx 反向代理好处:
- 提高访问速度
- 进行负载均衡
- 保证后端服务安全
- 解决跨域问题
三. 完善登录功能(md5 加密存储)
思路:
- 将密码加密后存储,提高安全性
- 使用 md5 加密方式对明文密码加密
视频中是直接使用了 DigestUtils 中的 MD5 加密来提高安全性,鉴于 MD5 现在已经有点不太安全,市面上已经有了破解的方法,这里使用 MD5 加盐处理来进一步提高安全性
由于前端登录界面问题,这里不再提供注册的方法,直接自创一个类把需要的盐和加密后的密码获取,手动输入到数据库中对应字段
1 | // 生成一个新的盐值 |
登录验证问题
1.首先打开 pojo 模块中实体类的 employee,添加 salt 字段
1 | package com.sky.entity; |
2.在数据库中 employee 表新建一个 salt 字段,注意得是字符串类型
3.修改 EmployeeServiceImpl 类,添加加密处理
1 | package com.sky.service.impl; |
然后就可以登录成功了
接口文档的导入
这里使用 apifox 软件来导入
导入时选择 YApi 的 json 格式来导入
具体如下:
基于 Swagger 的 Knife4j
使用方式:
- 导入 Knife4j 的 Maven 坐标
- 在配置类中加入 Knife4j 相关配置
- 设置静态资源映射,否则接口文档页面无法访问
具体代码在 server 中配置文件 WebMvcConfiguration 类中
1 | /** |
运行项目后在浏览器输入http://localhost:8080//doc.html即可进入
配置 apifox 中环境变量
调试:
可以成功
Swagger 常用注解
注解说明(OpenAPI3 规范)
@Tag
用于说明或定义的标签。
部分参数:
name:名称
description:描述
@Schema
用于描述实体类属性的描述、示例、验证规则等,比如 POJO 类及属性。
部分参数:
name:名称
title:标题
description:描述
example:示例值
required:是否为必须
format:属性的格式。如 @Schema(format = "email")
maxLength 、 minLength:指定字符串属性的最大长度和最小长度
maximum 、 minimum:指定数值属性的最大值和最小值
pattern:指定属性的正则表达式模式
type: 数据类型(integer,long,float,double,string,byte,binary,boolean,date,dateTime,password),必须是字符串。如 @Schema=(type="integer")
implementation :具体的实现类,可以是类本身,也可以是父类或实现的接口
@Content
内容注解。
部分参数:
mediaType:内容的类型。比如:application/json
schema:内容的模型定义,使用 @Schema 注解指定模型的相关信息。
@RequestBody(content = @Content(mediaType = "application/json", schema = @Schema(implementation = User.class)))
@PostMapping("/users")
public void createUser(User user) {
// ...
}
@Hidden
某个元素(API 操作、实体类属性等)是否在 API 文档中隐藏。
如,getUserById 方法不会显示在 API 文档中
使用在实体类字段中,实现对敏感信息或不需要公开的元素进行隐藏。如:用户密码字段
@Operation
描述 API 操作的元数据信息。常用于 controller 上
部分参数:
summary:简短描述
description :更详细的描述
hidden:是否隐藏
tags:标签,用于分组API
operationId:操作的唯一标识符,建议使用唯一且具有描述性的名称
parameters:指定相关的请求参数,使用 @Parameter 注解来定义参数的详细属性。
requestBody:指定请求的内容,使用 @RequestBody 注解來指定请求的类型。
responses:指定操作的返回内容,使用 @ApiResponse 注解定义返回值的详细属性。
@Parameter
用于描述 API 操作中的参数
部分参数:
name : 指定的参数名
in:参数来源,可选 query、header、path 或 cookie,默认为空,表示忽略
ParameterIn.QUERY 请求参数
ParameterIn.PATH 路径参数
ParameterIn.HEADER header参数
ParameterIn.COOKIE cookie 参数
description:参数描述
required:是否必填,默认为 false
schema :参数的数据类型。如 schema = @Schema(type = "string")
@Parameters
包含多个 @Parameter 注解,指定多个参数。
代码参考:
包含了 param1 和 param2 两个参数
@RequestBody
API 请求的注解
description:请求信息的描述
content:请求的内容
required:是否必须
@ApiResponse
API 的响应信息。
部分参数:
responseCode:响应的 HTTP 状态码
description:响应信息的描述
content:响应的内容