Django框架表單操作實例分析
本文實例講述了Django框架表單操作。分享給大家供大家參考,具體如下:
HTML表單是網(wǎng)站交互性的經(jīng)典方式。 開始學(xué)習如何用Django對用戶提交的表單數(shù)據(jù)進行處理。
HTTP 請求
HTTP協(xié)議以"請求-回復(fù)"的方式工作??蛻舭l(fā)送請求時,可以在請求中附加數(shù)據(jù)。服務(wù)器通過解析請求,就可以獲得客戶傳來的數(shù)據(jù),并根據(jù)URL來提供特定的服務(wù)。
GET 方法
在之前的項目中創(chuàng)建一個 search.py 文件,用于接收用戶的請求:
/djangoPro/djangoPro/search.py 文件代碼:
# -*- coding: utf-8 -*- from django.http import HttpResponse from django.shortcuts import render_to_response # 表單 def search_form(request): return render_to_response('search_form.html') # 接收請求數(shù)據(jù) def search(request): request.encoding='utf-8' if 'q' in request.GET: message = '你搜索的內(nèi)容為: ' + request.GET['q'] else: message = '你提交了空表單' return HttpResponse(message)
在模板目錄 templates 中添加 search_form.html 表單:
/djangoPro/templates/search_form.html 文件代碼
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>菜鳥教程(runoob.com)</title> </head> <body> <form action="/search" method="get"> <input type="text" name="q"> <input type="submit" value="搜索"> </form> </body> </html>
urls.py 規(guī)則修改為如下形式:
POST 方法
上面使用了GET方法。視圖顯示和請求處理分成兩個函數(shù)處理。
提交數(shù)據(jù)時更常用POST方法。下面使用該方法,并用一個URL和處理函數(shù),同時顯示視圖和處理請求。
在 templates 創(chuàng)建 post.html:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>菜鳥教程(runoob.com)</title> </head> <body> <form action="/search-post" method="post"> {% csrf_token %} <input type="text" name="q"> <input type="submit" value="Submit"> </form> <p>{{ rlt }}</p> </body> </html>
在模板的末尾,我們增加一個 rlt 記號,為表格處理結(jié)果預(yù)留位置。
表格后面還有一個{% csrf_token %}的標簽。csrf 全稱是 Cross Site Request Forgery。這是Django提供的防止偽裝提交請求的功能。POST 方法提交的表格,必須有此標簽。
在HelloWorld目錄下新建 search2.py 文件并使用 search_post 函數(shù)來處理 POST 請求:
/djangoPro/djangoPro/search2.py 文件代碼:
# -*- coding: utf-8 -*- from django.shortcuts import render from django.views.decorators import csrf # 接收POST請求數(shù)據(jù) def search_post(request): ctx ={} if request.POST: ctx['rlt'] = request.POST['q'] return render(request, "post.html", ctx)
urls.py 規(guī)則修改為如下形式:
from django.conf.urls import url from . import view,testdb,search,search2 urlpatterns = [ url(r'^hello$', view.hello), url(r'^testdb$', testdb.testdb), url(r'^search-form$', search.search_form), url(r'^search$', search.search), url(r'^search-post$', search2.search_post), ]
Request 對象
每個 view 函數(shù)的第一個參數(shù)是一個 HttpRequest 對象,就像下面這個 hello() 函數(shù):
from django.http import HttpResponse def hello(request): return HttpResponse("Hello world")
HttpRequest對象包含當前請求URL的一些信息:
屬性 |
描述 |
path |
請求頁面的全路徑,不包括域名—例如, "/hello/"。 |
method |
請求中使用的HTTP方法的字符串表示。全大寫表示。例如: if request.method == 'GET': |
GET |
包含所有HTTP GET參數(shù)的類字典對象。參見QueryDict 文檔。 |
POST |
包含所有HTTP POST參數(shù)的類字典對象。參見QueryDict 文檔。 服務(wù)器收到空的POST請求的情況也是有可能發(fā)生的。也就是說,表單form通過HTTP POST方法提交請求,但是表單中可以沒有數(shù)據(jù)。因此,不能使用語句if request.POST來判斷是否使用HTTP POST方法;應(yīng)該使用if request.method == "POST" (參見本表的method屬性)。 注意: POST不包括file-upload信息。參見FILES屬性。 |
REQUEST |
為了方便,該屬性是POST和GET屬性的集合體,但是有特殊性,先查找POST屬性,然后再查找GET屬性。借鑒PHP's $_REQUEST。 例如,如果GET = {"name": "john"} 和POST = {"age": '34'},則 REQUEST["name"] 的值是"john", REQUEST["age"]的值是"34". 強烈建議使用GET and POST,因為這兩個屬性更加顯式化,寫出的代碼也更易理解。 |
COOKIES |
包含所有cookies的標準Python字典對象。Keys和values都是字符串。 |
FILES |
包含所有上傳文件的類字典對象。FILES中的每個Key都是<input type="file" name="" />標簽中name屬性的值. FILES中的每個value 同時也是一個標準Python字典對象,包含下面三個Keys:
注意:只有在請求方法是POST,并且請求頁面中<form>有enctype="multipart/form-data"屬性時FILES才擁有數(shù)據(jù)。否則,F(xiàn)ILES 是一個空字典。 |
META |
包含所有可用HTTP頭部信息的字典。 例如:
META 中這些頭加上前綴HTTP_最為Key, 例如:
|
user |
是一個django.contrib.auth.models.User 對象,代表當前登錄的用戶。 如果訪問用戶當前沒有登錄,user將被初始化為django.contrib.auth.models.AnonymousUser的實例。 你可以通過user的is_authenticated()方法來辨別用戶是否登錄:
if request.user.is_authenticated():
# Do something for logged-in users.
else:
# Do something for anonymous users.
只有激活Django中的AuthenticationMiddleware時該屬性才可用 |
session |
唯一可讀寫的屬性,代表當前會話的字典對象。只有激活Django中的session支持時該屬性才可用。 |
raw_post_data |
原始HTTP POST數(shù)據(jù),未解析過。 高級處理時會有用處。 |
Request對象也有一些有用的方法:
方法 | 描述 |
---|---|
__getitem__(key) | 返回GET/POST的鍵值,先取POST,后取GET。如果鍵不存在拋出 KeyError。 這是我們可以使用字典語法訪問HttpRequest對象。 例如,request["foo"]等同于先request.POST["foo"] 然后 request.GET["foo"]的操作。 |
has_key() | 檢查request.GET or request.POST中是否包含參數(shù)指定的Key。 |
get_full_path() | 返回包含查詢字符串的請求路徑。例如, "/music/bands/the_beatles/?print=true" |
is_secure() | 如果請求是安全的,返回True,就是說,發(fā)出的是HTTPS請求。 |
QueryDict對象
在HttpRequest對象中, GET和POST屬性是django.http.QueryDict類的實例。
QueryDict類似字典的自定義類,用來處理單鍵對應(yīng)多值的情況。
QueryDict實現(xiàn)所有標準的詞典方法。還包括一些特有的方法:
方法 | 描述 |
---|---|
__getitem__ |
和標準字典的處理有一點不同,就是,如果Key對應(yīng)多個Value,__getitem__()返回最后一個value。 |
__setitem__ |
設(shè)置參數(shù)指定key的value列表(一個Python list)。注意:它只能在一個mutable QueryDict 對象上被調(diào)用(就是通過copy()產(chǎn)生的一個QueryDict對象的拷貝). |
get() |
如果key對應(yīng)多個value,get()返回最后一個value。 |
update() |
參數(shù)可以是QueryDict,也可以是標準字典。和標準字典的update方法不同,該方法添加字典 items,而不是替換它們: >>> q = QueryDict('a=1')
>>> q = q.copy() # to make it mutable
>>> q.update({'a': '2'})
>>> q.getlist('a')
['1', '2']
>>> q['a'] # returns the last
['2']
|
items() |
和標準字典的items()方法有一點不同,該方法使用單值邏輯的__getitem__(): >>> q = QueryDict('a=1&a=2&a=3')
>>> q.items()
[('a', '3')]
|
values() |
和標準字典的values()方法有一點不同,該方法使用單值邏輯的__getitem__(): |
此外, QueryDict也有一些方法,如下表:
方法 | 描述 |
---|---|
copy() |
返回對象的拷貝,內(nèi)部實現(xiàn)是用Python標準庫的copy.deepcopy()。該拷貝是mutable(可更改的) — 就是說,可以更改該拷貝的值。 |
getlist(key) |
返回和參數(shù)key對應(yīng)的所有值,作為一個Python list返回。如果key不存在,則返回空list。 It's guaranteed to return a list of some sort.. |
setlist(key,list_) |
設(shè)置key的值為list_ (unlike __setitem__()). |
appendlist(key,item) |
添加item到和key關(guān)聯(lián)的內(nèi)部list. |
setlistdefault(key,list) |
和setdefault有一點不同,它接受list而不是單個value作為參數(shù)。 |
lists() |
和items()有一點不同, 它會返回key的所有值,作為一個list, 例如: >>> q = QueryDict('a=1&a=2&a=3')
>>> q.lists()
[('a', ['1', '2', '3'])]
|
urlencode() |
返回一個以查詢字符串格式進行格式化后的字符串(e.g., "a=2&b=3&b=5"). |
希望本文所述對大家基于Django框架的Python程序設(shè)計有所幫助。
相關(guān)文章
python tkinter圖形界面代碼統(tǒng)計工具
這篇文章主要為大家詳細介紹了python tkinter圖形界面代碼統(tǒng)計工具,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-09-09Python將HTML快速轉(zhuǎn)換成PDF的方法實現(xiàn)
在Web開發(fā)和報告任務(wù)中,將HTML內(nèi)容轉(zhuǎn)換為PDF是一種常見需求,本文主要介紹了Python將HTML快速轉(zhuǎn)換成PDF的方法實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-01-01關(guān)于Python函數(shù)參數(shù)的進階用法
這篇文章主要給大家分享的是Python函數(shù)參數(shù)的進階用法,Python函數(shù)的參數(shù)根據(jù)函數(shù) 在調(diào)用時 傳參的形式分為關(guān)鍵字參數(shù)和位置參數(shù),下面文章小編就來介紹相關(guān)資料,需要的朋友可以參考一下2021-10-10