springboot實現mock平臺的示例代碼

一、實現場景:

1.1請求同一個接口,不同的傳參/ip返回的結果不一樣。

數據的匹配

以create_account接口為例,參數有accountId
accountId=123,返回成功
accountId=456,返回失敗
accountId=456,accountName=zhangsan,返回處理中
ip=123.123.123.1 返回成功
ip=123.123.123.2 返回失敗

解決方案:

將數據存儲在yml文件裡。如create_account接口,隻返回一個固定的結果,那麼我們就將返回值放到一個yml文件裡。

如create_name接口,根據傳參不同,返回不同的id。一個接口對應一個文件夾, 將create_name接口的返回值寫多個yml文件,放到同一個文件夾裡。然後再去匹配。

1.2 返回的結果不是寫死的,是動態數據,需要對數據進行處理

  • response: {xxxxx,"orderId":123456}
  • response: {xxxxx,"orderId":123456}
  • response: {xxxxx,"createTime":123456}

1、 返回的數據中不能全部都是寫死的,有的可能是隨機的id,有的可能是時間戳,還有的可能是固定格式的數據

2、實際業務有一個case: 要返回merId:xxxx, 但是這個merId的獲取,是要從別的業務的接口中獲取返回信息。

1.3 回調能力

就是外部請求到我mock服務之後,我mock服務做瞭返回,但同時我會按照要求給它去完成某些能力,如:

  • 調http
  • 調公司內部的RPC
  • 或mq
  • 還有可能是寫某個db.

1.4響應時間

比如服務調我們的mock時,我們是直接給返回。

那要是模擬一下真實的服務處理,比如處理超時,假設用時 3秒在返回。

模擬超時處理

思考: 如果你做線上壓測的時候,相應時間不能給返回一個固定值,所以返回是一個區間的概率。

1.5 hook參數

比如請求的時候,請求參數攜帶一個requestId, 然後requestId本身還是個變化的,也是隨機的。

然後在返回的時候,要把這個id帶回去,即:雖然返回數據不能寫死,但是你也不能自己生成,需要使用請求的參數。

1.6 透傳請求

比如10個請求,請求mock服務,其中參數id=123的走mock,id=456的走真實的服務。

所以這個時候如果我們判斷id=456瞭,我們需要去自己真實的拿著請求的參數,我們再去調真實服務。

拿到返回結果,在返回給調用端。

總結:
其實就是把數據源放在文件裡,根據用戶的傳參,對數據進行處理,然後再返回。

二、依賴

springframework.boot 用的2.4.4版本

pom.xml

<?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>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.4</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>AutoApi</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>AutoApi</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
 
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.yaml</groupId>
            <artifactId>snakeyaml</artifactId>
            <version>1.26</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.16</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>30.1.1-jre</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.11</version>
        </dependency>
        <dependency>
            <groupId>com.squareup.okhttp3</groupId>
            <artifactId>okhttp</artifactId>
            <version>4.9.0</version>
        </dependency>
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.6</version>
        </dependency>
        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.8.6</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.dataformat</groupId>
            <artifactId>jackson-dataformat-yaml</artifactId>
            <version>2.12.3</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.3.8</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.20</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.6</version>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-core</artifactId>
            <version>5.7.5</version>
        </dependency>
 
    </dependencies>
 
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
 
</project>

三、開始寫

3.1 新建一個controller,簡單的建一個服務,試試是否能ping通

 

PingController

package com.example.mockserver.controller;
 
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
@RestController
public class PingController {
 
    @RequestMapping("/ping")
    public String ping(){
        return "ok";
 
    }
}

要有@RestController 註解

修改application.properties 格式,換成yml  application.yml 。並指定端口號。

application.yml

server:
  port: 8081

啟動spring boot ,運行 MockServerApplication 。訪問一下127.0.0.1:8081/ping。

返回ok就是正常的。

3.2   新建MockController1,/** 這裡指的是任意的URI

MockController1

package com.example.mockserver.controller;
 
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
@RestController
public class MockController1 {
 
    @RequestMapping("/**")
    public String doMock(){
        return "do mock server";
    }
}

"/**" 這裡指的是任意的URI 。啟動服務,當請求ping時返回ok,請求其他任何URL時,返回 do mock server

到此這篇關於springboot實現mock平臺的示例代碼的文章就介紹到這瞭,更多相關springboot實現mock 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: