亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Django視圖、傳參和forms驗證操作

瀏覽:7日期:2024-09-25 13:04:30

簡介視圖

主要內容:URLconf、HttpRequest對象、HttpResponse

1)視圖接受Web請求并且返回Web響應

2)視圖就是一個python函數,被定義在views.py中

3)響應可以是一張網頁的HTML內容,一個重定向,一個404錯誤等等

4)在http請求中產生兩個核心對象,所在位置是,django.http:

http請求:HttpRequest對象

http響應:HttpResponse對象

這兩個對象是由django幫我構造的

URLconf相關概述

• 在settings.py文件中通過ROOT_URLCONF指定根級url的配置

• urlpatterns是一個url()實例的列表,我們把它稱為路由,它里面的每一個url()我們稱為路由配置

• 一個url()對象包括:正則表達式、視圖函數、可選參數、名稱name

• 請求的url被看做是一個普通的python字符串,進行匹配時不包括get或post請求的參數及域名。

字典Context={}上下文,在html頁面里有參數時要封裝到字典里作為render的第三個參數返回也可以直接寫字典存變量 context={’name’:’lm’}

在html模板語言里:模板語言注釋{#顯示。。#} 在模板里顯示變量時用{{’name’}}用來顯示變量。(取消字典context的{})

for循環:

{% for num in b %} b為列表

{{num}}

{%endfor%}<br>

{% for key,value in c.items %} #c為字典

{{key}}---->{{value}}

{% endfor %}<br>

{% if 條件 %} 滿足條件執行語句{% else %}不滿足條件的語句 {% endif %}

URL的反向解析(軟連接)

如果在視圖、模板中使用硬編碼的鏈接,在urlconf發生改變時維護是一件非常麻煩的事情

解決:在做鏈接時,通過指向urlconf的名稱,也就是我們配置的namespace和name,動態生成鏈接地址

網頁模板語言的路徑的表示'{% url ’namesapce(分發路徑的名字):name(url的別名)’%}'

視圖:使用django.core.urlresolvers.reverse()函數

在模板語言中()[]是非法的用就報錯

路由配置

include這個方法,會把經過主路由匹配成功后剩下的路徑,分發給我們app里面的子路由去處理,它并不是嚴格匹配,正則是沒有結束符$的,第一個參數代表分發給哪個路由配置文件去處理,第二個參數namespace代表反向解析,和url()當中name參數作用類似。

主路由配置:主路由就是我們項目設置文件夾當中和settings.py文件同級的那個urls.py文件里面的urlpatterns。把主路由當作調度分發路由的工具。 首頁放在主路由

子路由:分成不同的app模塊(app里配置urls.py文件)主路由判斷分子路由操作

urlpatterns 里的include為子路由分發。主路由的urlpatterns里的url(r’^news/’,include(’news.urls’,namespace='news')) news為應用模塊

路徑傳參(位置和關鍵詞)模板語言在大括號里{% url ’news:news_date’2018 4 20 %}

未命名正則表達式組傳參(位置傳參):url(r’/(d+)/(d+)/(d+)/$’)

Django視圖、傳參和forms驗證操作

視圖函數如下

Django視圖、傳參和forms驗證操作

命名正則表達式組傳參(關鍵字傳參):視圖函數中的參數可以是亂序

url(r’/(?P<year>d+)/(?P<mouth>d+)/(?p<day>d+)/$’)

Django視圖、傳參和forms驗證操作

請求方式傳參:模版語言傳參:{% url ’news:news_date’%}?name=lm&a=5 與url路徑無關

Django視圖、傳參和forms驗證操作

所有form表單提交都需要forms驗證,再前端form表單需要制定提交路徑 action='{% url ’users:user_register’ %}'

與方式method='post'

在user的app中創建forms.py文件,填寫驗證條件

from django import formsfrom captcha.fields import CaptchaFieldfrom .models import UserProfile,EmailVerify class UserRegisterForm(forms.Form): email = forms.EmailField(required=True,error_messages={ ’required’:’郵箱必須填寫’ }) password = forms.CharField(min_length=3,max_length=20,required=True,error_messages={ ’required’: ’密碼必須填寫’, ’min_length’:’密碼最少得3個’, ’max_length’: ’密碼最多20個’, }) captcha = CaptchaField(error_messages={ ’invalid’:’驗證碼錯誤’ })

在views.py文件中

from .forms import UserRegisterFormdef user_register(request): if request.method == ’GET’: user_register_form = UserRegisterForm() return render(request,’users/register.html’,{ ’user_register_form’:user_register_form }) else: user_register_form = UserRegisterForm(request.POST)#進行驗證 if user_register_form.is_valid():#判斷是否合法 email = user_register_form.cleaned_data[’email’]#獲取request數據 password = user_register_form.cleaned_data[’password’] user = UserProfile.objects.filter(Q(email=email)|Q(username=email)) if user: return render(request,’users/register.html’,{ ’msg’:’用戶已經存在’ }) else: a = UserProfile() a.username = email a.email = email a.set_password(password)#加密密碼 a.si_active=False#設置密碼未激活,需要郵箱驗證激活 a.save() else: return render(request,’users/register.html’,{ ’user_register_form’:user_register_form })

獲得參數用:zhaoliying=request.GET.get(’name’,None) GET類字典(可以一鍵多值用getlist取值) None沒有參數默認返回None。前端傳到后端的數據都為字符串

CSRF跨站偽造攻擊錯誤。在獲取POST方式傳遞的參數時,要取消錯誤在form表單里加入 {% csrf_token %}

HttpReqeust對象

下面除非特別說明,屬性都是只讀的,都是字符串

1)path:一個字符串,表示請求的頁面的完整路徑,不包含域名和請求參數

2)method:一個字符串,表示請求使用的HTTP方法,常用值包括:’GET’、’POST’

3)encoding:一個字符串,表示提交的數據的編碼方式

A)如果為None則表示使用瀏覽器的默認設置,一般為utf-8

B)這個屬性是可寫的,可以通過修改它來修改訪問表單數據使用的編碼,接下來對屬性的任何訪問將使用新的encoding值

4)GET:一個類似于字典QueryDict的對象,包含get請求方式的所有參數,與url請求地址中的參數對應,位于?后面參數的格式是鍵值對,如key1=value1。多個參數之間,使用&連接。獲得參數用:data = request.GET.get(‘鍵’,默認)獲取

5)POST:一個類似于字典QueryDict的對象,包含post請求方式的所有參數。控件要有name屬性,則name屬性的值為鍵,value屬性的值為鍵,構成鍵值對提交。獲得參數用:data = request.POST.get(‘鍵’,默認)獲取

6)FILES:一個類似于字典的對象,包含所有的上傳文件

7)COOKIES:一個標準的Python字典,包含所有的cookie,鍵和值都為字符串

8)session:一個既可讀又可寫的類似于字典的對象,表示當前的會話,只有當Django 啟用會話的支持時才可用,詳細內容見“狀態保持”與python字典不同,QueryDict類型的對象用來處理同一個鍵帶有多個值的情況。

關于cookie的操作

1)Cookie,有時也用其復數形式 Cookies,指某些網站為了辨別用戶身份、進行 session 跟蹤而儲存在用戶本地終端上的數據(通常經過加密)。定義于 RFC2109 和 2965 中的都已廢棄,最新取代的規范是 RFC6265 [1] 。(可以叫做瀏覽器緩存)

2)cookie是服務器設置存儲在瀏覽器的一段文本信息,例如用戶登錄的時候不用輸入密碼了。

以上這篇Django視圖、傳參和forms驗證操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 亚洲中国日本韩国美国毛片 | 亚洲精品专区 | 国内国外精品一区二区 | 日韩精品亚洲人成在线播放 | 俄罗斯小younv另类 | 亚洲第一页在线播放 | 亚洲欧美日韩高清一区二区三区 | 免费一级a毛片夜夜看 | 亚洲综合专区 | 澳门毛片精品一区二区三区 | 亚洲精品高清久久 | 国产aaa女人十八毛片 | 大尺度人体自拍私拍337p | 久久精品播放 | 岛国片在线播放 | 香蕉eeww99国产在线观看 | 成人免费久久精品国产片久久影院 | 在线欧美成人 | 12306播播影院午夜片在线观看 | 91麻豆免费观看 | 国拍在线精品视频免费观看 | 久久精品免费 | 亚洲国产成人超福利久久精品 | 嫩草视频网站 | 欧美日韩亚洲国产一区二区综合 | 免费看黄色一级 | 欧美一区二区精品系列在线观看 | 国产色司机在线视频免费观看 | 日本xxxxx成年视频软件 | 亚洲高清美女一区二区三区 | 亚洲色图视频在线观看 | 国产精品日韩专区 | 国产在线精品一区二区中文 | 亚洲视频精品在线 | 国内亚州视频在线观看 | 成熟女人特级毛片www免费 | 亚洲一区二区三区在线网站 | 久久久国产精品福利免费 | 午夜激情福利在线 | 色yeye成人免费视频 | 国产九色在线 |