成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

前端安全編碼規(guī)范

開發(fā) 前端
下面就以前端可能受到的攻擊方式為起點,講解web中可能存在的安全漏洞以及如何去檢測這些安全漏洞,如何去防范潛在的惡意攻擊。

前言

隨著互聯(lián)網(wǎng)高速的發(fā)展,信息安全已經(jīng)成為企業(yè)重點關(guān)注焦點之一,而前端又是引發(fā)安全問題的高危據(jù)點,所以,作為一個前端開發(fā)人員,需要了解前端的安全問題,以及如何去預(yù)防、修復(fù)安全漏洞。

下面就以前端可能受到的攻擊方式為起點,講解web中可能存在的安全漏洞以及如何去檢測這些安全漏洞,如何去防范潛在的惡意攻擊。

1. 跨站腳本攻擊(Cross Sites Script)

跨站腳本攻擊,Cross Site Script(簡稱 CSS或)。指黑客通過“HTML注入”篡改了網(wǎng)頁,插入了惡意的腳本(主要是JavaScript腳本),從而在用戶瀏覽網(wǎng)頁時,控制用戶瀏覽器的一種攻擊。

了解了什么是XSS,那你一定想知道,它有什么危害以及如何去防御

這里羅列一張列表:

  •  掛馬
  •  盜取用戶Cookie。
  •  釣魚攻擊,高級的釣魚技巧。
  •  刪除目標(biāo)文章、惡意篡改數(shù)據(jù)、嫁禍。
  •  劫持用戶Web行為,甚至進(jìn)一步滲透內(nèi)網(wǎng)。
  •  爆發(fā)Web2.0蠕蟲。
  •  蠕蟲式掛馬攻擊、刷廣告、刷瀏量、破壞網(wǎng)上數(shù)據(jù)
  •  其它安全問題

常見的跨站腳本攻擊也可分為:反射型XSS、存儲型XSS、DOM Based XSS

下面針對這三種常見的類型做具體的分析

1.1 反射型XSS--也可被稱為是HTML注入

  1. 反射型XSS,也稱為"非持久型XSS"簡單的把用戶輸入的數(shù)據(jù)"反射"給瀏覽器,即黑客往往需要誘使用戶"點擊"一個惡意鏈接攻擊才能成功,用戶通過點擊這個惡意鏈接,攻擊者可以成功獲取用戶隱私數(shù)據(jù)的一種方式。如:"盜取用戶Cookie信息"、"破壞頁面結(jié)構(gòu)"、"重定向到其他網(wǎng)站",盜取內(nèi)網(wǎng)IP等。 

那么既然反射型XSS也可以是HTML注入,那么它注入的關(guān)鍵自然也就從前端的HTML頁面開始下手: 

  1. 1. 用戶能夠與瀏覽器頁面產(chǎn)生交互動作(輸入搜索的關(guān)鍵詞,點擊按鈕,點擊鏈接等等),但這些都需要去誘使用戶去操作,說起來容易,做起來難。  
  2. 2. 用戶輸入的數(shù)據(jù)會被攻擊方拼接出合適的html去執(zhí)行惡意的js腳本,這樣的過程就像是"一次反射" 

1.2 存儲型XSS 

  1. 存儲型XSS,也稱為"`持久型XSS`",它與`反射型XSS`不同之處在于,它會將用戶輸入的數(shù)據(jù)"存儲"在攻擊方的服務(wù)器上,具有很強(qiáng)的"穩(wěn)定性"。  
  2. 例如:訪問某黑客寫下的一篇含有惡意JavaScript代碼的博客文章,黑客把惡意腳本保存到服務(wù)端。 

1.3 DOM based XSS 

  1. 從效果上來說,也是"反射型XSS",單獨劃分出來,是因為其形成是通過修改頁面的"DOM節(jié)點"形成的XSS。  
  2. 例如:通過修改DOM節(jié)點上的綁定方法,用戶無意間通過點擊、輸入等行為執(zhí)行這些方法獲取到用戶的相關(guān)信息 

1.4 如何去檢測是否存在XSS

一般方法是,用戶可以在有關(guān)鍵字輸入搜索的地方輸入<script>alert(123)</script>后點擊搜索,若彈框出現(xiàn)展示123,說明存在XSS漏洞,這就說明前端并沒有對用戶輸入的內(nèi)容過濾處理。

1.5 XSS的攻擊方式

1.Cookie劫持 

  1. 通過偽裝一些`圖片和按鈕`等,誘使用戶對其操作,使網(wǎng)頁執(zhí)行了攻擊者的惡意腳本,使攻擊者能夠獲取當(dāng)前用戶的Cookie信息 

2.構(gòu)造GET和POST請求

  1. 若某攻擊者想刪除某網(wǎng)站的一篇文章,首先獲得當(dāng)前文章的id,然后通過使用腳本`插入圖片`發(fā)送一個`GET請求`,或`構(gòu)造表單`,`XMLHTTPRequest`發(fā)送`POST請求`以達(dá)到刪除該文章的目的 

3.XSS釣魚 

  1. `釣魚`這個詞一般認(rèn)識是起源于`社會工程學(xué)`,黑客使用這個這門學(xué)科的理念思想,在未授權(quán)不知情的情況下誘騙用戶,并得到對方對方的姓名、年齡、郵箱賬號、甚至是銀行卡密碼等私人信息。  
  2. 比如:"某用戶在某網(wǎng)站(已被攻擊)上操作黑客偽造的一個登錄框,當(dāng)用戶在登錄框中輸入了用戶名(這里可能是身份證號等)和密碼之后,將其信息上傳至黑客的服務(wù)器上(該用戶的信息就已經(jīng)從該網(wǎng)站泄漏)" 

4.獲取用戶真實的IP地址

通過第三方軟件獲取,比如客戶端安裝了Java環(huán)境(JRE),則可通過調(diào)用`Java Applet`的接口獲取客戶端本地的IP地址

1.6 XSS的防御方式

1.HttpOnly

原理:瀏覽器禁止頁面的Javascript訪問帶有HttpOnly屬性的cookie。(實質(zhì)解決的是:XSS后的cookie劫持攻擊)如今已成為一種“標(biāo)準(zhǔn)”的做法 

  1. 解決方案:  
  2. JavaEE給Cookie添加HttpOnly的方式為:  
  3. response.setHeader("Set-Cookie","cookiename=valuePath=/;Domain=domainvalue;Max-Age=seconds;HTTPOnly"); 

2.輸入檢查(XSS Filter) 

  1. 原理:讓一些基于特殊字符的攻擊失效。(常見的Web漏洞如XSS、SQLInjection等,都要求攻擊者構(gòu)造一些特殊字符)  
  2. * 輸入檢查的邏輯,必須在服務(wù)端實現(xiàn),因為客戶端的檢查也是很容易被攻擊者繞過,現(xiàn)有的普遍做法是兩端都做同樣的檢查,客戶端的檢查可以阻擋大部分誤操作的正常用戶,從而節(jié)約服務(wù)器的資源。  
  3. 解決方案:  
  4. 檢查是否包含"JavaScript","<script></script>"等敏感字符。以及對字符串中的<>:"&/'等特殊字符做處理 

3.輸出檢查 

  1. 原理:一般來說除了富文本輸出之外,在變量輸出到HTML頁面時,使用編碼或轉(zhuǎn)義的方式來防御XSS攻擊  
  2. 解決方案:  
  3. *   針對HTML代碼的編碼方式:HtmlEncode  
  4. *   PHP:htmlentities()和htmlspecialchars()兩個函數(shù)  
  5. *   Javascript:JavascriptEncode(需要使用""對特殊字符進(jìn)行轉(zhuǎn)義,同時要求輸出的變量必須在引號內(nèi)部)  
  6. *   在URL的path(路徑)或者search(參數(shù))中輸出,使用URLEncode 

4.更嚴(yán)格的做法

  1. 除了數(shù)字和字母外的所有字符,都使用十六進(jìn)制的方式進(jìn)行編碼 

2. 跨站點請求偽造(Cross Sites Request Forgery)

跨站點請求偽造,指利用用戶身份操作用戶賬戶的一種攻擊方式,即攻擊者誘使用戶訪問一個頁面,就以該用戶身份在第三方有害站點中執(zhí)行了一次操作,泄露了用戶的身份信息,接著攻擊者就可以使用這個偽造的,但真實存在的身份信息,到某網(wǎng)站冒充用戶執(zhí)行惡意操作。

但是,攻擊者只有預(yù)測到URL的所有參數(shù)與參數(shù)值,才能成功地偽造一個請求(當(dāng)然了,他可以在安全站點里以自己的身份實際去操作一下,還是能拿到參數(shù)的);反之,攻擊者無法攻擊成功

下圖通俗解釋什么是CSRF,又是如何給用戶帶來危害的

參考上圖,我們可以總結(jié),完成一次CSRF攻擊,必須滿足兩個條件

  •  用戶登錄受信任網(wǎng)站A,并且在本地生成Cookie
  •  在不登出網(wǎng)站A的情況下,訪問有害網(wǎng)站B

2.1 CSRF的原理 

  1. CSRF攻擊是攻擊者利用**`用戶身份`**操作用戶賬戶的一種攻擊方式  
  2. 如電影速度與激情5中吉賽爾使用內(nèi)褲獲取巴西大佬指紋,最后成功使用偽造指紋的手法打開保險柜,CSRF只不過是網(wǎng)絡(luò)上這個手法的實現(xiàn)。 

2.2 CSRF的攻擊方式

1.瀏覽器的Cookie策略 

  1. 瀏覽器所持有的策略一般分為兩種:  
  2. Session Cookie,臨時Cookie。保存在瀏覽器進(jìn)程的內(nèi)存中,瀏覽器關(guān)閉了即失效。  
  3. Third-party Cookie,本地Cookie。服務(wù)器在Set-Cookie時指定了Expire Time。過期了本地Cookie失效,則網(wǎng)站會要求用戶重新登錄。 

* 在瀏覽網(wǎng)站的過程中,即使瀏覽器打開了Tab頁,Session Cookie都是有效的,因此發(fā)起CSRF攻擊是可行的。

2.P3P頭的副作用 

  1. "P3P Header"是 "W3C" 制定的一項關(guān)于隱私的標(biāo)準(zhǔn),全稱是 "The Platform for Privacy Preference"(隱私偏好平臺)  
  2. 如果網(wǎng)站返回給瀏覽器的 HTTP 頭包含有 P3P 頭,則在某種程度上來說,將允許 瀏覽器發(fā)送第三方 Cookie。在 IE 下即使是"<iframe>"、`<script>`等標(biāo)簽頁將不再攔截第三方 Cookie 的發(fā)送。主要應(yīng)用在類似廣告等需要跨域訪問的頁面。 

 3.GET,POST請求 

  1. * 這里有個誤區(qū)  
  2. 大多數(shù) CSRF 攻擊,都是通過 <img> 、 <iframe> 、 <script> 等帶 src 屬性的標(biāo)簽,這類標(biāo)簽只能發(fā)送一次 GET 請求,而不能發(fā)送 POST 請求,由此也有了認(rèn)為 CSRF 攻擊只能由 GET 請求發(fā)起的錯誤觀點。 
  3. 構(gòu)造一個 POST 請求,只需要在一個不可見的iframe窗口中,構(gòu)造一個form表單,然后使用JavaScript自動提交這個表單。那么整個自動提交表單的過程,對于用戶來說就是不可見的。 

2.3 CSRF的防御方式

1.驗證碼 

  1. 原理:  
  2. CSRF攻擊過程中,用戶在不知情的情況下構(gòu)造了網(wǎng)絡(luò)請求,添加驗證碼后,強(qiáng)制用戶必須與應(yīng)用進(jìn)行交互  
  3. *  優(yōu)點:簡潔而有效  
  4. *  缺點:網(wǎng)站不能給所有的操作都加上驗證碼 

2.Referer Check 

  1. 原理:  
  2. * 利用HTTP頭中的Referer判斷請求來源是否合法  
  3. * Referer首部包含了當(dāng)前請求頁面的來源頁面的地址,一般情況下Referer的來源頁就是發(fā)起請求的那個頁面,如果是在iframe中發(fā)起的請求,那么對應(yīng)的頁面URL就是iframe的src  
  4. *  優(yōu)點:簡單易操作(只需要在最后給所有安全敏感的請求統(tǒng)一添加一個攔截器來檢查Referer的值就行)  
  5. *  缺點:服務(wù)器并非什么時候都能取到Referer  
  6.         1.很多出于保護(hù)用戶隱私的考慮,限制了Referer的發(fā)送。  
  7.         2.比如從HTTPS跳轉(zhuǎn)到HTTP,出于安全的考慮,瀏覽器不會發(fā)送Referer 

3.使用Anti CSRF Token 

  1. 原理:把參數(shù)加密,或者使用一些隨機(jī)數(shù),從而讓攻擊者無法猜測到參數(shù)值,也就無法構(gòu)造請求的 URL,也就無法發(fā)起 CSRF 攻擊。  
  2. 例子(增加token):  
  3. *  比如一個刪除操作的URL是:`http://host/path/delete?uesrname=abc&item=123 
  4. *  保持原參數(shù)不變,新增一個參數(shù)Token,Token值是隨機(jī)的,不可預(yù)測  
  5. *  http://host/path/delete?username=abc&item=123&token=[random(seed)]  
  6. *  優(yōu)點:比檢查Referer方法更安全,并且不涉及用戶隱私  
  7. *  缺點:  
  8.         加密  
  9.         1. 加密后的URL非常難讀,對用戶非常不友好  
  10.         2. 加密的參數(shù)每次都在改變,導(dǎo)致用戶無法對頁面進(jìn)行搜索  
  11.         3. 普通參數(shù)也會被加密或哈希,將會給DBA工作帶來很大的困擾,因為數(shù)據(jù)分析常常需要用到參數(shù)的明文     
  12.          token  
  13.         1. 對所有的請求都添加Token比較困難 

需要注意的點

  1.  Token需要足夠隨機(jī),必須用足夠安全的隨機(jī)數(shù)生成算法
  2.  Token應(yīng)該為用戶和服務(wù)器所共同持有,不能被第三方知曉
  3.  Token可以放在用戶的Session或者瀏覽器的Cookie中
  4.  盡量把Token放在表單中,把敏感操作由GET改為POST,以form表單的形式提交,可以避免Token泄露(比如一個頁面:http://host/path/manage?username=abc&token=[random],在此頁面用戶需要在這個頁面提交表單或者單擊“刪除”按鈕,才能完成刪除操作,在這種場景下,如果這個頁面包含了一張攻擊者能指定地址的圖片<img src="http://evil.com/notexist" />,則這個頁面地址會作為HTTP請求的Refer發(fā)送到evil.com的服務(wù)器上,從而導(dǎo)致Token泄露)

2.4 XSRF

當(dāng)網(wǎng)站同時存在XSS和CSRF漏洞時,XSS可以模擬客戶端瀏覽器執(zhí)行任意操作,在XSS攻擊下,攻擊者完全可以請求頁面后,讀取頁面內(nèi)容中的Token值,然后再構(gòu)造出一個合法的請求

3. 點擊劫持(ClickJacking)

點擊劫持是一種視覺上的欺騙手段。攻擊者使用一個透明的、不可見的iframe,覆蓋在一個網(wǎng)頁上,然后誘使用戶在網(wǎng)頁上進(jìn)行操作,此時用戶將在不知情的情況下點擊透明的iframe頁面。通過調(diào)整iframe頁面的位置,可以誘使用戶恰好點擊在iframe頁面的一些功能性按鈕上。

比如,程序員小王在訪問A網(wǎng)頁時,點擊空白區(qū)域,瀏覽器卻意外打開了xx新葡京賭場的頁面,于是他在A網(wǎng)頁打開控制臺,在空白區(qū)域發(fā)現(xiàn)了一個透明的iframe,該iframe嵌入了一個第三方網(wǎng)頁的URL

3.1 點擊劫持防御方式 

  1. 1.X-Frame-Options HTTP響應(yīng)頭是用來給瀏覽器指示允許一個頁面能否在`<frame><iframe><object>`中展現(xiàn)的標(biāo)記  
  2. #### 有三個可選的值  
  3. 1.  DENY:瀏覽器會拒絕當(dāng)前頁面加載任何frame頁面(即使是相同域名的頁面也不允許)  
  4. 2.  SAMEORIGIN:允許加載frame頁面,但是frame頁面的地址只能為同源域名下的頁面  
  5. 3.  ALLOW-FROM:可以加載指定來源的frame頁面(可以定義frame頁面的地址)  
  6. 2.禁止iframe的嵌套  
  7. if(window.top.location !== window.loaction){window.top.location === window.self.location} 

4. 其他安全問題 

  1. 4.1 跨域問題處理 
  2.     當(dāng)服務(wù)端設(shè)置 'Access-Control-Allow-Origin' 時使用了通配符 "*",允許來自任意域的跨域請求,這是極其危險的  
  3. 4.2 postMessage 跨窗口傳遞信息  
  4.     postMessage 允許每一個 window(包括當(dāng)前窗口、彈出窗口、iframes等)對象往其他的窗口發(fā)送文本消息,從而實現(xiàn)跨窗口的消息傳遞。并且這個功能不受同源策略限制。  
  5.     必要時,在接受窗口驗證 Domain,甚至驗證URL,以防止來自非法頁面的消息。實際上是在代碼上實現(xiàn)一次同源策略的驗證過程。接受窗口對接口的信息進(jìn)行安全檢查。   
  6.  4.3 Web Storage  
  7.     Web Storage 分為 Session Storage 和 Local Storage。  
  8.     雖然受同源策略的約束,但當(dāng)存有敏感信息時,也可能會成為攻擊的目標(biāo)。   

 5. 總結(jié)

  1.  謹(jǐn)慎用戶輸入信息,進(jìn)行輸入檢查(客戶端和服務(wù)端同時檢查)
  2.  在變量輸出到HTML頁面時,都應(yīng)該進(jìn)行編碼或轉(zhuǎn)義來預(yù)防XSS攻擊
  3.  該用驗證碼的時候一定要添上
  4.  盡量在重要請求上添加Token參數(shù),注意Token要足夠隨機(jī),用足夠安全的隨機(jī)數(shù)生成算法 

 

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2012-05-25 13:54:18

JavaScript

2013-04-08 10:33:54

編碼編碼規(guī)范

2015-03-18 09:34:47

程序員編碼規(guī)范

2020-04-16 21:02:35

前端命名規(guī)范html規(guī)范

2009-08-03 17:07:13

ASP.NET編程規(guī)范

2020-08-19 15:30:04

PHP網(wǎng)絡(luò)安全代碼

2010-01-05 09:35:07

.Net Framew

2011-08-04 09:35:09

Objective-C 編碼規(guī)范

2009-08-26 10:09:22

C#編碼規(guī)范

2018-10-06 05:00:53

2010-03-01 09:19:10

WCF編碼規(guī)范

2011-09-26 10:50:16

JavaScript

2009-10-26 13:13:17

VB.NET編碼規(guī)范

2011-11-01 10:12:09

Web

2009-10-22 11:28:35

VB.NET編碼規(guī)范

2010-03-03 15:26:54

Python編碼規(guī)范

2012-06-29 09:27:51

2012-06-28 09:45:58

2023-08-28 16:22:06

2013-10-18 16:51:36

前端安全javascript代碼安全
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲欧美中文日韩在线v日本 | 久久精品视频一区二区 | 操操操av | 91精品国产综合久久久久久首页 | a视频在线观看 | 国产一级影片 | 日韩国产精品一区二区三区 | 日本 欧美 国产 | 久久综合狠狠综合久久综合88 | 欧美日韩亚洲一区 | 日韩二区 | 国产综合av | 男女视频在线观看免费 | 精品一区二区三区在线观看 | 99re视频在线 | 日韩在线中文字幕 | 精精久久 | 日本 欧美 国产 | 99久久精品免费看国产四区 | 欧美视频一区二区三区 | 97av视频在线观看 | 欧美三级视频 | 在线日韩精品视频 | 欧美日韩视频在线 | 中文字幕在线免费 | 久久久久国产一区二区三区不卡 | 一区二区三区四区av | 精产国产伦理一二三区 | 欧美自拍第一页 | 91精品国产一区 | 亚洲97| 成人h免费观看视频 | 久久免费电影 | 日韩在线不卡视频 | 欧美99久久精品乱码影视 | 国内精品久久久久久 | 日韩不卡一区二区三区 | 91玖玖| 成人免费网站在线 | 欧美性猛交 | 草久在线视频 |