真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

django_響應對象

Django_響應對象

響應對象

響應對象有三種形式:

為城中等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及城中網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為網(wǎng)站制作、網(wǎng)站設計、城中網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

HttpResponse()

render()

Redirect()

(1) HttpResponse()

django服務器接收到客戶端發(fā)來的請求之后,會將提交上來的數(shù)據(jù)封裝成一個HttpResponse對象傳給視圖函數(shù)。視圖函數(shù)在處理完相關邏輯之后,也需要一個返回響應給瀏覽器。而這個響應方式,我們必須通過返回HttpResponseBase或者其他子類的對象。

常用屬性:

  1. content:返回內(nèi)容

  2. status:響應狀態(tài)碼

  3. content_type:返回的數(shù)據(jù)的MIME類型,默認為 text/html 。瀏覽器會根據(jù)這個屬性,來顯示數(shù)據(jù)。如果是 text/html ,那么就會解析這個字符串,如果 text/plain ,那么就會顯示一個純文本

  4. 設置響應頭: 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)

顯示出來的并不是

JiaRui

,而是一個一級標題,如果想要得到完整的這個文本內(nèi)容,需要加一個參數(shù)配置content_type="text/plain"

同時也可以設置響應頭部分,瀏覽器在自動接收的時候就會默認設置好一些參數(shù)

如果想自定義一些響應頭就需要修改一下python代碼

res = HttpResponse("

JiaRui

",content_type="text/plain") res["regina"] = "my_wife" return res

(2)JsonResponse()

用來對象 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就可以了

(3)render

render(request, template_name,[context])結合一個給定的模板和一個給定的上下文字典,并返回一個渲染后的 HttpResponse 對象。

參數(shù)

  1. request:用于生成響應的請求對象

  2. template_name:要使用的模板的完整名稱,可選的參數(shù)

  3. context:添加到模板上下文的一個字典,
    默認是一個空字典。如果字典中的某個值是可調(diào)用的,視圖將在渲染模板之前調(diào)用它。

結合運用請求信息里面的知識點,首先在請求頭里添加一個自定義的名字

name = request.META.get("HTTP_NAME")
    return render(request,"regina.html",{'now':name})

可以看到請求部分name改為了HTTP_NAME這個名字,然后獲取它,渲染到我們的模板文件里就好

(4)redirect重定向

當您使用Django框架構建Python Web應用程序時,您在某些時候必須將用戶從一個URL重定向到另一個URL,

通過redirect方法實現(xiàn)重定向。

參數(shù)可以是:

  • 一個絕對的或相對的URL, 將原封不動的作為重定向的位置.
  • 一個url的別名: 可以使用reverse來反向解析url

首先我們創(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

名稱欄目:django_響應對象
轉載來于:http://weahome.cn/article/dsogeij.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部