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

Web安全之實(shí)戰(zhàn):跨站腳本攻擊XSS

開發(fā) 前端
今天,泥瓦匠帶你們認(rèn)識(shí)下XSS,然后關(guān)于怎么防御的問題。至于防御的話,仁者見仁智者見智。爾等啥都不配不上的就綽見,望各位閱讀者相互討論。泥瓦匠目前是搞JAVA的,所以例子上JAVA比較多。

Writer:BYSocket(泥沙磚瓦漿木匠)

Reprint it anywhere u want.

文章Points:

1. 認(rèn)識(shí)XSS

2. XSS攻擊

3. XSS防御(重點(diǎn))

一、認(rèn)識(shí)XSS先

先說個(gè)故事吧,在上一篇,我還想說這個(gè)案例。其實(shí)什么叫攻擊,很簡單。獲取攻擊者想要的信息,就黑成功了。抓到一個(gè)Tomcat漏洞(這不是我說的,一個(gè)認(rèn)識(shí)的人說的),上傳一個(gè)JSP,里面模擬HttpClient,下載一個(gè)木馬,運(yùn)行。OK,搞定了。所以,沒有絕對(duì)的安全。

今天,泥瓦匠帶你們認(rèn)識(shí)下XSS,然后關(guān)于怎么防御的問題。至于防御的話,仁者見仁智者見智。爾等啥都不配不上的就綽見,望各位閱讀者相互討論。泥瓦匠目前是搞JAVA的,所以例子上JAVA比較多。

Q: 什么是XSS? 為啥有這個(gè)呢?

A: 全名:Cross Site Script,中文名:跨站腳本攻擊。顧名思義,是指“HTML注入”纂改了網(wǎng)頁,插入惡意的腳本,從而在用戶用瀏覽網(wǎng)頁的時(shí)候,控制用戶瀏覽器的一種攻擊。

XSS根據(jù)攻擊的穩(wěn)定性可分為三種:反射型XSS, 存儲(chǔ)型XSS,DOM Based XSS.

image

二、XSS攻擊

再來了解下XSS,是如何攻擊?泥瓦匠這時(shí)候想到一句話:知己知彼,百戰(zhàn)百勝吧。這攻擊我們不會(huì)很詳細(xì)解釋,畢竟想說的是XSS防御嘛。首先,泥瓦匠要介紹下的是:

XSS Playload,所謂用以完成各種具體的功能的惡意腳本。這時(shí)候我想到了黑客精神中的小插曲,現(xiàn)在所謂的“黑客”不是真正的黑客,而是稱為腳本小子(Script Kid)。常見的一個(gè)XSS Playload,就是通過讀取瀏覽器的Cookie對(duì)象,從而發(fā)起了‘Cookie劫持’攻擊。這個(gè)泥瓦匠會(huì)教你們?nèi)シ烙渲蠧ookie的‘HttpOnly’標(biāo)識(shí)可以防止哦。

強(qiáng)大的XSS Playload可以做以下的事情哈:1、構(gòu)造 GET 與 POST 請(qǐng)求 2、各種釣魚 3、識(shí)別用戶瀏覽器 等等

Q&A

Q:什么叫做釣魚呢?

A:顧名思義,愿者上鉤,這里做貶義用法。比如,人家用一個(gè)假的彈出框,或者假的頁面讓你輸入QQ信息,或者啥賬號(hào)信息。其實(shí)你一輸入人家服務(wù)器獲取到你的賬戶密碼了。這就是魚兒上鉤了。 如圖比喻:

[[127051]]

三、XSS防御(重點(diǎn))

兵來將擋,水來土掩。泥瓦匠在Web安全上,想提醒大家的是:“再高的樹,猴子也能爬上去。”因此,我們考慮的地方有些默認(rèn)都給你做好了,有些需要我們自己去關(guān)心,去設(shè)置。

其實(shí)在看不到的地方很多已經(jīng)對(duì)抗XSS做了些措施。比如各種瀏覽器等。

一、按著上面的思路,泥瓦匠先聊下Cookie,一個(gè)Cookie,我們是這樣使用的:

1、瀏覽器下服務(wù)器發(fā)送請(qǐng)求,準(zhǔn)備獲取Cookie

2、服務(wù)器返回發(fā)送Cookie頭,向客戶端瀏覽器寫入Cookie。(注意哦,這里是瀏覽器,不要當(dāng)成什么瀏覽器內(nèi)核)

3、在Cookie到期前,瀏覽器所有頁面,都會(huì)發(fā)送Cookie。

這就意味著,我們Cookie不能亂用。就像Session一樣,所以在使用的時(shí)候,要注意下。有時(shí)候Cooike在用于記住密碼的時(shí)候,千萬要注意要將Cookie設(shè)置HttpOnly屬性為Ture。這里我以SpringMVC為例子。如果用到Cookie的時(shí)候,應(yīng)該這樣:

1
2
3
4
5
6
7
         // create cookie and set it in response
Cookie cookie1 = new Cookie("cookie1", "cookieValueHttpOnly");
Cookie cookie2 = new Cookie("cookie2", "cookieValue");
cookie1.setHttpOnly(true);
 
response.addCookie(cookie1);
response.addCookie(cookie2);

截個(gè)Controller整個(gè)代碼看看:

image

我們打開瀏覽器可以看到下面這種結(jié)果,訪問URL這個(gè)Controller層,打開Firebug查看:

image

二、輸入校驗(yàn)

輸入校驗(yàn)的邏輯必須放在服務(wù)端中實(shí)現(xiàn)。如果用JS進(jìn)行的話,容易被攻擊者繞過去。所以普遍的做法是,類似很多代碼一樣進(jìn)行Double Check:”客戶端JS校驗(yàn)和服務(wù)端校驗(yàn)一起,這樣客戶端JS校驗(yàn)會(huì)阻擋大部分甚至說99%的用戶的誤操作。”

在XSS防御上,我們需要對(duì)用戶輸入的一些特殊字符校驗(yàn),過濾或者是編碼。這種輸入校驗(yàn)的方式成為“XSS Filter”。首先我們?cè)谂渲梦募校?/span>

image

其中的路徑配置當(dāng)然,在你需要的地方配置下咯。然后泥瓦匠在這里寫了個(gè),Http請(qǐng)求裝飾類,用來對(duì)這些參數(shù)的過濾。說干就干唄~實(shí)戰(zhàn)出經(jīng)驗(yàn)。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
public class XssHttpServletRequestWrapper extends HttpServletRequestWrapper
{
 
    public XssHttpServletRequestWrapper(HttpServletRequest request)
    {
        super(request);
    }
 
    public String[] getParameterValues(String parameter)
    {
        String[] values = super.getParameterValues(parameter);
        if (values==null)
        {
            return null;
        }
        int count = values.length;
        String[] encodedValues = new String[count];
        for (int i = 0; i <  count; i++)
        {
            encodedValues[i] = cleanXSS(values[i]);
        }
        return encodedValues;
    }
 
    public String getParameter(String parameter)
    {
        String  value=  super.getParameter(parameter);
        if (value == null)
        {
            return null;
        }
        return cleanXSS(value);
    }
 
    public String getHeader(String name)
    {
        String  value=  super.getHeader(name);
        if (value == null)
            return null;
        return cleanXSS(value);
    }
 
    /**
      * @Title: cleanXSS
      * @Description: You'll need to remove the spaces from the html entities below
      * @param @param value
      * @param @return
      * @return String
      */
    private String cleanXSS(String value)
    {
        value= value.replaceAll("<", "& lt;").replaceAll(">", "& gt;");
        value = value.replaceAll("\\(", "& #40;").replaceAll("\\)", "& #41;");
        value = value.replaceAll("'", "& #39;");
        value = value.replaceAll("eval\\((.*)\\)", "");
        value = value.replaceAll("[\\\"\\\'][\\s]*javascript:(.*)[\\\"\\\']", "\"\"");
        value = value.replaceAll("script", "");
        return value;
    }
}

三、輸出校驗(yàn)

一般來說,除了富文本之外,在變量輸出到HTML頁面,可以使用編碼或者轉(zhuǎn)義的方式來防御XSS攻擊。這是一種各家委婉的方式吧。

四、總結(jié)

  用兵之道在于,如何正確的使用,才能以少勝多。Web安全這場戰(zhàn)爭也一樣,所以要如何正確的使用XSS防御。

Writer:BYSocket(泥沙磚瓦漿木匠)

Reprint it anywhere u want.

原文出自:http://my.oschina.net/jeffli1993/blog/373992

責(zé)任編輯:林師授 來源: 泥沙磚瓦漿木匠的博客
相關(guān)推薦

2010-09-10 14:13:11

2017-06-14 16:08:31

2013-01-11 17:33:46

2020-12-21 09:40:06

腳本攻擊XSS漏洞

2012-11-15 09:51:36

2012-04-12 14:45:13

2010-09-29 15:33:51

2012-11-09 15:42:44

2010-08-30 11:15:38

2010-06-07 20:19:49

2013-05-22 18:06:41

2010-06-30 16:26:05

2009-02-24 17:19:38

2009-03-09 17:19:53

2013-01-28 16:44:50

2010-09-09 11:19:10

2010-09-27 17:37:10

2012-12-18 17:11:58

2017-05-16 14:25:28

2021-06-14 09:33:23

TLS攻擊跨站腳本攻擊網(wǎng)絡(luò)攻擊
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 成人一区二区三区 | 国产精品成人一区二区 | 亚洲一区二区三区视频免费观看 | 久久毛片 | 久久99蜜桃综合影院免费观看 | 亚洲有码转帖 | 国产最好的av国产大片 | 婷婷免费视频 | 欧美日韩亚洲国产 | 成年人视频免费在线观看 | 亚洲天堂中文字幕 | 欧美日韩高清在线观看 | 在线视频一区二区三区 | 国产主播第一页 | 夜夜夜操 | 成人免费视频在线观看 | 91免费高清| 91精品成人久久 | 欧美特级黄色 | 男女免费网站 | 日韩视频中文字幕 | 亚洲综合第一页 | 免费观看国产视频在线 | 日韩中文字幕在线观看 | 色黄视频在线 | 日韩欧美在线播放 | 午夜寂寞网站 | 欧美成人自拍 | 色婷婷国产精品综合在线观看 | 久久久av | 国产999精品久久久久久 | 开操网| 精品亚洲一区二区 | 精品成人69xx.xyz | 国产视频中文字幕 | 欧美乱码精品一区二区三区 | 中文字幕在线免费观看 | 99视频| 一区二区精品在线 | 日韩视频一区二区三区 | 男女羞羞视频网站 |