響應對象有三種形式:
為城中等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及城中網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為網(wǎng)站制作、網(wǎng)站設計、城中網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
HttpResponse()
render()
Redirect()
django服務器接收到客戶端發(fā)來的請求之后,會將提交上來的數(shù)據(jù)封裝成一個HttpResponse對象傳給視圖函數(shù)。視圖函數(shù)在處理完相關邏輯之后,也需要一個返回響應給瀏覽器。而這個響應方式,我們必須通過返回HttpResponseBase或者其他子類的對象。
content:返回內(nèi)容
status:響應狀態(tài)碼
content_type:返回的數(shù)據(jù)的MIME類型,默認為 text/html 。瀏覽器會根據(jù)這個屬性,來顯示數(shù)據(jù)。如果是 text/html ,那么就會解析這個字符串,如果 text/plain ,那么就會顯示一個純文本
設置響應頭: response['X-Access-Token'] = 'xxxx' 。
class HttpResponseBase:
"""
An HTTP response base class with dictionary-accessed headers.
This class doesn't handle content. It should not be used directly.
Use the HttpResponse and StreamingHttpResponse subclasses instead.
"""
status_code = 200
def __init__(self, content_type=None, status=None, reason=None, charset=None, headers=None):
self.headers = ResponseHeaders(headers or {})
打開HttpResponseBase類的源碼可以看到構造屬性中有上述的這些參數(shù),默認status為200
但是我們也可以自己設置不同的狀態(tài)碼
同時我們也可以自己設置傳輸類型
默認的種類是text/html類型的文本,所以再加入某些標簽的時候會被認作是html文本
return HttpResponse("JiaRui",status=403)
顯示出來的并不是
,而是一個一級標題,如果想要得到完整的這個文本內(nèi)容,需要加一個參數(shù)配置JiaRui
content_type="text/plain"
同時也可以設置響應頭部分,瀏覽器在自動接收的時候就會默認設置好一些參數(shù)
如果想自定義一些響應頭就需要修改一下python代碼
res = HttpResponse("JiaRui
",content_type="text/plain")
res["regina"] = "my_wife"
return res
用來對象 dump 成 json 字符串,然后返回將 json 字符串封裝成 Response 對象返回給瀏覽器。并且他的 Content-Type 是 application/json
from django.http import JsonResponse
dir = {
'name':"regina",
'age': 20
}
import json
return HttpResponse(json.dumps(dir,ensure_ascii=False))
因為不接受字典,所以先要用dumo方法變成字符串,括號里的參數(shù)可以使字符串里寫成中文
返回的確實是一個類似于字典類型的格式,但是如果我們想進一步變的更加條理,就需要把文本類型再改一下
return HttpResponse(json.dumps(dir,ensure_ascii=False),content_type="application.json")
為了方便,上述的操作過程可以用JsonResponse格式統(tǒng)一替換掉
class JsonResponse(HttpResponse):
"""
An HTTP response class that consumes data to be serialized to JSON.
:param data: Data to be dumped into json. By default only ``dict`` objects
are allowed to be passed due to a security flaw before EcmaScript 5. See
the ``safe`` parameter for more information.
:param encoder: Should be a json encoder class. Defaults to
``django.core.serializers.json.DjangoJSONEncoder``.
:param safe: Controls if only ``dict`` objects may be serialized. Defaults
to ``True``.
:param json_dumps_params: A dictionary of kwargs passed to json.dumps().
"""
def __init__(self, data, encoder=DjangoJSONEncoder, safe=True,
json_dumps_params=None, **kwargs):
if safe and not isinstance(data, dict):
raise TypeError(
'In order to allow non-dict objects to be serialized set the '
'safe parameter to False.'
)
if json_dumps_params is None:
json_dumps_params = {}
kwargs.setdefault('content_type', 'application/json')
data = json.dumps(data, cls=encoder, **json_dumps_params)
super().__init__(content=data, **kwargs)
dir = {
'name':"regina",
'age': 20
}
return JsonResponse(dir)
得到的也是同樣的效果,但是如果我們想傳輸一個字典列表的話,這種方法就不適用了
return JsonResponse([ {'name':"regina",'age': 20},{'name':"Jiarui",'age': 22}])
如果想要得到這種形式的內(nèi)容,就需要在把默認的safe參數(shù)改為false就可以了
render(request, template_name,[context])
結合一個給定的模板和一個給定的上下文字典,并返回一個渲染后的 HttpResponse 對象。
參數(shù)
request:用于生成響應的請求對象
template_name:要使用的模板的完整名稱,可選的參數(shù)
context:添加到模板上下文的一個字典,
默認是一個空字典。如果字典中的某個值是可調(diào)用的,視圖將在渲染模板之前調(diào)用它。
結合運用請求信息里面的知識點,首先在請求頭里添加一個自定義的名字
name = request.META.get("HTTP_NAME")
return render(request,"regina.html",{'now':name})
可以看到請求部分name改為了HTTP_NAME這個名字,然后獲取它,渲染到我們的模板文件里就好
當您使用Django框架構建Python Web應用程序時,您在某些時候必須將用戶從一個URL重定向到另一個URL,
通過redirect方法實現(xiàn)重定向。
參數(shù)可以是:
首先我們創(chuàng)建一個登錄驗證的邏輯,通過路由分發(fā)轉到一個登錄頁面
def login(request):
return render(request,"login.html")
然后通過這個提交轉到一個叫做auth的視圖函數(shù)進行驗證,通過post方式進行提交
可以看到用戶名和密碼都打印出來了,這時就可以進行判斷以及重定向
def auth(request):
print(request.POST)
name = request.POST.get("user")
pwd = request.POST.get("pwd")
if name == "zhangjiarui" and pwd == "regina":
return redirect("/JRrequest/jr")
else:
return redirect("/ZJR/login")
auth函數(shù)重定向的時候是沒有響應內(nèi)容的,但是有響應頭
當狀態(tài)碼是302時,就說明要發(fā)起一個重定向了,并且此時的location代表重定向的路徑。
如果輸入錯誤,想要獲取的效果是提示并返回登錄頁面,添加一個渲染即可
在我們寫路由的時候,往往會有/
的區(qū)別
path("login",views.login)
在這里是沒有斜杠的,那么在瀏覽器訪問的時候,多一個/一定會報錯
但假如說我們的路由里是帶/的,那么無論我們訪問瀏覽器是怎么寫的,都不會有問題
path("login/",views.login)
具體區(qū)別就是
如果本身就是帶著/訪問,那么就是一次訪問,狀態(tài)碼是200,但如果訪問的時候沒有帶/,那么將會有兩次響應,服務器會幫客戶端做一次重定向,補齊url里面的東西然后再進行提交
首先下方的紅框表示我們第一次訪問的路徑,沒有帶/,所以進行了第二次的重定向,但最終得到的效果是一樣的。
如果想取消這個自動補全功能,在setting.py
里加一句
APPEND_SLASH = False