不少想學習接口測試的同窗,可能在最開始的時候,經常會因沒有能夠練習的項目而苦惱,畢竟網上能夠練習的接口項目很少,有些可能太簡單了,有些可能又太複雜了,或者是網上一些免費接口請求次數有限制,最終致使這些同窗遲遲沒法進行實踐。html
就拿我之前在練習JMeter時所用到的接口(相關連接:Jmeter接口測試實例-牛刀小試
),由於是網上別人開發的接口,有時候常常因各類緣由致使沒法正常使用,因而,我就想到爲何不能夠本身開發一個簡單的接口項目,來知足日常的練習呢?python
由於目前使用Python比較普遍,考慮到Django比較笨重性,而我目前畢竟只是想開發一些簡單接口,因而我選擇了Flask。Flask是一個使用 Python 編寫的輕量級 Web 應用框架,它很是容易上手,咱們準備使用它來開發一個簡單的接口項目。web
在Python下,能夠直接經過 pip
工具來進行安裝,而在我環境下由於同時安裝了python2和python3,因此用 pip3
來區分,安裝命令:pip3 install Flask
,若是想要查看當前Flask版本信息,可使用命令:pip3 show flask
,我目前使用的版本是 1.0.3
。數據庫
[root@wintest ~]# pip3 show flask Name: Flask Version: 1.0.3 Summary: A simple framework for building complex web applications. Home-page: https://www.palletsprojects.com/p/flask/ Author: Armin Ronacher Author-email: armin.ronacher@active-4.com License: BSD Location: /root/python36/lib/python3.6/site-packages Requires: itsdangerous, Jinja2, click, Werkzeug Required-by: [root@wintest ~]#
爲了更好的學習Flask,咱們能夠在網上找到Flask的官方文檔和中文文檔,以便進一步學習。json
Flask官方文檔(1.0.x版本):https://flask.palletsprojects.com/en/1.0.x/
Flask中文文檔(最新版):https://dormousehole.readthedocs.io/en/latest/flask
from flask import Flask app = Flask(__name__) @app.route('/') def hello_world(): return 'Hello, World!'
上面是Flask官方提供的一個最簡單的Flask應用,在PyCharm中,咱們點擊左上方的 file
,選擇 New Project
,建立一個Flask項目。api
在建立的項目中,會存在一個 app.py
文件,該文件裏便包含了最簡單的Flask應用代碼。瀏覽器
咱們執行代碼啓動Flask應用,能夠看到以下信息:app
能夠發現,Flask應用的默認端口是 5000
,咱們打開本地瀏覽器,輸入 http://127.0.0.1:5000/
,即可以看到在界面上顯示一行內容:Hello World!。框架
這是一個最簡單的接口,用Flask實現只用了5行代碼,可見Flask上手起來並不難。接下來,咱們將會使用Flask來開發2個GET接口:獲取全部用戶信息接口和獲取某個用戶信息接口。
咱們建立一個 Python包 ,包名設置爲 api
,表示將用於存放後續編寫的接口。在該包下新建一個 user.py
文件,這個文件用於編寫用戶相關的接口。
data = [ {"id": 1, "username": "小明", "password": "123456", "role": 0, "sex": 0, "telephone": "10086", "address": "北京市海淀區"}, {"id": 2, "username": "李華", "password": "abc", "role": 1, "sex": 0, "telephone": "10010", "address": "廣州市天河區"}, {"id": 3, "username": "大白", "password": "666666", "role": 0, "sex": 1, "telephone": "10000", "address": "深圳市南山區"} ]
上面是咱們準備的用戶數據,由於咱們暫沒用到數據庫,因此本身定義了一個列表,列表下存放多個用戶信息,而每一個用戶信息,則經過字典來存儲。每一個字典均含有 id、username、password、telphone、address 等鍵名和鍵值。
咱們在接口返回數據時,咱們會定義一個字典,設置了接口返回碼code、接口返回信息msg、返回數據實體data,用字典將這幾個數據存儲,並返回顯示到頁面上。
若是咱們直接把這個定義的字典返回,在請求的時候就會出現報錯:
TypeError: 'dict' object is not callable
,爲解決這個問題,咱們須要將這樣的字典數據轉換爲JSON字符串,而後才能正常向頁面返回。
通常狀況,要返回JSON格式數據,咱們能夠直接使用 json
模塊的 json.dumps()
方法,將字典轉換爲json字符串,而後返回 。
# 使用python的json模塊 import json json.dumps({"code":"0", "msg":"操做成功", "data":data})
但在Flask中,提供了jsonify方法供用戶處理返回的序列化json數據,咱們能夠直接導入該方法並進行使用。
# 使用Flask的jsonify方式 from flask import Flask,jsonify jsonify({"code":"0", "msg":"操做成功", "data":data})
在這裏,咱們將直接使用Flask的jsonify方式來處理返回的數據,須要注意的一點,使用該方法會把返回的 Content-Type
從 text/html
轉換成帶json特徵的 application/json
。
@app.route("/users", methods=["GET"]) def get_all_users(): """獲取全部用戶信息""" return jsonify({"code":"0", "data":data, "msg":"操做成功"})
這裏的代碼表示,當咱們在請求路徑爲 /users
,且請求方法爲GET方式時,纔會執行 get_all_users
接口,最後才能返回JSON數據。
Flask的請求默認是GET請求,也就是說 @app.route()
中,咱們能夠不寫 methods
參數,但這樣只能經過GET方式來發出請求。若是須要支持其餘的請求方式,那麼這裏的 methods 須要寫成一個列表,固然也能夠同時支持 GET、POST等請求方式,好比 methods=["GET", "POST"]
表示既支持GET方式也支持POST方式的請求。
@app.route("/users/<int:user_id>", methods=["GET"]) def get_user(user_id): """獲取某個用戶信息""" if user_id > 0 and user_id <= len(data): return jsonify({"code": "0", "data": data[user_id - 1], "msg": "操做成功"}) return jsonify({"code": "1", "msg": "用戶不存在"})
在這裏,咱們的請求URL中有變量(由於須要獲取指定的用戶信息),對於變量,咱們須要使用 <>
,如 <user_id>
,這樣就能夠將這些特殊部分標記爲變量名。
在上面代碼中,咱們使用的是
<int:user_id>
,這裏用到了Flask自帶的路由轉換器int
,表示接收到的 user_id 是整數類型,若是不加的話,那麼就默認是string
轉換器。
而咱們獲取到指定的用戶信息,則是用 data[user_id - 1]
來實現,好比要獲取到data中第2條用戶信息,那麼用data[1]就能夠獲得,另外,若是請求的 user_id 不在當前範圍的,則是直接返回用戶不存在的JSON數據。。
完成以上內容後,咱們運行代碼,而後到Chrome瀏覽器上進行請求。
這裏在Chrome瀏覽器中文顯示爲了Unicode字符編碼,雖然不影響接口的讀取,可是可讀性很差啊,因而須要在代碼中作簡單處理,直接加一行代碼便可:
app.config["JSON_AS_ASCII"] = False # jsonify返回的中文正常顯示
最後,再次進行請求,就能夠獲得想要的數據了。
源碼附上:
from flask import Flask, jsonify app = Flask(__name__) app.config["JSON_AS_ASCII"] = False # jsonify返回的中文正常顯示 data = [ {"id": 1, "username": "小明", "password": "123456", "role": 0, "sex": 0, "telephone": "10086", "address": "北京市海淀區"}, {"id": 2, "username": "李華", "password": "abc", "role": 1, "sex": 0, "telephone": "10010", "address": "廣州市天河區"}, {"id": 3, "username": "大白", "password": "666666", "role": 0, "sex": 1, "telephone": "10000", "address": "深圳市南山區"} ] @app.route('/') def hello_world(): return 'Hello World!' @app.route("/users", methods=["GET"]) def get_all_users(): """獲取全部用戶信息""" return jsonify({"code": "0", "data": data, "msg": "操做成功"}) @app.route("/users/<int:user_id>", methods=["GET"]) def get_user(user_id): """獲取某個用戶信息""" if user_id > 0 and user_id <= len(data): return jsonify({"code": "0", "data": data[user_id - 1], "msg": "操做成功"}) return jsonify({"code": "1", "msg": "用戶不存在"}) if __name__ == '__main__': app.run()