Django 自動(dòng)生成api接口文檔教程
最近在寫(xiě)測(cè)試平臺(tái),需要實(shí)現(xiàn)一個(gè)節(jié)點(diǎn)服務(wù)器的api,正好在用django,準(zhǔn)備使用djangorestframework插件實(shí)現(xiàn)。
需求
實(shí)現(xiàn)一個(gè)接口,在調(diào)用時(shí),通過(guò)傳遞的參數(shù),直接運(yùn)行對(duì)應(yīng)項(xiàng)目的自動(dòng)化測(cè)試
環(huán)境
Python3.6 ,PyCharm,W7
項(xiàng)目結(jié)構(gòu)
功能實(shí)現(xiàn)
流程
我們要做的就是實(shí)現(xiàn)以上流程
安裝
pip install djangorestframework pip install markdown pip install django-filter # Filtering support
配置
INSTALLED_APPS = ( ... 'rest_framework', )
編寫(xiě)代碼(本次代碼不涉及數(shù)據(jù)庫(kù)操作,只簡(jiǎn)單的寫(xiě)一個(gè)api)
①:打開(kāi)AutoApi/Api/views.py 編寫(xiě)如下代碼
from django.http import JsonResponse, HttpResponseNotAllowed, HttpResponse from django.views.decorators.csrf import csrf_exempt from rest_framework.parsers import JSONParser from rest_framework import status @csrf_exempt def run_job(request): # 判斷請(qǐng)求頭是否為json if request.content_type != 'application/json': # 如果不是的話(huà),返回405 return HttpResponse('only support json data', status=status.HTTP_415_UNSUPPORTED_MEDIA_TYPE) # 判斷是否為post 請(qǐng)求 if request.method == 'POST': try: # 解析請(qǐng)求的json格式入?yún)? data = JSONParser().parse(request) except Exception as why: print(why.args) else: content = {'msg': 'SUCCESS'} print(data) # 返回自定義請(qǐng)求內(nèi)容content,200狀態(tài)碼 return JsonResponse(data=content, status=status.HTTP_200_OK) # 如果不是post 請(qǐng)求返回不支持的請(qǐng)求方法 return HttpResponseNotAllowed(permitted_methods=['POST'])
②:打開(kāi)AutoApi/Api/urls.py 編寫(xiě)如下代碼
from django.conf.urls import url from Api import views urlpatterns = [ url(r'^runJob/$',views.run_job), ]
③:打開(kāi)AutoApi/AutoApi/urls.py 修改如下代碼
ALLOWED_HOSTS = '*' # 修改為* 代碼允許任意host from django.conf.urls import url,include urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^',include('Api.urls')),# 新增 ]
④:啟動(dòng)服務(wù)
python manage.py runserver 0.0.0.0:8080
⑤:我們請(qǐng)求試試看
以上就是簡(jiǎn)單的實(shí)現(xiàn)一個(gè)api ,其實(shí)開(kāi)發(fā)說(shuō)的接口就這么簡(jiǎn)單,沒(méi)有那么神秘!
接下來(lái)把post 的數(shù)據(jù)env ,project,cases 解析出來(lái)傳給對(duì)應(yīng)的自動(dòng)化測(cè)試入口函數(shù),就可以實(shí)現(xiàn)通過(guò)接口請(qǐng)求,啟動(dòng)自動(dòng)化測(cè)試的目的。
后續(xù)
實(shí)現(xiàn)接口調(diào)用自動(dòng)化測(cè)試項(xiàng)目
實(shí)現(xiàn)異步接口
實(shí)現(xiàn)定時(shí)任務(wù)
這篇Django 自動(dòng)生成api接口文檔教程就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python學(xué)習(xí)筆記之列表推導(dǎo)式實(shí)例分析
這篇文章主要介紹了Python學(xué)習(xí)筆記之列表推導(dǎo)式,結(jié)合實(shí)例形式分析Python列表推導(dǎo)式的原理、寫(xiě)法與相關(guān)使用技巧,需要的朋友可以參考下2019-08-08Python多進(jìn)程與服務(wù)器并發(fā)原理及用法實(shí)例分析
這篇文章主要介紹了Python多進(jìn)程與服務(wù)器并發(fā)原理及用法,深入淺出的介紹了進(jìn)程、并行、并發(fā)、同步、異步等相關(guān)概念與原理,并結(jié)合實(shí)例形式給出了Python多進(jìn)程編程相關(guān)操作技巧,需要的朋友可以參考下2018-08-08pytorch無(wú)法使用GPU問(wèn)題的解決方法
這篇文章主要介紹了如何解決pytorch 無(wú)法使用GPU 的問(wèn)題,文中通過(guò)代碼和圖文給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-02-02Python中類(lèi)變量和實(shí)例變量的區(qū)別
這篇文章主要介紹了Python中類(lèi)變量和實(shí)例變量的區(qū)別,文章針對(duì)Python類(lèi)變量和實(shí)例變量的問(wèn)題,給出了具體說(shuō)明和演示,需要的小伙伴可以參考一下2022-02-02使用python list 查找所有匹配元素的位置實(shí)例
今天小編就為大家分享一篇使用python list 查找所有匹配元素的位置實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06Python進(jìn)程間通信Queue消息隊(duì)列用法分析
這篇文章主要介紹了Python進(jìn)程間通信Queue消息隊(duì)列用法,結(jié)合實(shí)例形式分析了基于Queue的進(jìn)程間通信相關(guān)操作技巧與使用注意事項(xiàng),需要的朋友可以參考下2019-05-05