使用django怎么實現(xiàn)API接口的互相調用?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
秭歸ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!url = "http://%s:%s/api-token-auth/" % (ip, port) query_args = { "username": username, "password": password } resp = requests.post(url=url, data=query_args) token = json.loads(resp.text)["token"] headers = {"Authorization": "JWT" + " " + token} # 拿到token,拼成headers post_url = "http://%s:%s/message/message-level-two/"% (ip, port) data = { "app": app, "url": url, "message_id": message_id, "head": head, "title": title, "userprofile_id_list": userprofile_id_list } headers = self.headers requests.post(url=post_url, data=data, headers=headers)
獲取當前請求的ip和端口
host_ip, host_port = self.request.META.get("HTTP_HOST").split(':')[0], \ self.request.META.get("HTTP_HOST").split(':')[1]
常見的請求頭如下:
CONTENT_LENGTH – The length of the request body (as a string).
CONTENT_TYPE – The MIME type of the request body.
HTTP_ACCEPT – Acceptable content types for the response.
HTTP_ACCEPT_ENCODING – Acceptable encodings for the response.
HTTP_ACCEPT_LANGUAGE – Acceptable languages for the response.
HTTP_HOST – The HTTP Host header sent by the client.
HTTP_REFERER – The referring page, if any.
HTTP_USER_AGENT – The client's user-agent string.
QUERY_STRING – The query string, as a single (unparsed) string.
REMOTE_ADDR – The IP address of the client.
REMOTE_HOST – The hostname of the client.
REMOTE_USER – The user authenticated by the Web server, if any.
REQUEST_METHOD – A string such as "GET" or "POST".
SERVER_NAME – The hostname of the server.
SERVER_PORT – The port of the server (as a string).
獲取請求頭內(nèi)容的用META
示例:
def index(request): ip = request.META.get("REMOTE_ADDR") return HttpResponse("你的ip地址是%s"%ip)
http://10.254.30.27/1
self.kwargs[‘pk'] # 可以拿到后邊的 1
補充知識:django 使用requests請求相關接口
1、如果是get請求接口,并且需要帶相關參數(shù)的話,可以借鑒下面的代碼:
import requests from django.http import JsonResponse def get_info(request): url = 'http://www.baidu.com' params = {'id': 1, 'user': 'lin'} response = requests.get(url=url, params=params) return JsonResponse(response.text, safe=False)
這樣將會返回一串json的字符串數(shù)據(jù)。
2、如果是post請求接口,并且需要帶相關參數(shù)的話,可以借鑒下面的代碼:
import requests from json import dumps from django.http import JsonResponse def get_info(request): url = 'http://www.baidu.com' data = {'id': 1, 'user': 'lin'} response = requests.post(url=url, data=dumps(data)) return JsonResponse(response.text, safe=False)
注:
(1)、其中必須注意的為data這個參數(shù),必須要用dumps(data)轉換一下,不然會報錯,response狀態(tài)碼為400,bad request error 400 while using python requests.post function。
(2)、如果需要在post請求底下加相關請求頭的話,可以借鑒下面的代碼:
import requests from json import dumps from django.http import JsonResponse def get_info(request): url = 'http://www.baidu.com' data = {'id': 1, 'user': 'lin'} headers = {'content-Type': 'application/json', 'Accept': '*/*'} response = requests.post(url=url, data=dumps(data), headers=headers) return JsonResponse(response.text, safe=False)
這里如果response的狀態(tài)碼報415錯誤的話,即HTTP請求415錯誤 – 不支持的媒體類型(Unsupported media type),這就是content-Type可能寫錯了,就要注意一下了,因為通常接口會封裝一些參數(shù)到請求頭底下。
看完上述內(nèi)容,你們掌握使用django怎么實現(xiàn)API接口的互相調用的方法了嗎?如果還想學到更多技能或想了解更多相關內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!