溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Django 視圖層(view)的使用

發(fā)布時(shí)間:2020-10-05 00:58:57 來(lái)源:腳本之家 閱讀:160 作者:學(xué)一點(diǎn)也是好 欄目:開(kāi)發(fā)技術(shù)

視圖層(view)

視圖函數(shù),簡(jiǎn)稱(chēng)視圖,本質(zhì)上是一個(gè)簡(jiǎn)單的Python函數(shù),它接受Web請(qǐng)求并且返回Web響應(yīng)。響應(yīng)的內(nèi)容可以是HTML網(wǎng)頁(yè),重定向,404錯(cuò)誤,圖片等任何東西,但本質(zhì)是返回 響應(yīng)對(duì)象HttpResponse 。

視圖函數(shù)的代碼寫(xiě)哪里都可以,但一般約定俗成設(shè)置在項(xiàng)目或應(yīng)用程序目錄中的 views.py 文件中

視圖案例:

from django.shortcuts import render, HttpResponse, HttpResponseRedirect, redirect
import datetime

def current_datetime(request):
  now = datetime.datetime.now()
  html = "<html><body>It is now %s.</body></html>" % now
  return HttpResponse(html)

解析:

  1. 從 django.shortcuts 模塊導(dǎo)入了 HttpResponse 類(lèi),以及Python的 datetime 庫(kù)。
  2. 定義了 current_datetime 函數(shù)。它就是視圖函數(shù)。每個(gè)視圖函數(shù)都使用 HttpRequest 對(duì)象作為第一個(gè)參數(shù),并且通常稱(chēng)之為 request 。 視圖函數(shù)的名字能反映除它的功能即可
  3. 視圖函數(shù)最后返回 HttpResponse 對(duì)象,其中包含生成的響應(yīng)。每個(gè)視圖函數(shù)都負(fù)責(zé)返回一個(gè) HttpResponse 對(duì)象。

一、HttpRequest對(duì)象

請(qǐng)求對(duì)象(request)的屬性:

django將請(qǐng)求報(bào)文中的請(qǐng)求行、首部信息、內(nèi)容主題封裝成HttpRequest類(lèi)中的屬性。除特殊說(shuō)明外,其他均為只讀
1. request.POST    # 前臺(tái)Post傳過(guò)來(lái)的數(shù)據(jù),包裝到POST字典中
2. request.GET     # 前臺(tái)瀏覽器窗口里攜帶的數(shù)據(jù),包裝到GET字典中
3. request.method  # 前臺(tái)請(qǐng)求的方式
4. request.body    # post提交的數(shù)據(jù),body體的內(nèi)容,前臺(tái)會(huì)封裝成:name=lqz&age=18&sex=1
5. request.path  # 取出請(qǐng)求的路徑,取不到數(shù)據(jù)部分
6. request.encoding  #一個(gè)字符串,表示提交的數(shù)據(jù)的編碼方式,默認(rèn)'utf-8'
7. request.META  #一個(gè)標(biāo)準(zhǔn)的Python 字典,包含所有的HTTP 首部
        CONTENT_LENGTH —— 請(qǐng)求的正文的長(zhǎng)度(是一個(gè)字符串)。
        CONTENT_TYPE —— 請(qǐng)求的正文的MIME 類(lèi)型。
        HTTP_ACCEPT —— 響應(yīng)可接收的Content-Type。
        HTTP_ACCEPT_ENCODING —— 響應(yīng)可接收的編碼。
        HTTP_ACCEPT_LANGUAGE —— 響應(yīng)可接收的語(yǔ)言。
        HTTP_HOST —— 客服端發(fā)送的HTTP Host 頭部。
        HTTP_REFERER —— Referring 頁(yè)面。
        HTTP_USER_AGENT —— 客戶(hù)端的user-agent 字符串。
        QUERY_STRING —— 單個(gè)字符串形式的查詢(xún)字符串(未解析過(guò)的形式)。
        REMOTE_ADDR —— 客戶(hù)端的IP 地址。
        REMOTE_HOST —— 客戶(hù)端的主機(jī)名。
        REMOTE_USER —— 服務(wù)器認(rèn)證后的用戶(hù)。
        REQUEST_METHOD —— 一個(gè)字符串,例如"GET" 或"POST"。
        SERVER_NAME —— 服務(wù)器的主機(jī)名。
        SERVER_PORT —— 服務(wù)器的端口(是一個(gè)字符串)。
   --------------------------------
    除CONTENT_LENGTH 和 CONTENT_TYPE 之外,請(qǐng)求中的任何 HTTP 首部轉(zhuǎn)換為 META 的鍵時(shí),
    都會(huì)將所有字母大寫(xiě)并將連接符替換為下劃線最后加上 HTTP_  前綴。
   ---------------------------------
8. request.FILES #包含所有的上傳文件信息。
9. request.COOKIES  #字典格式,鍵和只都是字符串,包含所有的cookie
10. request.session  #當(dāng)前會(huì)話,只有當(dāng)django啟用會(huì)話時(shí)才可用
11. request.user(用戶(hù)認(rèn)證組件)
    一個(gè) AUTH_USER_MODEL 類(lèi)型的對(duì)象,表示當(dāng)前登錄的用戶(hù)。

如果用戶(hù)當(dāng)前沒(méi)有登錄,user 將設(shè)置為 django.contrib.auth.models.AnonymousUser 的一個(gè)實(shí)例。       你可以通過(guò) is_authenticated() 區(qū)分它們。

例如:

  if request.user.is_authenticated():
    # Do something for logged-in users.
  else:
    # Do something for anonymous users.

user 只有當(dāng)Django 啟用 AuthenticationMiddleware 中間件時(shí)才可用。

匿名用戶(hù)

  class models.AnonymousUser

  django.contrib.auth.models.AnonymousUser 類(lèi)實(shí)現(xiàn)了django.contrib.auth.models.User 接   口,但具有下面幾個(gè)不同點(diǎn):

    id 永遠(yuǎn)為None。
    username 永遠(yuǎn)為空字符串。
    get_username() 永遠(yuǎn)返回空字符串。
    is_staff 和 is_superuser 永遠(yuǎn)為False。
    is_active 永遠(yuǎn)為 False。
    groups 和 user_permissions 永遠(yuǎn)為空。
    is_anonymous() 返回True 而不是False。
    is_authenticated() 返回False 而不是True。
    set_password()、check_password()、save() 和delete() 引發(fā) NotImplementedError。

New in Django 1.8: 新增 AnonymousUser.get_username() 以更好地模擬 django.contrib.auth.models.User。

注:FILES 只有在請(qǐng)求的方法為POST 且提交的

帶有enctype="multipart/form-data" 的情況下才會(huì)

包含數(shù)據(jù)。否則,F(xiàn)ILES 將為一個(gè)空的類(lèi)似于字典的對(duì)象。

request的常用方法:

1. request.get_full_path()
取出請(qǐng)求的路徑,能取到數(shù)據(jù)部分,request.path取不到數(shù)據(jù)
2. request.is_ajax()
如果請(qǐng)求是通過(guò)XMLHttpRequest生成的,則返回True。這個(gè)方法的作用就是判斷,當(dāng)前請(qǐng)求是否通過(guò)ajax機(jī)制發(fā)送過(guò)來(lái)的。
3. request.is_secure()
如果使用的是Https,則返回True,表示連接是安全的。

二、HttpResponse對(duì)象

響應(yīng)對(duì)象主要有三種形式:

  • HttpResponse()
  • render()
  • redirect()

1.HttpResponse

HttpResponse()括號(hào)內(nèi)直接跟一個(gè)具體的字符串作為響應(yīng)體。

2.render

render(request,template_name,[,context])

結(jié)合一個(gè)

參數(shù):

  • request:用于生成響應(yīng)的請(qǐng)求對(duì)象。
  • template_name:要使用的模板名稱(chēng)。
  • context:添加到模板上下文的一個(gè)字典。默認(rèn)空字典,如果字典中某個(gè)值是可調(diào)用的,視圖將在渲染模板前調(diào)用它。
  • render方法就是將一個(gè)模板頁(yè)面中的模板語(yǔ)法進(jìn)行渲染,最終渲染成一個(gè)html頁(yè)面作為響應(yīng)體。

3.redirect

傳遞要重定向的一個(gè)硬編碼的URL

def my_view(request):
  ...
  return redirect('some/url')

也可以是一個(gè)完整的URL:

def my_view(request):
  ...
  return redirect('http://www.baidu.com')

重定向301和302的區(qū)別

1)301和302的區(qū)別。

301和302狀態(tài)碼都表示重定向,就是說(shuō)瀏覽器在拿到服務(wù)器返回的這個(gè)狀態(tài)碼后會(huì)自動(dòng)跳轉(zhuǎn)到一個(gè)新的URL地址,這個(gè)地址可以從響應(yīng)的Location首部中獲取(用戶(hù)看到的效果就是他輸入的地址A瞬間變成了另一個(gè)地址B)——這是它們的共同點(diǎn)。

他們的不同在于。301表示舊地址A的資源已經(jīng)被永久地移除了(這個(gè)資源不可訪問(wèn)了),搜索引擎在抓取新內(nèi)容的同時(shí)也將舊的網(wǎng)址交換為重定向之后的網(wǎng)址;

302表示舊地址A的資源還在(仍然可以訪問(wèn)),這個(gè)重定向只是臨時(shí)地從舊地址A跳轉(zhuǎn)到地址B,搜索引擎會(huì)抓取新的內(nèi)容而保存舊的網(wǎng)址。 SEO302好于301

2)重定向原因:

(1)網(wǎng)站調(diào)整(如改變網(wǎng)頁(yè)目錄結(jié)構(gòu));
(2)網(wǎng)頁(yè)被移到一個(gè)新地址;
(3)網(wǎng)頁(yè)擴(kuò)展名改變(如應(yīng)用需要把.php改成.Html或.shtml)。

這種情況下,如果不做重定向,則用戶(hù)收藏夾或搜索引擎數(shù)據(jù)庫(kù)中舊地址只能讓訪問(wèn)客戶(hù)得到一個(gè)404頁(yè)面錯(cuò)誤信息,訪問(wèn)流量白白喪失;再者某些注冊(cè)了多個(gè)域名的

網(wǎng)站,也需要通過(guò)重定向讓訪問(wèn)這些域名的用戶(hù)自動(dòng)跳轉(zhuǎn)到主站點(diǎn)等。

三、JsonResponse對(duì)象

向前端返回一個(gè)json格式字符串的兩種方式

# 第一種方式
# import json
# data={'name':'lqz','age':18}
# data1=['lqz','egon']
# return HttpResponse(json.dumps(data1))
# 第二種方式
from django.http import JsonResponse
# data = {'name': 'lqz', 'age': 18}
data1 = ['lqz', 'egon']
# return JsonResponse(data)
return JsonResponse(data1,safe=False)

四、CBV和FBV

CBV是基于類(lèi)的視圖(Class base view)和FBV基于函數(shù)的視圖(Function base view)

from django.views import View
class AddPublish(View):
  def dispatch(self, request, *args, **kwargs):
    print(request)
    print(args)
    print(kwargs)
    # 可以寫(xiě)類(lèi)似裝飾器的東西,在前后加代碼
    obj=super().dispatch(request, *args, **kwargs)
    return obj

  def get(self,request):
    return render(request,'index.html')
  def post(self,request):
    request
    return HttpResponse('post')

五、簡(jiǎn)單文件上傳

def fileupload(request):
  if request.method=='GET':
    return render(request,'fileupload.html')
  if request.method=='POST':
    # FILES
    print(request.FILES)
    print(type(request.FILES.get('myfile')))
    # 從字典里根據(jù)名字,把文件取出來(lái)
    myfile=request.FILES.get('myfile')
    from django.core.files.uploadedfile import InMemoryUploadedFile
    # 文件名字
    name=myfile.name
    # 打開(kāi)文件,把上傳過(guò)來(lái)的文件存到本地
    with open(name,'wb') as f:
      # for line in myfile.chunks():
      for line in myfile:
        f.write(line)
    return HttpResponse('ok')

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI