springboot苍穹外卖实战:二、nginx反向代理和负载均衡配置+MD5加密+Apifox导入接口文档+Swagger(knife4j版、含常用接口注解)

本专栏只是黑马课程的相关笔记,个人自学使用,请支持B站上黑马的原版视频。
该文章对应视频Day01-09到Day01-14(含14)。

nginx反向代理和负载均衡

观察项目代码,我们可以发现
前端请求地址:http://localhost/api/employee/login
后端接口地址:http://localhost:8080/admin/employee/login
很明显,两个地址不一致,那是如何请求到后端服务的呢?

这便是通过nginx来反向代理,前端的请求通过nginx转发给后端,从而实现前后端不同的地址之间的映射。

前后端接口地址

具体怎么看的前端的接口地址呢,其实我们执行登录操作的时候可以抓一下包。
在这里插入图片描述

具体怎么看的后端接口地址,是如下代码
在这里插入图片描述

nginx反向代理和负载均衡的配置

反向代理的配置

server{
    listen 80;
    server_name localhost;
    
    location /api/{
        proxy_pass http://localhost:8080/admin/; #反向代理
    }
}

如上代码的含义是:监听80端口号, 当我们访问 http://localhost:80/api/../..这样的接口的时候,它通过了 location /api/ {} 这样的匹配,从而被nginx反向代理到 http://localhost:8080/admin/上来。

负载均衡配置

upstream webservers{
    server 192.168.100.128:8080;
    server 192.168.100.129:8080;
}
server{
    listen 80;
    server_name localhost;
    
    location /api/{
        proxy_pass http://webservers/admin;#负载均衡
    }
}

upstream:如果代理服务器是一组服务器的话,我们可以使用upstream指令配置后端服务器组。其后面的名称可自定义,如这里的webservers,但要上下保持一致。

如上代码的含义是:监听80端口号, 当我们访问 http://localhost:80/api/../..这样的接口的时候,它会通过 location /api/ {} 这样的反向代理到 http://webservers/admin,同时根据webservers名称找到一组服务器,根据设置的负载均衡策略(默认是轮询)转发到具体的服务器。

nginx反向代理的优势和负载均衡策略和对应配置

那为什么不直接通过浏览器直接请求后台服务端,需要通过nginx反向代理呢?

nginx反向代理的优势如下

  • 提高访问速度

    因为nginx本身可以进行缓存,如果访问的同一接口,并且做了数据缓存,nginx就直接可把数据返回,不需要真正地访问服务端,从而提高访问速度。

  • 进行负载均衡

    所谓负载均衡,就是把大量的请求按照我们指定的方式均衡的分配给集群中的每台服务器。

  • 保证后端服务安全

    把nginx作为请求访问的入口,请求到达nginx后转发到具体的服务中,从而保证后端服务的安全。

nginx 负载均衡策略:

名称说明
轮询默认方式
weight权重方式,默认为1,权重越高,被分配的客户端请求就越多
ip_hash依据ip分配方式,这样每个访客可以固定访问一个后端服务
least_conn依据最少连接方式,把请求优先分配给连接数少的后端服务
url_hash依据url分配方式,这样相同的url会被分配到同一个后端服务
fair依据响应时间方式,响应时间短的服务将会被优先分配

轮询:

upstream webservers{
    server 192.168.100.128:8080;
    server 192.168.100.129:8080;
}

weight:

upstream webservers{
    server 192.168.100.128:8080 weight=90;
    server 192.168.100.129:8080 weight=10;
}

ip_hash:

upstream webservers{
    ip_hash;
    server 192.168.100.128:8080;
    server 192.168.100.129:8080;
}

least_conn:

upstream webservers{
    least_conn;
    server 192.168.100.128:8080;
    server 192.168.100.129:8080;
}

url_hash:

upstream webservers{
    hash &request_uri;
    server 192.168.100.128:8080;
    server 192.168.100.129:8080;
}

fair:

upstream webservers{
    server 192.168.100.128:8080;
    server 192.168.100.129:8080;
    fair;
}

MD5加密

此时我们代码还存在一些问题,譬如员工表中的密码是明文存储,安全性太低。所以我们修改数据库中明文密码,改为MD5加密后的密文。

打开employee表,修改密码123456为

e10adc3949ba59abbe56e057f20f883e

注意不要用回车或者空格,直接点更新即可。

找到项目中的TODO,然后加入加密代码:

// TODO 后期需要进行md5加密,然后再进行比对
        password = DigestUtils.md5DigestAsHex(password.getBytes());

Apifox导入接口文档

Apifox是在设计阶段使用的工具,用来管理和维护接口。

在Apifox中新建两个HTTP项目,分别为“苍穹外卖管理端”和“苍穹外卖用户端”。
然后ctrl+o打开接口设置的导入。或者通过如下方式打开:
在这里插入图片描述
然后选择YApi格式,将资料中的day02的“项目接口”的两个json文档,分别拖拽到两个项目的这个页面进行导入,随后发现两个项目中新增接口。
在这里插入图片描述

Swagger(knife4j版)

Swagger 是在开发阶段使用的框架,帮助后端开发人员做后端的接口测试

导入依赖

在初始工程中sky-take-outpom.xml已经导入了。

<dependency>
   <groupId>com.github.xiaoymin</groupId>
   <artifactId>knife4j-spring-boot-starter</artifactId>
</dependency>

配置类添加配置并设置静态资源映射

sky-servcer下的com.sky.config.WebMvcConfiguration添加配置,初始工程也已经添加了。

/**
     * 通过knife4j生成接口文档
     * @return
*/
    @Bean
    public Docket docket() {
        ApiInfo apiInfo = new ApiInfoBuilder()
                .title("苍穹外卖项目接口文档")
                .version("2.0")
                .description("苍穹外卖项目接口文档")
                .build();
        Docket docket = new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo)
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.sky.controller"))
                .paths(PathSelectors.any())
                .build();
        return docket;
    }

sky-servcer下的com.sky.config.WebMvcConfiguration添加配置,初始工程也已经添加了。
设置静态资源映射

/**
     * 设置静态资源映射
     * @param registry
*/
protected void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/doc.html").addResourceLocations("classpath:/META-INF/resources/");
        registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
}

测试

浏览器中输入http://localhost:8080/doc.html,发现如下页面即测试成功。
在这里插入图片描述

常用注解

通过注解可以控制生成的接口文档,使接口文档拥有更好的可读性,常用注解如下:

注解说明
@Api用在类上,例如Controller,表示对类的说明
@ApiModel用在类上,例如entity、DTO、VO
@ApiModelProperty用在属性上,描述属性信息
@ApiOperation用在方法上,例如Controller的方法,说明方法的用途、作用
### 如何使用 Apifox 进行苍穹外卖接口测试 #### 准备工作 为了顺利进行接口测试,需先完成以下准备工作: - 安装并登录 Apifox 平台。 - 获取项目所需的 JSON 文件,通常由开发者提供或通过其他方式获得。 #### 导入接口文档 按照描述的操作指南[^1],在 Apifox导入 Yapi 格式的接口文档: 1. 打开 Apifox 后进入目标项目页面; 2. 点击左侧菜单栏中的“API 文档”,再点击右上角的`+`按钮选择“导入”选项; 3. 在弹出窗口内选取“Yapi”的导入模式,并上传准备好的 `JSON` 文件(如苍穹外卖管理端接口.json 用户端.json),随后确认提交即可成功加载所有相关接口信息到平台中。 #### 创建 API 测试用例 基于已有的接口列表创建具体的测试场景。对于每一个待测接口而言,应当明确其请求参数、响应预期以及可能存在的异常情况处理逻辑等内容。具体步骤如下所示: - **设置基本信息** - 选定要测试的目标接口。 - 输入名称与描述以便于识别该条目下的各项配置项。 - **构建请求体结构** - 对应不同的 HTTP 方法类型(GET/POST/PATCH...)填写相应的 URL 路径变量及查询字符串;如果是 POST 请求,则还需指定 Content-Type 头部字段值为 application/json 或 multipart/form-data 等形式之一,并附带实际发送的数据负载部分。 - **定义断言规则** - 设置期望的状态码范围,默认情况下一般设定为 200 OK 表明服务器正常返回结果。 - 验证特定键名是否存在及其对应的取值是否符合预设条件,比如检查某个属性是否为空串或是数值大小处于合理区间之内等等。 - **执行前后的脚本编写** - 可选地加入 JavaScript 代码片段用于辅助自动化流程控制或其他自定义行为扩展目的,例如提前准备好模拟环境所需资源或者清理遗留状态防止干扰后续操作等动作。 ```javascript // 示例:前置脚本 - 自动生成时间戳作为唯一标识符附加至请求头当中 pm.environment.set('timestamp', new Date().getTime()); ``` ```javascript // 示例:后置脚本 - 将获取到的结果保存下来供关联性验证所用 const responseJson = pm.response.json(); pm.variables.set('order_id', responseJson.data.id); ``` #### 实施测试过程 当上述准备工作完成后就可以正式发起调用了。每次运行时会自动依据之前建立起来的一系列指令集依次向远程服务发出相应类型的网络请求并将得到的信息反馈回来显示出来便于观察分析。如果遇到失败情形也不要着急,仔细对照报错提示逐步排查直至解决问题为止。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

shanshandeisu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值