您好,登錄后才能下訂單哦!
視圖層(view)
視圖函數,簡稱視圖,本質上是一個簡單的Python函數,它接受Web請求并且返回Web響應。響應的內容可以是HTML網頁,重定向,404錯誤,圖片等任何東西,但本質是返回 響應對象HttpResponse 。
視圖函數的代碼寫哪里都可以,但一般約定俗成設置在項目或應用程序目錄中的 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)
解析:
一、HttpRequest對象
請求對象(request)的屬性:
django將請求報文中的請求行、首部信息、內容主題封裝成HttpRequest類中的屬性。除特殊說明外,其他均為只讀
1. request.POST # 前臺Post傳過來的數據,包裝到POST字典中
2. request.GET # 前臺瀏覽器窗口里攜帶的數據,包裝到GET字典中
3. request.method # 前臺請求的方式
4. request.body # post提交的數據,body體的內容,前臺會封裝成:name=lqz&age=18&sex=1
5. request.path # 取出請求的路徑,取不到數據部分
6. request.encoding #一個字符串,表示提交的數據的編碼方式,默認'utf-8'
7. request.META #一個標準的Python 字典,包含所有的HTTP 首部
CONTENT_LENGTH —— 請求的正文的長度(是一個字符串)。
CONTENT_TYPE —— 請求的正文的MIME 類型。
HTTP_ACCEPT —— 響應可接收的Content-Type。
HTTP_ACCEPT_ENCODING —— 響應可接收的編碼。
HTTP_ACCEPT_LANGUAGE —— 響應可接收的語言。
HTTP_HOST —— 客服端發送的HTTP Host 頭部。
HTTP_REFERER —— Referring 頁面。
HTTP_USER_AGENT —— 客戶端的user-agent 字符串。
QUERY_STRING —— 單個字符串形式的查詢字符串(未解析過的形式)。
REMOTE_ADDR —— 客戶端的IP 地址。
REMOTE_HOST —— 客戶端的主機名。
REMOTE_USER —— 服務器認證后的用戶。
REQUEST_METHOD —— 一個字符串,例如"GET" 或"POST"。
SERVER_NAME —— 服務器的主機名。
SERVER_PORT —— 服務器的端口(是一個字符串)。
--------------------------------
除CONTENT_LENGTH 和 CONTENT_TYPE 之外,請求中的任何 HTTP 首部轉換為 META 的鍵時,
都會將所有字母大寫并將連接符替換為下劃線最后加上 HTTP_ 前綴。
---------------------------------
8. request.FILES #包含所有的上傳文件信息。
9. request.COOKIES #字典格式,鍵和只都是字符串,包含所有的cookie
10. request.session #當前會話,只有當django啟用會話時才可用
11. request.user(用戶認證組件)
一個 AUTH_USER_MODEL 類型的對象,表示當前登錄的用戶。
如果用戶當前沒有登錄,user 將設置為 django.contrib.auth.models.AnonymousUser 的一個實例。 你可以通過 is_authenticated() 區分它們。
例如:
if request.user.is_authenticated(): # Do something for logged-in users. else: # Do something for anonymous users.
user 只有當Django 啟用 AuthenticationMiddleware 中間件時才可用。
匿名用戶
class models.AnonymousUser django.contrib.auth.models.AnonymousUser 類實現了django.contrib.auth.models.User 接 口,但具有下面幾個不同點:
id 永遠為None。
username 永遠為空字符串。
get_username() 永遠返回空字符串。
is_staff 和 is_superuser 永遠為False。
is_active 永遠為 False。
groups 和 user_permissions 永遠為空。
is_anonymous() 返回True 而不是False。
is_authenticated() 返回False 而不是True。
set_password()、check_password()、save() 和delete() 引發 NotImplementedError。
New in Django 1.8: 新增 AnonymousUser.get_username() 以更好地模擬 django.contrib.auth.models.User。
注:FILES 只有在請求的方法為POST 且提交的
帶有enctype="multipart/form-data" 的情況下才會
包含數據。否則,FILES 將為一個空的類似于字典的對象。
request的常用方法:
1. request.get_full_path()
取出請求的路徑,能取到數據部分,request.path取不到數據
2. request.is_ajax()
如果請求是通過XMLHttpRequest生成的,則返回True。這個方法的作用就是判斷,當前請求是否通過ajax機制發送過來的。
3. request.is_secure()
如果使用的是Https,則返回True,表示連接是安全的。
二、HttpResponse對象
響應對象主要有三種形式:
1.HttpResponse
HttpResponse()括號內直接跟一個具體的字符串作為響應體。
2.render
render(request,template_name,[,context])
結合一個
參數:
3.redirect
傳遞要重定向的一個硬編碼的URL
def my_view(request): ... return redirect('some/url')
也可以是一個完整的URL:
def my_view(request): ... return redirect('http://www.baidu.com')
重定向301和302的區別
1)301和302的區別。
301和302狀態碼都表示重定向,就是說瀏覽器在拿到服務器返回的這個狀態碼后會自動跳轉到一個新的URL地址,這個地址可以從響應的Location首部中獲取(用戶看到的效果就是他輸入的地址A瞬間變成了另一個地址B)——這是它們的共同點。
他們的不同在于。301表示舊地址A的資源已經被永久地移除了(這個資源不可訪問了),搜索引擎在抓取新內容的同時也將舊的網址交換為重定向之后的網址;
302表示舊地址A的資源還在(仍然可以訪問),這個重定向只是臨時地從舊地址A跳轉到地址B,搜索引擎會抓取新的內容而保存舊的網址。 SEO302好于301
2)重定向原因:
(1)網站調整(如改變網頁目錄結構);
(2)網頁被移到一個新地址;
(3)網頁擴展名改變(如應用需要把.php改成.Html或.shtml)。
這種情況下,如果不做重定向,則用戶收藏夾或搜索引擎數據庫中舊地址只能讓訪問客戶得到一個404頁面錯誤信息,訪問流量白白喪失;再者某些注冊了多個域名的
網站,也需要通過重定向讓訪問這些域名的用戶自動跳轉到主站點等。
三、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基于函數的視圖(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'))) # 從字典里根據名字,把文件取出來 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')
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。