Django 視圖層(view)的使用
視圖層(view)
視圖函數(shù),簡稱視圖,本質(zhì)上是一個簡單的Python函數(shù),它接受Web請求并且返回Web響應(yīng)。響應(yīng)的內(nèi)容可以是HTML網(wǎng)頁,重定向,404錯誤,圖片等任何東西,但本質(zhì)是返回 響應(yīng)對象HttpResponse 。
視圖函數(shù)的代碼寫哪里都可以,但一般約定俗成設(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)
解析:
- 從 django.shortcuts 模塊導(dǎo)入了 HttpResponse 類,以及Python的 datetime 庫。
- 定義了 current_datetime 函數(shù)。它就是視圖函數(shù)。每個視圖函數(shù)都使用 HttpRequest 對象作為第一個參數(shù),并且通常稱之為 request 。 視圖函數(shù)的名字能反映除它的功能即可
- 視圖函數(shù)最后返回 HttpResponse 對象,其中包含生成的響應(yīng)。每個視圖函數(shù)都負(fù)責(zé)返回一個 HttpResponse 對象。
一、HttpRequest對象
請求對象(request)的屬性:
django將請求報(bào)文中的請求行、首部信息、內(nèi)容主題封裝成HttpRequest類中的屬性。除特殊說明外,其他均為只讀
1. request.POST # 前臺Post傳過來的數(shù)據(jù),包裝到POST字典中
2. request.GET # 前臺瀏覽器窗口里攜帶的數(shù)據(jù),包裝到GET字典中
3. request.method # 前臺請求的方式
4. request.body # post提交的數(shù)據(jù),body體的內(nèi)容,前臺會封裝成:name=lqz&age=18&sex=1
5. request.path # 取出請求的路徑,取不到數(shù)據(jù)部分
6. request.encoding #一個字符串,表示提交的數(shù)據(jù)的編碼方式,默認(rèn)'utf-8'
7. request.META #一個標(biāo)準(zhǔn)的Python 字典,包含所有的HTTP 首部
CONTENT_LENGTH —— 請求的正文的長度(是一個字符串)。
CONTENT_TYPE —— 請求的正文的MIME 類型。
HTTP_ACCEPT —— 響應(yīng)可接收的Content-Type。
HTTP_ACCEPT_ENCODING —— 響應(yīng)可接收的編碼。
HTTP_ACCEPT_LANGUAGE —— 響應(yīng)可接收的語言。
HTTP_HOST —— 客服端發(fā)送的HTTP Host 頭部。
HTTP_REFERER —— Referring 頁面。
HTTP_USER_AGENT —— 客戶端的user-agent 字符串。
QUERY_STRING —— 單個字符串形式的查詢字符串(未解析過的形式)。
REMOTE_ADDR —— 客戶端的IP 地址。
REMOTE_HOST —— 客戶端的主機(jī)名。
REMOTE_USER —— 服務(wù)器認(rèn)證后的用戶。
REQUEST_METHOD —— 一個字符串,例如"GET" 或"POST"。
SERVER_NAME —— 服務(wù)器的主機(jī)名。
SERVER_PORT —— 服務(wù)器的端口(是一個字符串)。
--------------------------------
除CONTENT_LENGTH 和 CONTENT_TYPE 之外,請求中的任何 HTTP 首部轉(zhuǎn)換為 META 的鍵時,
都會將所有字母大寫并將連接符替換為下劃線最后加上 HTTP_ 前綴。
---------------------------------
8. request.FILES #包含所有的上傳文件信息。
9. request.COOKIES #字典格式,鍵和只都是字符串,包含所有的cookie
10. request.session #當(dāng)前會話,只有當(dāng)django啟用會話時才可用
11. request.user(用戶認(rèn)證組件)
一個 AUTH_USER_MODEL 類型的對象,表示當(dāng)前登錄的用戶。
如果用戶當(dāng)前沒有登錄,user 將設(shè)置為 django.contrib.auth.models.AnonymousUser 的一個實(shí)例。 你可以通過 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 中間件時才可用。
匿名用戶
class models.AnonymousUser django.contrib.auth.models.AnonymousUser 類實(shí)現(xiàn)了django.contrib.auth.models.User 接 口,但具有下面幾個不同點(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 只有在請求的方法為POST 且提交的
帶有enctype="multipart/form-data" 的情況下才會
包含數(shù)據(jù)。否則,F(xiàn)ILES 將為一個空的類似于字典的對象。
request的常用方法:
1. request.get_full_path()
取出請求的路徑,能取到數(shù)據(jù)部分,request.path取不到數(shù)據(jù)
2. request.is_ajax()
如果請求是通過XMLHttpRequest生成的,則返回True。這個方法的作用就是判斷,當(dāng)前請求是否通過ajax機(jī)制發(fā)送過來的。
3. request.is_secure()
如果使用的是Https,則返回True,表示連接是安全的。
二、HttpResponse對象
響應(yīng)對象主要有三種形式:
- HttpResponse()
- render()
- redirect()
1.HttpResponse
HttpResponse()括號內(nèi)直接跟一個具體的字符串作為響應(yīng)體。
2.render
render(request,template_name,[,context])
結(jié)合一個
參數(shù):
- request:用于生成響應(yīng)的請求對象。
- template_name:要使用的模板名稱。
- context:添加到模板上下文的一個字典。默認(rèn)空字典,如果字典中某個值是可調(diào)用的,視圖將在渲染模板前調(diào)用它。
- render方法就是將一個模板頁面中的模板語法進(jìn)行渲染,最終渲染成一個html頁面作為響應(yīng)體。
3.redirect
傳遞要重定向的一個硬編碼的URL
def my_view(request): ... return redirect('some/url')
也可以是一個完整的URL:
def my_view(request): ... return redirect('http://www.baidu.com')
重定向301和302的區(qū)別
1)301和302的區(qū)別。
301和302狀態(tài)碼都表示重定向,就是說瀏覽器在拿到服務(wù)器返回的這個狀態(tài)碼后會自動跳轉(zhuǎn)到一個新的URL地址,這個地址可以從響應(yīng)的Location首部中獲取(用戶看到的效果就是他輸入的地址A瞬間變成了另一個地址B)——這是它們的共同點(diǎn)。
他們的不同在于。301表示舊地址A的資源已經(jīng)被永久地移除了(這個資源不可訪問了),搜索引擎在抓取新內(nèi)容的同時也將舊的網(wǎng)址交換為重定向之后的網(wǎng)址;
302表示舊地址A的資源還在(仍然可以訪問),這個重定向只是臨時地從舊地址A跳轉(zhuǎn)到地址B,搜索引擎會抓取新的內(nèi)容而保存舊的網(wǎng)址。 SEO302好于301
2)重定向原因:
(1)網(wǎng)站調(diào)整(如改變網(wǎng)頁目錄結(jié)構(gòu));
(2)網(wǎng)頁被移到一個新地址;
(3)網(wǎng)頁擴(kuò)展名改變(如應(yīng)用需要把.php改成.Html或.shtml)。
這種情況下,如果不做重定向,則用戶收藏夾或搜索引擎數(shù)據(jù)庫中舊地址只能讓訪問客戶得到一個404頁面錯誤信息,訪問流量白白喪失;再者某些注冊了多個域名的
網(wǎng)站,也需要通過重定向讓訪問這些域名的用戶自動跳轉(zhuǎn)到主站點(diǎn)等。
三、JsonResponse對象
向前端返回一個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是基于類的視圖(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) # 可以寫類似裝飾器的東西,在前后加代碼 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')
五、簡單文件上傳
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ù)名字,把文件取出來 myfile=request.FILES.get('myfile') from django.core.files.uploadedfile import InMemoryUploadedFile # 文件名字 name=myfile.name # 打開文件,把上傳過來的文件存到本地 with open(name,'wb') as f: # for line in myfile.chunks(): for line in myfile: f.write(line) return HttpResponse('ok')
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python 處理微信對賬單數(shù)據(jù)的實(shí)例代碼
本文通過實(shí)例代碼給大家介紹了python 處理微信對賬單數(shù)據(jù),代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07Python使用lambda拋出異常實(shí)現(xiàn)方法解析
這篇文章主要介紹了Python使用lambda拋出異常實(shí)現(xiàn)方法解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08利用Python對哥德巴赫猜想進(jìn)行檢驗(yàn)和推理
數(shù)學(xué)是一個奇妙的東西,對此,也衍生出了許多的悖論與猜想。這篇文章會對哥德巴赫猜想用編程語言進(jìn)行檢驗(yàn)和推理,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-12-12Python實(shí)現(xiàn)簡單狀態(tài)框架的方法
這篇文章主要介紹了Python實(shí)現(xiàn)簡單狀態(tài)框架的方法,涉及Python狀態(tài)框架的實(shí)現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03Python內(nèi)置random模塊生成隨機(jī)數(shù)的方法
這篇文章主要介紹了Python內(nèi)置random模塊生成隨機(jī)數(shù)的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-05-05python實(shí)現(xiàn)快速排序的示例(二分法思想)
本篇文章主要介紹了python實(shí)現(xiàn)快速排序的示例(二分法思想),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03python腳本實(shí)現(xiàn)驗(yàn)證碼識別
這篇文章主要為大家詳細(xì)介紹了python腳本實(shí)現(xiàn)驗(yàn)證碼識別的實(shí)現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06python thread 并發(fā)且順序運(yùn)行示例
以上源文件是對python中的線程的一個簡單應(yīng)用,實(shí)現(xiàn)了對并發(fā)線程的順序運(yùn)行,也許對你會有小小幫助2009-04-04