日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Django如何實(shí)現(xiàn)防止XSS攻擊

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

一、什么是XSS攻擊

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

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

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

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

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

 - 模版頁(yè)面上對(duì)拿到的數(shù)據(jù)后寫(xiě)上safe. ----> {{XXXX|safe}}  - 在后臺(tái)導(dǎo)入模塊:from django.utils.safestring import mark_safe

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

二、測(cè)試代碼

實(shí)施XSS攻擊需要具備兩個(gè)條件:

一、需要向web頁(yè)面注入惡意代碼;

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

解決辦法:

1、一種方法是在表單提交或者url參數(shù)傳遞前,對(duì)需要的參數(shù)進(jìn)行過(guò)濾。

2、在后臺(tái)對(duì)從數(shù)據(jù)庫(kù)獲取的字符串?dāng)?shù)據(jù)進(jìn)行過(guò)濾,判斷關(guān)鍵字。

3、設(shè)置安全機(jī)制。

django框架:內(nèi)部機(jī)制默認(rèn)阻止了。它會(huì)判定傳入的字符串是不安全的,就不會(huì)渲染而以字符串的形式顯示。如果手賤寫(xiě)了safe,那就危險(xiǎn)了,若想使用safe,那就必須在后臺(tái)對(duì)要渲染的字符串做過(guò)濾了。所以在開(kāi)發(fā)的時(shí)候,一定要慎用安全機(jī)制。尤其是對(duì)用戶可以提交的并能渲染的內(nèi)容!!!

這里是不存在xss漏洞的寫(xiě)法,因?yàn)閐jango已經(jīng)做了防攻擊措施

index.html

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><body><h1>評(píng)論</h1>{% for item in msg %}{# <div>{{ item|safe }}</div>#} #這里被注釋的,是因?yàn)椋瑋safe 加了這個(gè)就認(rèn)為是安全的了,寫(xiě)入 <script> alert(123)</script> 就會(huì)惡意加載 <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) #這里相當(dāng)于加了 |safe ,把字符串認(rèn)為是安全的,執(zhí)行代碼,如果不加 test.html里面 {{ temp }} 就只會(huì)顯示出字符串,而不是 a 標(biāo)簽 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),]

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

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

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>評(píng)論</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>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Django
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美精品一二| 国产一区二区久久久久| 久久精品国产www456c0m| 日韩免费福利视频| 久久国产精品成人免费观看的软件| se01亚洲视频 | 国产一区二区三区不卡视频网站 | 日本不卡一区二区三区| 日韩精品成人| 九九九精品视频| 久久婷婷一区| 另类亚洲自拍| 日韩精品视频网| 国产成人免费精品| 久久精品国产www456c0m| 蜜臀精品一区二区三区在线观看| 日韩av影院| 老牛影视精品| 美女精品在线观看| 久久激五月天综合精品| 不卡专区在线| 久久亚洲风情| 国产一区二区三区天码| 日韩网站在线| 免费视频一区二区三区在线观看| 日韩久久精品| 在线国产日韩| 欧美国产美女| 亚洲精品自拍| 国产调教精品| 国产尤物精品| 国产精品一区二区99| 久久九九国产| 视频一区中文字幕精品| 97在线精品| 日本不卡的三区四区五区| а√天堂8资源中文在线| 视频一区视频二区在线观看| 久久99国产精品视频| 欧美日韩国产高清电影| 国产精品日本一区二区不卡视频| 亚洲精品电影| 国产66精品| 婷婷精品久久久久久久久久不卡| 黄色欧美在线| 日韩在线黄色| 91精品蜜臀一区二区三区在线| 青青伊人久久| 妖精视频成人观看www| 国产精品免费99久久久| 日韩av自拍| 欧美一区二区性| 国产精品2区| 免费观看在线综合色| 日韩在线观看不卡| 国产欧美亚洲一区| 鲁大师影院一区二区三区| 日韩深夜视频| 啪啪亚洲精品| 国产99久久| 精品精品国产三级a∨在线| 天堂va在线高清一区| 亚洲欧美网站| 久久久久免费| 久久www成人_看片免费不卡| 欧美亚洲精品在线| 国产精品蜜月aⅴ在线| 午夜亚洲精品| 中文字幕在线高清| 国产极品久久久久久久久波多结野| 欧美+亚洲+精品+三区| 精品五月天堂| 国产精品一区二区精品| 亚洲ab电影| 91精品精品| 欧美日韩免费观看视频| 精品国产乱码久久久久久樱花| 日韩激情综合| 亚洲精品高潮| 日韩中文字幕一区二区三区| 性感美女一区二区在线观看| 国产一区二区三区四区二区| 日本aⅴ亚洲精品中文乱码| 久久久精品日韩| 国产精品99一区二区三| 欧美一级二级三级视频| 亚洲一区二区日韩| 香蕉久久久久久久av网站| 亚洲第一区色| 一本大道色婷婷在线| 国产一区二区三区不卡视频网站 | 国产精品欧美大片| 蜜桃一区二区三区在线| 免播放器亚洲| 蜜桃久久av| 四虎精品永久免费| 久久人人99| 在线视频观看日韩| 国内亚洲精品| 亚洲欧洲一区二区天堂久久| 午夜国产一区二区| 亚洲国产不卡| 亚洲欧美日本日韩| 奶水喷射视频一区| 亚洲一区二区免费在线观看| 日本亚洲最大的色成网站www | 人人草在线视频| 日韩一区二区在线免费| 精品三级久久久| 四虎8848精品成人免费网站| 精品视频99| 亚洲精品一区三区三区在线观看| 精品日韩视频| 五月综合激情| 亚洲视频国产精品| 欧美日本一区| 国产精品久久乐| 国内自拍视频一区二区三区| 九色porny丨国产首页在线| 国产亚洲精品久久久久婷婷瑜伽| 首页欧美精品中文字幕| 不卡一区2区| 久久久91麻豆精品国产一区| 不卡中文一二三区| 日韩精品专区| 久久99久久久精品欧美| 日韩国产欧美三级| 一区在线免费观看| 99国产精品私拍| 中文字幕日韩欧美精品高清在线| 精品视频91| 天堂а√在线最新版中文在线| 久久精品青草| 亚洲精品中文字幕99999| 精品一区二区三区的国产在线观看| 日韩欧美自拍| 亚州av日韩av| 涩涩av在线| 亚洲人成亚洲精品| 手机在线电影一区| 蜜桃视频在线观看一区| 成人综合一区| 亚洲久草在线| 欧洲av不卡| 青草国产精品| 久久久久久久久丰满| 日韩免费精品| 三级小说欧洲区亚洲区| 日本一区二区中文字幕| av资源新版天堂在线| 蜜臀91精品一区二区三区| 成人国产精品一区二区免费麻豆| 另类av一区二区| 亚洲黄色免费av| 91九色综合| 亚洲欧美久久| 一本大道色婷婷在线| 国产一卡不卡| 一区在线免费| 久久电影tv| 日韩欧美中文字幕电影| 日韩美女一区二区三区在线观看| 日韩有吗在线观看| 欧美一区二区三区高清视频| 国产精品66| 一级成人国产| 亚洲第一区色| 国产一区一一区高清不卡| 亚洲精品成人一区| 宅男在线一区| 成人综合一区| 婷婷视频一区二区三区| 亚洲国产日韩欧美在线| 国产不卡精品在线| 精品三级av| 国产精品一区二区三区美女| 日韩一级不卡| 日韩欧美一区免费| 精品一区91| 国产精品丝袜在线播放| 在线看片日韩| 亚洲深夜影院| 欧美成人日韩| 国产精品亚洲一区二区三区在线观看| 国产精品红桃| 日韩激情一二三区| 综合国产精品| 免费人成在线不卡| 狠狠色综合网| 欧美 日韩 国产一区二区在线视频 | 老牛国内精品亚洲成av人片| 综合激情视频| 麻豆亚洲精品| 亚洲精品网址| 欧美.日韩.国产.一区.二区| 99久久婷婷| 久久久久午夜电影| 群体交乱之放荡娇妻一区二区| 91青青国产在线观看精品| 久久精品三级|