国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Python > 正文

在Python的Django框架中使用通用視圖的方法

2019-11-25 17:09:14
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

使用通用視圖的方法是在URLconf文件中創(chuàng)建配置字典,然后把這些字典作為URLconf元組的第三個(gè)成員。

例如,下面是一個(gè)呈現(xiàn)靜態(tài)“關(guān)于”頁(yè)面的URLconf:

from django.conf.urls.defaults import *from django.views.generic.simple import direct_to_templateurlpatterns = patterns('',  (r'^about/$', direct_to_template, {    'template': 'about.html'  }))

一眼看上去似乎有點(diǎn)不可思議,不需要編寫(xiě)代碼的視圖! 它和第八章中的例子完全一樣:direct_to_template視圖僅僅是直接從傳遞過(guò)來(lái)的額外參數(shù)獲取信息并用于渲染視圖。

因?yàn)橥ㄓ靡晥D都是標(biāo)準(zhǔn)的視圖函數(shù),我們可以在我們自己的視圖中重用它。 例如,我們擴(kuò)展 about例子,把映射的URL從 /about//修改到一個(gè)靜態(tài)渲染 about/.html 。 我們首先修改URL配置以指向新的視圖函數(shù):

from django.conf.urls.defaults import *from django.views.generic.simple import direct_to_template**from mysite.books.views import about_pages**urlpatterns = patterns('',  (r'^about/$', direct_to_template, {    'template': 'about.html'  }),  **(r'^about/(/w+)/$', about_pages),**)

接下來(lái),我們編寫(xiě) about_pages 視圖的代碼:

from django.http import Http404from django.template import TemplateDoesNotExistfrom django.views.generic.simple import direct_to_templatedef about_pages(request, page):  try:    return direct_to_template(request, template="about/%s.html" % page)  except TemplateDoesNotExist:    raise Http404()

在這里我們象使用其他函數(shù)一樣使用 direct_to_template 。 因?yàn)樗祷匾粋€(gè)HttpResponse對(duì)象,我們只需要簡(jiǎn)單的返回它就好了。 這里唯一有點(diǎn)棘手的事情是要處理找不到模板的情況。 我們不希望一個(gè)不存在的模板導(dǎo)致一個(gè)服務(wù)端錯(cuò)誤,所以我們捕獲TemplateDoesNotExist異常并且返回404錯(cuò)誤來(lái)作為替代。

這里有沒(méi)有安全性問(wèn)題?

眼尖的讀者可能已經(jīng)注意到一個(gè)可能的安全漏洞: 我們直接使用從客戶(hù)端瀏覽器得到的數(shù)據(jù)構(gòu)造模板名稱(chēng)(template="about/%s.html" % page )。乍看起來(lái),這像是一個(gè)經(jīng)典的 目錄跨越(directory traversal) 攻擊(詳情請(qǐng)看第20章)。 事實(shí)真是這樣嗎?

完全不是。 是的,一個(gè)惡意的 page 值可以導(dǎo)致目錄跨越,但是盡管 page 是 從請(qǐng)求的URL中獲取的,但并不是所有的值都會(huì)被接受。 這就是URL配置的關(guān)鍵所在: 我們使用正則表達(dá)式 /w+ 來(lái)從URL里匹配 page ,而 /w 只接受字符和數(shù)字。 因此,任何惡意的字符 (例如在這里是點(diǎn) . 和正斜線(xiàn) / )將在URL解析時(shí)被拒絕,根本不會(huì)傳遞給視圖函數(shù)。

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 民乐县| 宁城县| 汤原县| 东阳市| 卫辉市| 彭州市| 大邑县| 宜昌市| 习水县| 潍坊市| 宜昌市| 东港市| 永吉县| 嘉荫县| 玉门市| 稷山县| 荔波县| 台中市| 河南省| 额敏县| 五台县| 岑溪市| 麻城市| 汉寿县| 页游| 平谷区| 平和县| 宜良县| 桑日县| 沂水县| 辉县市| 黄冈市| 建平县| 新和县| 洱源县| 紫阳县| 都昌县| 北流市| 德清县| 苏州市| 曲阳县|