django中模板的html自動(dòng)轉(zhuǎn)意方法
一、需求來源:
如果用戶在文本框中填了一段<script>alert(xxx);</script>代碼,然后我們還保存在了數(shù)據(jù)庫(kù)中,下次模板加載數(shù)據(jù)的時(shí)候,將這段代碼顯示在瀏覽器,將會(huì)彈出一個(gè)警告框。因此,這是XSS(跨域腳本)攻擊的一種方式,我們肯定不能允許這種事件發(fā)生,因此django默認(rèn)給我們啟動(dòng)了自動(dòng)轉(zhuǎn)意的功能。將這段代碼轉(zhuǎn)換成普通的文本進(jìn)行展示。
二、如何關(guān)閉:
你肯定會(huì)問既然自動(dòng)轉(zhuǎn)意可以關(guān)閉XSS漏洞為什么需要關(guān)閉呢?原因很簡(jiǎn)單,如果你數(shù)據(jù)庫(kù)中保存了一段可信任的HTML代碼,那么你肯定想將他插在頁面文檔中,這時(shí)候你肯定不想被當(dāng)成字符串處理。這時(shí)候你就可以針對(duì)某些模塊進(jìn)行關(guān)閉,django提供了兩種方式進(jìn)行關(guān)閉:
對(duì)單獨(dú)的變量,用safe過濾器為單獨(dú)的變量關(guān)閉自動(dòng)轉(zhuǎn)意,比如:
這個(gè)data將會(huì)被轉(zhuǎn)意:{{ data }} 這個(gè)data不會(huì)被轉(zhuǎn)意:{{ data|safe }}
對(duì)模板塊,可以使用autoescape進(jìn)行統(tǒng)一管理,他有兩個(gè)參數(shù)off和on分別用來關(guān)閉和打開自動(dòng)轉(zhuǎn)意,比如以下代碼關(guān)閉一整段代碼的自動(dòng)轉(zhuǎn)意:
{% autoescape off %} name: {{ name }} age: {{ age }} {% endautoescape %}
以下代碼先關(guān)閉自動(dòng)轉(zhuǎn)意再打開自動(dòng)轉(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ù)里的字符串常量的自動(dòng)轉(zhuǎn)意:
{{ data|default:"no data" }}
分析以上代碼,如果視圖函數(shù)提供了data數(shù)據(jù),則會(huì)顯示data,如果沒有提供,則默認(rèn)會(huì)顯示no data。如果你要默認(rèn)顯示帶有/,<,",',&也不會(huì)進(jìn)行轉(zhuǎn)意,因此如果你要顯示3<1這樣帶有特殊字符的,將對(duì)html文檔產(chǎn)生結(jié)構(gòu)上的影響。但是你可以通過3<1這種方式,進(jìn)行轉(zhuǎn)意輸出。
以上這篇django中模板的html自動(dòng)轉(zhuǎn)意方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python使用metaclass實(shí)現(xiàn)Singleton模式的方法
這篇文章主要介紹了Python使用metaclass實(shí)現(xiàn)Singleton模式的方法,實(shí)例分析了Python基于metaclass實(shí)現(xiàn)單例模式的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-05-05對(duì)python讀取CT醫(yī)學(xué)圖像的實(shí)例詳解
今天小編就為大家分享一篇對(duì)python讀取CT醫(yī)學(xué)圖像的實(shí)例詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-01-01python實(shí)現(xiàn)切割url得到域名、協(xié)議、主機(jī)名等各個(gè)字段的例子
今天小編就為大家分享一篇python實(shí)現(xiàn)切割url得到域名、協(xié)議、主機(jī)名等各個(gè)字段的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-07-07python?使用turtle實(shí)現(xiàn)實(shí)時(shí)鐘表并生成exe
這篇文章主要為大家詳細(xì)介紹了python使用Turtle庫(kù)繪制動(dòng)態(tài)鐘表,并有需要可以生成exe可執(zhí)行文件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03Python常用base64 md5 aes des crc32加密解密方法匯總
這篇文章主要介紹了Python常用base64 md5 aes des crc32加密解密方法匯總,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11TensorFlow和keras中GPU使用的設(shè)置操作
這篇文章主要介紹了TensorFlow和keras中GPU使用的設(shè)置操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05python使用xmlrpclib模塊實(shí)現(xiàn)對(duì)百度google的ping功能
這篇文章主要介紹了python使用xmlrpclib模塊實(shí)現(xiàn)對(duì)百度google的ping功能,實(shí)例分析了xmlrpclib模塊的相關(guān)技巧,需要的朋友可以參考下2015-06-06