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

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

Django如何實現防止XSS攻擊

瀏覽:7日期:2024-09-20 15:06:43

一、什么是XSS攻擊

xss攻擊:----->web注入

  xss跨站腳本攻擊(Cross site script,簡稱xss)是一種“HTML注入”,由于攻擊的腳本多數時候是跨域的,所以稱之為“跨域腳本”。

我們常常聽到“注入”(Injection),如SQL注入,那么到底“注入”是什么?注入本質上就是把輸入的數據變成可執行的程序語句。SQL注入是如此,XSS也如此,只不過XSS一般注入的是惡意的腳本代碼,這些腳本代碼可以用來獲取合法用戶的數據,如Cookie信息。

PS: 把用戶輸入的數據以安全的形式顯示,那只能是在頁面上顯示字符串。

django框架中給數據標記安全方式顯示(但這種操作是不安全的!):

 - 模版頁面上對拿到的數據后寫上safe. ----> {{XXXX|safe}}  - 在后臺導入模塊:from django.utils.safestring import mark_safe

  把要傳給頁面的字符串做安全處理 ----> s = mark_safe(s)

二、測試代碼

實施XSS攻擊需要具備兩個條件:

一、需要向web頁面注入惡意代碼;

二、這些惡意代碼能夠被瀏覽器成功的執行。

解決辦法:

1、一種方法是在表單提交或者url參數傳遞前,對需要的參數進行過濾。

2、在后臺對從數據庫獲取的字符串數據進行過濾,判斷關鍵字。

3、設置安全機制。

django框架:內部機制默認阻止了。它會判定傳入的字符串是不安全的,就不會渲染而以字符串的形式顯示。如果手賤寫了safe,那就危險了,若想使用safe,那就必須在后臺對要渲染的字符串做過濾了。所以在開發的時候,一定要慎用安全機制。尤其是對用戶可以提交的并能渲染的內容!!!

這里是不存在xss漏洞的寫法,因為django已經做了防攻擊措施

index.html

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><body><h1>評論</h1>{% for item in msg %}{# <div>{{ item|safe }}</div>#} #這里被注釋的,是因為,|safe 加了這個就認為是安全的了,寫入 <script> alert(123)</script> 就會惡意加載 <div>{{ item}}</div>{% endfor %}</body></html>

conment.html

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><body><form action='/comment/' method='POST'> <input type='text' name='content'> <input type='submit' value='提交'></form></body></html>

views.py

from django.shortcuts import render,HttpResponse# Create your views here.msg = []def comment(request): if request.method == 'GET': return render(request,'comment.html') else: v = request.POST.get('content') msg.append(v) return render(request,'comment.html')def index(request): return render(request,'index.html',{'msg':msg})########################################################def test(request): from django.utils.safestring import mark_safe temp = '<a href=’http://www.baidu.com’>百度</a>' newtemp = mark_safe(temp) #這里相當于加了 |safe ,把字符串認為是安全的,執行代碼,如果不加 test.html里面 {{ temp }} 就只會顯示出字符串,而不是 a 標簽 return render(request,’test.html’,{’temp’:newtemp})

urls.py

from app01 import viewsurlpatterns = [ url(r’^admin/’, admin.site.urls), url(r’^index/’, views.index), url(r’^comment/’,views.comment),]

------------------------------------######################_-------------------------------

以下是做了用戶輸入判斷,檢測是否有特殊字符

views.py

from django.shortcuts import render,HttpResponse# Create your views here.msg = []def comment(request): if request.method == 'GET': return render(request,'comment.html') else: v = request.POST.get('content') if 'script' in v: return render(request, 'comment.html',{’error’:’小比崽子’}) else: msg.append(v) return render(request,’comment.html’)def index(request): return render(request,'index.html',{'msg':msg})

index.html

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><body><h1>評論</h1>{% for item in msg %} <div>{{ item|safe }}</div>{# <div>{{ item}}</div>#}{% endfor %}</body></html>

comment.html

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><body><form action='/comment/' method='POST'> <input type='text' name='content'> <input type='submit' value='提交'>{{ error }}</form></body></html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 婷婷丁香色综合图亚洲 | 免费人成黄页在线观看69 | 国产精品视频人人做人人爱 | 91精品国产欧美一区二区 | 日韩黄毛片 | 柠檬福利视频在线观看 | 成年人网站在线观看视频 | 91久久青青草原线免费 | 免费又黄又爽又猛大片午夜 | 亚洲欧美日韩激情在线观看 | 免费大片网站 | www.看片 | 亚洲欧美日韩国产精品网 | 伊人久久综合网亚洲 | 农村妇女又色黄一级毛片 | 久久精品在线观看 | 性做久久久久久久久男女 | 国产一级做a爰片久久毛片 国产一级做a爰片久久毛片99 | 麻豆视频在线观看免费 | 一道本色| 国产91精品一区二区视色 | 欧美性性性性性色大片免费的 | 国产a级男女性高爱潮片 | 成人国产永久福利看片 | 99爱在线视频这里只有精品 | 精彩视频一区二区三区 | 人妇出轨三级香港 | 国产成人精品日本亚洲专 | 黄色一级录像 | 91视频观看免费 | 欧美日韩 国产区 在线观看 | 激情在线日韩视频免费 | 欧美一级看片a免费观看 | 亚洲绝美精品一区二区 | 亚洲一区二区三区高清不卡 | 女人帮男人橹的视频网站 | 午夜日韩久久影院 | 国产v精品成人免费视频71sao | 亚洲高清视频免费 | 国自产拍在线视频天天更新 | 黄色短视频在线播放 |