【接口自动化_12课_基于Flask搭建MockServer】
创始人
2024-12-28 20:11:24
0

知识非核心点,面试题较少。框架搭建的过程中的细节才是面试要点

 第三方接口,不方便进行测试,

自己要一个接口去进行模拟。去作为我们项目访问模拟接口。自己写一个接口,需要怎样写

一、flask:轻量级的web应用的框架

安装命令

pip install flask

1、flask-web应用

1)一个最简单的例子

flask轻量级应用--下面就是实现一个最简单的web应用----单页面

from flask import Flask, request  # 实例化一个应用,当前页面就是一个应用 app = Flask(__name__)   # 写接口 - 可以不写任何的逻辑,只返回正确的响应数据。  @app.route("/")# 通过装饰器设置对应的路由(路径)("/"表示当前的根目录) def index():     return "欢迎来到主页"   if __name__ == '__main__':     # 当你修改代码,并且保存之后,则自动更新代码     app.run(debug=True)

这个就是启动了一个应用 --可以理解是一个登录页面,无数据输入,还需要另外写一个数据输入的程序

本地启动后,可以在浏览器访问这个地址:http://127.0.0.1:5000

效果:

2)加上请求方法,post,提供给外部的接口和方法

然后,我们模拟一下请求四要素,再发起,相当于一个请求,此时再去看这个flask应用的日志,可以看到请求了

 

3)请求方法,get

2、 搭建一个登录应用

1)字符串模式的

1.1)搭建应用
from flask import Flask, request  # 实例化一个应用 app = Flask(__name__)  #  从数据库拿到的数据 all_user = {"username": "hami", "password": "123456"}   # 写接口 - 不写任何的逻辑,只返回正确的响应数据。 # 设置对应的路由(路径) @app.route("/") def index():     return "欢迎来到应用主页"   # 写一个登录接口, 开发指定的请求方法 @app.route("/api/login", methods=["POST"]) def login():     # 数据的获取:以json格式进行获取数据     res = request.get_json()     print("用户请求的数据是:", res)      # 用户填写的用户名和密码数据,key的话必须是username,password     username = res["username"]     password = res["password"]        # 判断数据的正确性:结合你们业务常用场景去写几个     """     测试场景有哪些?          1. 正确登录          2. 参数为空          3. 密码不正确          4. 用户名不正确          5. 参数填写错误     """   #业务场景如下:     if username == "" or password =="":         return "参数不能为空~"     elif username == all_user["username"] and password == all_user["password"]:         return "登录成功"     elif username == all_user["username"] and password != all_user["password"]:         return "密码错误"     elif username != all_user["username"]:         return "用户名不存在"     else:         return "对应的参数请求错误"   if __name__ == '__main__':     # 当你修改代码,并且保存之后,则自动更新代码     app.run(debug=True) 
1.2)创建请求,请求这个应用
import requests  #  登录接口 url = "http://127.0.0.1:5000/api/login" data = {"username": "hami", "password": "123456"} res = requests.post(url, json=data) print(res.text)
1.3)请求结果,以字符串形式返回

2)JSON模式的

2.1)搭建应用
from flask import Flask, request, jsonify from P12_Flask应用.MsgDome import *  # 实例化一个应用 app = Flask(__name__)  #  从数据库拿到的数据 all_user = {"username": "hami", "password": "123456"}   # 响应数据的模板:   # 写接口 - 不写任何的逻辑,只返回正确的响应数据。 # 设置对应的路由(路径) @app.route("/") def index():     return "欢迎来到主页"   # 写一个登录接口, 开发指定的请求方法 @app.route("/api/login", methods=["POST"]) def login():     # 数据的获取:以json格式进行获取数据     res = request.get_json()     print("用户请求的数据是:", res)      # 用户填写的用户名和密码数据,key的话必须是username,password     username = res["username"]     password = res["password"]        # 判断数据的正确性:结合你们业务常用场景去写几个     """     测试场景有哪些?          1. 正确登录          2. 参数为空          3. 密码不正确          4. 用户名不正确          5. 参数填写错误     """  #下面是以JSON的方式进行返回,下面的 MSG_是根据MsgDome来匹配的     if username == "" or password == "":         return jsonify(MSG_DATA_NULL)     elif username == all_user["username"] and password == all_user["password"]:         return jsonify(MSG_LOGIN_SUCCESS)     elif username == all_user["username"] and password != all_user["password"]:         return jsonify(MSG_ERROR_PASSWORD)     elif username != all_user["username"]:         return jsonify(MSG_ERROR_USERNAME)     else:         return MSG_DATA_ERROR   if __name__ == '__main__':     # 当你修改代码,并且保存之后,则自动更新代码     app.run(debug=True) 
2.2)创建请求
import requests import jsonpath  #这个程序是一个对flask应用发起请求的数据程序  #  登录接口 url = "http://127.0.0.1:5000/api/login" data = {"username": "ham", "password": "123456"} res = requests.post(url, json=data print(res.json())
2.3)请求结果,以JSON返回
    elif username != all_user["username"]:                  return jsonify(MSG_ERROR_USERNAME) #jsonify只是为了确定让返回结果都json化                 #return MSG_ERROR_USERNAME 这样也可以的。  

 如果还是用text返回,也能打印

 

开发把项目整好了, 部署到服务器  自己写的mock的服务也可以部署到服务器上。  服务器(linux) 和 win 基本操作一样。    部署环境环节:  1、安装python3的环境 2、jdk的环境 3、要安装对应的第三方模块

需要安装第三方包,比如sql

pip install pymysql -i https://pypi.tuna.tsinghua.edu.cn/simple

 

相关内容

热门资讯

玩家亲测!永胜联盟辅助软件(透... 玩家亲测!永胜联盟辅助软件(透视)2025新版(实用作弊开挂辅助安装);永胜联盟辅助软件简单的灵活控...
第七分钟透视“wepoker有... 第七分钟透视“wepoker有有挂规律”约局吧德州真的存在透视(详细开挂透视辅助神器)约局吧德州真的...
第二分钟了解!新祥心有挂,we... 第二分钟了解!新祥心有挂,wepoker是有人用挂,扑克教程(本然是真的有挂);新祥心有挂是一种具有...
八次性普及“九江讨赏辅助中至小... 八次性普及“九江讨赏辅助中至小程序”发现作弊开挂辅助app(真是有挂);八次性普及“九江讨赏辅助中至...
总算了解!同城乐吧乐享版510... 总算了解!同城乐吧乐享版510k辅助(辅助挂)分享教程(线上作弊开挂辅助软件)是一款可以让一直输的玩...
第九分钟透视“智星德州插件可以... 第九分钟透视“智星德州插件可以下载”hhpoker透视挂靠谱(推荐开挂透视辅助插件)1、用户打开应用...
一分钟了解!赣牌圈修改器,we... 一分钟了解!赣牌圈修改器,wepoker私人局透视教程,揭秘教程(从前是有挂);一、赣牌圈修改器AI...
六次性普及“指尖四川辅助破解版... 六次性普及“指尖四川辅助破解版”介绍作弊开挂辅助神器(确实是有挂);1、完成指尖四川辅助破解版的残局...
玩家爆料!哥哥打大a辅助(透视... 玩家爆料!哥哥打大a辅助(透视)安装教程(曝光作弊开挂辅助软件);哥哥打大a辅助最新版本免费下载安装...
5分钟透视“sohoo竞技联盟... 5分钟透视“sohoo竞技联盟辅助器”sohoo辅助(了解开挂透视辅助软件)一、sohoo竞技联盟辅...