Django自定義過濾器中is_safe和need_autoescape兩個參數(shù)的理解

自定義template過濾器的方法參考文檔,不再贅述

is_safe

文檔說明過濾的兩種最終形態(tài),其中一種是設(shè)置register.filter(is_safe=True),但是對is_safe的具體作用說的云山霧繞的,而查了些博文只是簡單的說is_safe可以關(guān)閉掉自動轉(zhuǎn)義(這個說法是錯誤的!)
我嘗試了加或者不加is_safe的效果

@register.filter
def demo(value):
    return '<br>' + value

@register.filter(is_safe=True)
def demo(value):
    return '<br>' + value

<li> {{ text|demo}} </li>

結(jié)果就是都對過濾器返回的結(jié)果進(jìn)行了轉(zhuǎn)義!
后來發(fā)現(xiàn)重點(diǎn)在于文檔中的這一句話:

This flag tells Django that if a “safe” string is passed into your filter, the result will still be “safe” and if a non-safe string is passed in, Django will automatically escape it, if necessary.
這個標(biāo)志告訴Django 如果"安全"的字符串傳遞到您的過濾,結(jié)果仍將是"安全",如果一個非安全字符串傳遞柠硕,如果必要Django 會自動轉(zhuǎn)義它扒寄。

重點(diǎn)在于"安全",也就是文檔中提到的SafeData類型.文檔中有提到'某些正常的字符串操作會將SafeData對象轉(zhuǎn)換成普通的str或unicode對象,Django的過濾器在完成之后會修復(fù)這種破壞,并且很困難'.
這才是is_safe的意義所在:如果傳入的value已經(jīng)是SafeData對象,is_safe會告訴Django當(dāng)前過濾器輸出的數(shù)據(jù)不再需要轉(zhuǎn)義.
至于SafeData類型數(shù)據(jù)的來源,我暫時只知道mark_safe()函數(shù)會返回SafeData對象.

from django.utils.safestring import mark_safe

@register.filter()
def to_safe(value):
    return mark_safe(value)

@register.filter(is_safe=True)
def demo(value):
    return '<br>' + value

<li> {{ test|to_safe|demo }} </li>

這樣的情況,demo過濾器接收到一個SafeData對象,其結(jié)果不會再轉(zhuǎn)義(<br>換行符起作用了).

need_autoescape

如果在注冊過濾器時添加了need_autoescape=True,那么過濾器必須接收一個autoescape參數(shù),這樣過濾器會捕捉其引用位置的自動轉(zhuǎn)義是否開啟,以決定你在過濾器中的行為.
引用下文檔中的栗子:

@register.filter(needs_autoescape=True)
def initial_letter_filter(text, autoescape=True):
    first, other = text[0], text[1:]
    if autoescape:
        esc = conditional_escape
    else:
        esc = lambda x: x
    result = '<strong>%s</strong>%s' % (esc(first), esc(other))
    return mark_safe(result)

該過濾器的輸出通過mark_safe()函數(shù)標(biāo)記為"安全",這樣可以保證在過濾器中引入的HTML標(biāo)簽可以實(shí)現(xiàn).但是同樣要考慮輸入的安全問題.如果模板中autoescape是開啟的,說明我們已經(jīng)認(rèn)定這部分的數(shù)據(jù)是存在威脅的,所以需要在過濾器中手動對輸入數(shù)據(jù)進(jìn)行轉(zhuǎn)義來保證其安全性.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末茂缚,一起剝皮案震驚了整個濱河市甥绿,隨后出現(xiàn)的幾起案子携兵,更是在濱河造成了極大的恐慌,老刑警劉巖覆积,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件听皿,死亡現(xiàn)場離奇詭異,居然都是意外死亡宽档,警方通過查閱死者的電腦和手機(jī)尉姨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來吗冤,“玉大人又厉,你說我怎么就攤上這事⌒拦拢” “怎么了馋没?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長降传。 經(jīng)常有香客問我篷朵,道長,這世上最難降的妖魔是什么婆排? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任声旺,我火速辦了婚禮,結(jié)果婚禮上段只,老公的妹妹穿的比我還像新娘腮猖。我一直安慰自己,他們只是感情好赞枕,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布澈缺。 她就那樣靜靜地躺著,像睡著了一般炕婶。 火紅的嫁衣襯著肌膚如雪姐赡。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天柠掂,我揣著相機(jī)與錄音项滑,去河邊找鬼。 笑死涯贞,一個胖子當(dāng)著我的面吹牛枪狂,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播宋渔,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼州疾,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了皇拣?” 一聲冷哼從身側(cè)響起严蓖,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后谈飒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡态蒂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年杭措,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片钾恢。...
    茶點(diǎn)故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡手素,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出瘩蚪,到底是詐尸還是另有隱情泉懦,我是刑警寧澤,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布疹瘦,位于F島的核電站崩哩,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏言沐。R本人自食惡果不足惜邓嘹,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望险胰。 院中可真熱鬧汹押,春花似錦、人聲如沸起便。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽榆综。三九已至妙痹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間奖年,已是汗流浹背细诸。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留陋守,地道東北人震贵。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像水评,于是被迫代替她去往敵國和親猩系。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內(nèi)容