您好,登錄后才能下訂單哦!
這篇文章主要介紹了springboot如何實現mock平臺的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇springboot如何實現mock平臺文章都會有所收獲,下面我們一起來看看吧。
數據的匹配
以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文件,放到同一個文件夾里。然后再去匹配。
response: {xxxxx,"orderId":123456}
response: {xxxxx,"orderId":123456}
response: {xxxxx,"createTime":123456}
1、 返回的數據中不能全部都是寫死的,有的可能是隨機的id,有的可能是時間戳,還有的可能是固定格式的數據
2、實際業務有一個case: 要返回merId:xxxx, 但是這個merId的獲取,是要從別的業務的接口中獲取返回信息。
就是外部請求到我mock服務之后,我mock服務做了返回,但同時我會按照要求給它去完成某些能力,如:
調http
調公司內部的RPC
或mq
還有可能是寫某個db.
比如服務調我們的mock時,我們是直接給返回。
那要是模擬一下真實的服務處理,比如處理超時,假設用時 3秒在返回。
模擬超時處理
思考: 如果你做線上壓測的時候,相應時間不能給返回一個固定值,所以返回是一個區間的概率。
比如請求的時候,請求參數攜帶一個requestId, 然后requestId本身還是個變化的,也是隨機的。
然后在返回的時候,要把這個id帶回去,即:雖然返回數據不能寫死,但是你也不能自己生成,需要使用請求的參數。
比如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>
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就是正常的。
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平臺”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。