溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

django中模板的html自動轉(zhuǎn)意方法

發(fā)布時(shí)間:2020-10-07 18:25:50 來源:腳本之家 閱讀:154 作者:南窗客斯黃 欄目:開發(fā)技術(shù)

一、需求來源:

如果用戶在文本框中填了一段<script>alert(xxx);</script>代碼,然后我們還保存在了數(shù)據(jù)庫中,下次模板加載數(shù)據(jù)的時(shí)候,將這段代碼顯示在瀏覽器,將會彈出一個(gè)警告框。因此,這是XSS(跨域腳本)攻擊的一種方式,我們肯定不能允許這種事件發(fā)生,因此django默認(rèn)給我們啟動了自動轉(zhuǎn)意的功能。將這段代碼轉(zhuǎn)換成普通的文本進(jìn)行展示。

二、如何關(guān)閉:

你肯定會問既然自動轉(zhuǎn)意可以關(guān)閉XSS漏洞為什么需要關(guān)閉呢?原因很簡單,如果你數(shù)據(jù)庫中保存了一段可信任的HTML代碼,那么你肯定想將他插在頁面文檔中,這時(shí)候你肯定不想被當(dāng)成字符串處理。這時(shí)候你就可以針對某些模塊進(jìn)行關(guān)閉,django提供了兩種方式進(jìn)行關(guān)閉:

對單獨(dú)的變量,用safe過濾器為單獨(dú)的變量關(guān)閉自動轉(zhuǎn)意,比如:

這個(gè)data將會被轉(zhuǎn)意:{{ data }}
這個(gè)data不會被轉(zhuǎn)意:{{ data|safe }}

對模板塊,可以使用autoescape進(jìn)行統(tǒng)一管理,他有兩個(gè)參數(shù)off和on分別用來關(guān)閉和打開自動轉(zhuǎn)意,比如以下代碼關(guān)閉一整段代碼的自動轉(zhuǎn)意:

{% autoescape off %}
 name: {{ name }}
 age: {{ age }}
{% endautoescape %}

以下代碼先關(guān)閉自動轉(zhuǎn)意再打開自動轉(zhuǎn)意功能:

Auto-escaping is on by default. Hello {{ name }}
{% autoescape off %}
 This will not be auto-escaped: {{ data }}.
 Nor this: {{ other_data }}
 {% autoescape on %}
  Auto-escaping applies again: {{ name }}
 {% endautoescape %}
{% endautoescape %}

注意事項(xiàng):autoescape標(biāo)簽的作用域不僅可以影響到當(dāng)前模板還可以通過include標(biāo)簽以及block標(biāo)簽影響到其他的模板。這個(gè)一定要切記!

三:過濾器參數(shù)里的字符串常量的自動轉(zhuǎn)意:

{{ data|default:"no data" }}

分析以上代碼,如果視圖函數(shù)提供了data數(shù)據(jù),則會顯示data,如果沒有提供,則默認(rèn)會顯示no data。如果你要默認(rèn)顯示帶有/,<,",',&也不會進(jìn)行轉(zhuǎn)意,因此如果你要顯示3<1這樣帶有特殊字符的,將對html文檔產(chǎn)生結(jié)構(gòu)上的影響。但是你可以通過3&lt;1這種方式,進(jìn)行轉(zhuǎn)意輸出。

以上這篇django中模板的html自動轉(zhuǎn)意方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI