Django request.META.get()獲取不到header頭的原因分析
在使用Django過程中需要開發(fā)一些API給其他系統(tǒng)使用,為了安全把Token等驗(yàn)證信息放在header頭中。
如何獲?。?p>使用request.META.get('headerkey')來獲取注意:如果headerkey為auth-token,即headers={’auth-token’:’1234’}
應(yīng)該使用request.META.get('HTTP_AUTH_TOKEN')獲取
headerkey中的小寫轉(zhuǎn)為大寫,橫線“-”轉(zhuǎn)為下劃線“_”,并且加上前綴HTTP
尤其注意headerkey中不應(yīng)該包含 HTTP前綴,以及符號(hào)'_',否則會(huì)取不到對(duì)應(yīng)的值
補(bǔ)充:Django中獲取參數(shù)(路徑,查詢,請(qǐng)求頭,請(qǐng)求體)
一、通常HTTP協(xié)議向服務(wù)器傳參有幾種途徑提取URL的特定部分,如/weather/shanghai/2018,可以在服務(wù)器端的路由中用正則表達(dá)式截取;
查詢字符串(query string),形如key1=value1&key2=value2;
請(qǐng)求體(body)中發(fā)送的數(shù)據(jù),比如表單數(shù)據(jù)、json、xml;
在http報(bào)文的頭(header)中。
1.URL中參數(shù)的獲取在定義路由URL時(shí),可以使用正則表達(dá)式提取參數(shù)的方法從URL中獲取請(qǐng)求參數(shù),Django會(huì)將提取的參數(shù)直接傳遞到視圖的傳入?yún)?shù)中。
1. 1未命名參數(shù)按定義順序傳遞
注意:參數(shù)獲取的順序與url中參數(shù)的位置一一對(duì)應(yīng),不能互換
url(r’^users/([a-z]+)/(d{4})/$’, views.get_user), def get_user(request, name, ID): print(’name=%s’ % name) print(’id=%s’ % id) return HttpResponse(’OK’)
1.2 命名參數(shù)按名字傳遞
注意:如果在路由中指定了參數(shù)的名字,name接收參數(shù)時(shí),必須要使用路由中指定的參數(shù)名稱,不能換成其他名字,此時(shí),兩個(gè)參數(shù)位置可以互換。
url(r’^users/(?P<name>[a-z]+)/(?P<id>d{4})/$’, views.users), def weather(request, name, id): print(’name=%s’ % name) print(’id=%s’ % id) return HttpResponse(’OK’)2.獲取請(qǐng)求路徑中的查詢字符串參數(shù)
(形如?k1=v1&k2=v2),可以通過request.GET屬性獲取,返回QueryDict對(duì)象。
什么是QueryDict對(duì)象?
定義在django.http.QueryDict
HttpRequest對(duì)象的屬性GET、POST都是QueryDict類型的對(duì)象
與python字典不同,QueryDict類型的對(duì)象用來處理同一個(gè)鍵帶有多個(gè)值的情況
2.1方法get():根據(jù)鍵獲取值
如果一個(gè)鍵同時(shí)擁有多個(gè)值將獲取最后一個(gè)值
如果鍵不存在則返回None值,可以設(shè)置默認(rèn)值進(jìn)行后續(xù)處理
dict.get(’key’,value)==>可簡(jiǎn)寫為: dict[’key’]
2.2方法getlist():根據(jù)鍵獲取值,值以列表返回,可以獲取指定鍵的所有值
如果鍵不存在則返回空列表[],可以設(shè)置默認(rèn)值進(jìn)行后續(xù)處理
dict.getlist(’鍵’,默認(rèn)值)
2.3獲取參數(shù)實(shí)例
訪問路徑:/user/qs/?a=1&b=2&a=3
注意:查詢字符串不區(qū)分請(qǐng)求方式,客戶端GET,POST方式的請(qǐng)求,都可以通過request.GET獲取請(qǐng)求中的查詢字符串?dāng)?shù)據(jù)。
url(r’^qs/$’,views.get_value,name=’g_v’), def get_value(request): a = request.GET.get(’a’) #3 b = request.GET.get(’b’) #2 num_list = request.GET.getlist(’a’) #[’1’,’3’] print(a) print(b) print(num_list) return HttpResponse(reverse(’user:get_value’))3.請(qǐng)求體中的參數(shù)
3.1表單數(shù)據(jù)獲取
通過request.POST來獲取
注意:Django默認(rèn)開啟了CSRF防護(hù),會(huì)對(duì)上述請(qǐng)求方式進(jìn)行CSRF防護(hù)驗(yàn)證,在開發(fā)測(cè)試時(shí)可以關(guān)閉CSRF防護(hù)機(jī)制,方法為在settings.py文件中注釋掉CSRF中間件
url(r’^getbody/$’,views.get_body), def get_body(request): form_data = request.POST.get(’c’) print(form_data) return HttpResponse(form_data)
3.2非表單數(shù)據(jù)獲取
非表單類型的請(qǐng)求體數(shù)據(jù),Django無法自動(dòng)解析,可以通過request.body屬性獲取最原始的請(qǐng)求體數(shù)據(jù),自己按照請(qǐng)求體格式(JSON、XML等)進(jìn)行解析。request.body返回bytes類型
import json url(r’^getjson/$’,views.get_body_json), def get_body_json(request): # 得到的是一個(gè)二進(jìn)制數(shù)據(jù) json_str = request.body print(json_str) # b’{n 'f':200,n 'd':300n n}’ # 對(duì)二進(jìn)制數(shù)據(jù)進(jìn)行解碼,解碼得到j(luò)son數(shù)據(jù) json_str = json_str.decode() print(json_str) # {'f':200,'d':300} # 將json數(shù)據(jù)轉(zhuǎn)化成字典形式 json_data = json.loads(json_str) print(json_data) # {’f’: 200, ’d’: 300} # 獲取json數(shù)據(jù),使用字典方式取值 print(json_data[’d’]) # 300 print(json_data[’f’]) # 200 return HttpResponse(’ok’)4.例如:Django獲取http請(qǐng)求頭內(nèi)容
通過view函數(shù)傳遞過來的 reuqest,使用request.META.get('header key')來獲取
注意:
header key必須大寫,前綴必須是'HTTP',后面如果連接符是橫線“-”,要改成下劃線“_”。例如你的header的key為api_auth,那在Django中應(yīng)該使用request.META.get('HTTP_API_AUTH')來獲取請(qǐng)求頭的數(shù)據(jù)。
5.其他常用HttpRequest對(duì)象屬性request.method 請(qǐng)求方式
request.path 請(qǐng)求路徑
request.user 請(qǐng)求的用戶對(duì)象
request.FILES 一個(gè)類似于字典的對(duì)象,包含所有的上傳文件
request.encoding 一個(gè)字符串,表示請(qǐng)求的頁(yè)面的完整路徑,不包含域名和參數(shù)部分。
url(r’^otherattr/$’, views.other_attr), def other_attr(request): print(request.method) # POST print(request.path) # /user/otherattr/ print(request.encoding) # None:表示使用瀏覽器的默認(rèn)設(shè)置,一般為utf-8,這個(gè)屬性是可寫的, # 可以通過修改它來修改訪問表單數(shù)據(jù)使用的編碼,接下來對(duì)屬性的任何訪問將使用新的encoding值。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. 使用css實(shí)現(xiàn)全兼容tooltip提示框2. SpringBoot快速集成jxls-poi(自定義模板,支持本地文件導(dǎo)出,在線文件導(dǎo)出)3. 使用ProcessBuilder調(diào)用外部命令,并返回大量結(jié)果4. 通過工廠模式返回Spring Bean方法解析5. JSP實(shí)現(xiàn)客戶信息管理系統(tǒng)6. 關(guān)于Mysql-connector-java驅(qū)動(dòng)版本問題總結(jié)7. python中HTMLParser模塊知識(shí)點(diǎn)總結(jié)8. CSS自定義滾動(dòng)條樣式案例詳解9. python 批量下載bilibili視頻的gui程序10. python:刪除離群值操作(每一行為一類數(shù)據(jù))
