大帝AV在线一区二区三区_日韩精品一区二区三区中文_国产福利一区二区在线视频_国产在线观看一区二区三区精品

299

跨站腳本攻擊XSS

時間: 2015-10-09 11:37:33   點擊數: 30629   來源: 耐思智慧

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


一、認識XSS先

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

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



Q: 什么是XSS? 為啥有這個呢?

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

XSS根據攻擊的穩定性可分為三種:反射型XSS, 存儲型XSS,DOM Based XSS.

<img title="image" alt="image" width="390" height="311" src="http://s9.51cto.com/wyfs02/M02/59/3F/wKioL1TNg4bxyLbwAAA-WGcB1yw307.jpg" style="border:0px;" />

二、XSS攻擊

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

XSS Playload,所謂用以完成各種具體的功能的惡意腳本。這時候我想到了黑客精神中的小插曲,現在所謂的“黑客”不是真正的黑客,而是稱為腳本小子(Script Kid)。常見的一個XSS Playload,就是通過讀取瀏覽器的Cookie對象,從而發起了‘Cookie劫持’攻擊。這個泥瓦匠會教你們去防御哈,其中Cookie的‘HttpOnly’標識可以防止哦。

強大的XSS Playload可以做以下的事情哈:1、構造 GET 與 POST 請求 2、各種釣魚 3、識別用戶瀏覽器 等等

Q&A

Q:什么叫做釣魚呢?

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

<img title="image" alt="image" width="417" height="318" src="http://s8.51cto.com/wyfs02/M02/59/42/wKiom1TNgqDTmmgOAAA3ZIJeddY827.jpg" style="border:0px;" />

三、XSS防御(重點)

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

其實在看不到的地方很多已經對抗XSS做了些措施。比如各種瀏覽器等。

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

1、瀏覽器下服務器發送請求,準備獲取Cookie

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

3、在Cookie到期前,瀏覽器所有頁面,都會發送Cookie。

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


 // 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);


截個Controller整個代碼看看:

<img title="image" alt="image" width="498" height="371" src="http://s4.51cto.com/wyfs02/M02/59/3F/wKioL1TNg4bwYQYVAABwFSGDcPM003.jpg" style="border:0px;" />

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

<img title="image" alt="image" width="498" height="136" src="http://s7.51cto.com/wyfs02/M00/59/3F/wKioL1TNg4eRUGJhAAA8ZC-kclw848.jpg" style="border:0px;" />

二、輸入校驗

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

在XSS防御上,我們需要對用戶輸入的一些特殊字符校驗,過濾或者是編碼。這種輸入校驗的方式成為“XSS Filter”。首先我們在配置文件中,

<img title="image" alt="image" width="498" height="304" src="http://s5.51cto.com/wyfs02/M02/59/42/wKiom1TNgqLz9TO-AACA0kcgxeM065.jpg" style="border:0px;" />

其中的路徑配置當然,在你需要的地方配置下咯。然后泥瓦匠在這里寫了個,Http請求裝飾類,用來對這些參數的過濾。說干就干唄~實戰出經驗。


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;
    }
}


三、輸出校驗

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

四、總結

  用兵之道在于,如何正確的使用,才能以少勝多。Web安全這場戰爭也一樣,所以要如何正確的使用XSS防御。如果你是菜鳥,沒關系,建議你使用企業自助建站系統建站寶盒,通過這套程序您可以有效規避跨站腳本攻擊XSS,將合適的工作交給最專業的人,制作一個擁有電腦站+手機站+微站+手機APP的四站一體的企業商城網站,在線銷售產品豈不是很好呢。

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


上一篇:公司官網打開慢,優化服務器負載均衡解決方案 下一篇:給企業微信運營最中肯的10條建議

旗下網站:耐思智慧 - 淘域網 - 我的400電話 - 中文域名:耐思尼克.cn 耐思尼克.top

耐思智慧 © 版權所有 Copyright © 2000-2025 IISP.COM,Inc. All rights reserved

備案號碼: 粵ICP備09063828號  公安備案號: 公安備案 粵公網安備 44049002000123號  域名注冊服務機構許可:粵D3.1-20240003 CN域名代理自深圳萬維網

聲明:本網站中所使用到的其他各種版權內容,包括但不限于文章、圖片、視頻、音頻、字體等內容版權歸原作者所有,如權利所有人發現,請及時告知,以便我們刪除版權內容

本站程序界面、源代碼受相關法律保護, 未經授權, 嚴禁使用; 耐思智慧 © 為我公司注冊商標, 未經授權, 嚴禁使用

法律顧問:珠海知名律師 廣東篤行律師事務所 夏天風 律師

大帝AV在线一区二区三区_日韩精品一区二区三区中文_国产福利一区二区在线视频_国产在线观看一区二区三区精品

      9000px;">

          日韩av中文字幕一区二区三区| 中文字幕av在线一区二区三区| 欧美精选在线播放| 欧美videossexotv100| 一区二区日韩av| 国产在线日韩欧美| 欧美猛男超大videosgay| 亚洲一区二区三区在线| 色一区在线观看| 亚洲国产成人tv| 欧美日韩国产经典色站一区二区三区 | 国产成人av电影免费在线观看| 粉嫩一区二区三区性色av| 日韩视频一区二区三区在线播放| 亚洲成人精品一区二区| 欧美妇女性影城| 久久99国内精品| 国产精品视频线看| 91网站黄www| 另类综合日韩欧美亚洲| 中文字幕国产一区二区| 亚洲精品在线免费观看视频| 日本中文在线一区| 欧美一区二区成人| 国产成人av自拍| 亚洲精品乱码久久久久| 在线观看一区二区精品视频| 午夜激情一区二区| 不卡高清视频专区| 国产一区91精品张津瑜| 狠狠色丁香久久婷婷综| 日韩一级完整毛片| 国产成人精品一区二区三区网站观看| 综合精品久久久| 日韩午夜三级在线| 色婷婷综合久久久久中文一区二区 | 欧美丰满一区二区免费视频| 九九**精品视频免费播放| 图片区小说区国产精品视频| 国产精品国产三级国产aⅴ入口 | 免费观看一级欧美片| 一区二区在线观看免费视频播放| 亚洲成人免费视| 久久午夜老司机| 99在线精品免费| 一区在线播放视频| 99精品偷自拍| 欧美日韩综合一区| 欧美激情一区二区三区四区| 激情久久五月天| 亚洲乱码国产乱码精品精小说| 欧美性一二三区| 国产麻豆精品在线| 亚洲国产精品一区二区久久| 欧洲av在线精品| 久久er精品视频| 国产性色一区二区| 欧美日韩精品三区| 紧缚捆绑精品一区二区| 日韩亚洲欧美中文三级| 国产成人高清在线| 日韩电影在线一区二区| 中文字幕一区二区5566日韩| 日韩免费福利电影在线观看| 在线免费精品视频| 亚洲天堂免费在线观看视频| 精品国产凹凸成av人导航| 99re视频精品| 成人免费高清在线观看| 国产成人精品免费看| 久久99国产精品久久99| 亚洲综合免费观看高清完整版| 久久精品日韩一区二区三区| 欧美成人在线直播| 精品少妇一区二区三区在线播放 | 欧美一区二区国产| 欧美自拍丝袜亚洲| 欧美午夜影院一区| 91精品欧美一区二区三区综合在| 成人a区在线观看| 国产成人精品一区二区三区四区 | 激情综合网天天干| 天天做天天摸天天爽国产一区 | 97超碰欧美中文字幕| 丁香婷婷综合激情五月色| 成人三级伦理片| 欧美午夜视频网站| 欧美一区二区三区四区五区| 91精品中文字幕一区二区三区| 成人黄色一级视频| 成人高清av在线| 91老师片黄在线观看| 色噜噜偷拍精品综合在线| 日韩精品专区在线影院重磅| 久久久精品tv| 欧美女孩性生活视频| 91精品在线免费观看| 日本一区二区高清| 午夜精品福利一区二区蜜股av | 日本一区二区三级电影在线观看| 国产色91在线| 亚洲一级片在线观看| 91日韩精品一区| 欧美日韩国产a| 一区二区三区在线观看国产| 激情综合网最新| 日韩视频一区二区三区在线播放| 一区二区三区四区在线| 日韩av网站在线观看| 亚洲欧美偷拍另类a∨色屁股| 亚洲男帅同性gay1069| 久热成人在线视频| 日韩三级伦理片妻子的秘密按摩| 2022国产精品视频| 性久久久久久久久久久久| av一区二区久久| 久久久久久久久久电影| 国产麻豆精品95视频| 久久一区二区三区四区| 国产精品1区二区.| 91精品欧美久久久久久动漫 | 久久夜色精品国产噜噜av| 欧美不卡一区二区三区四区| 中文字幕字幕中文在线中不卡视频| 国内成人自拍视频| 欧美激情一区二区三区不卡| 国产福利精品导航| 久久精子c满五个校花| 亚洲影院在线观看| 欧美一激情一区二区三区| 欧美色图12p| 天天亚洲美女在线视频| 91一区二区三区在线播放| 亚洲免费在线电影| 日韩欧美在线观看一区二区三区| 中文一区在线播放| 7777精品伊人久久久大香线蕉完整版| 一区二区三区在线观看欧美| 欧美视频一区二区| 欧美国产日韩a欧美在线观看 | 337p亚洲精品色噜噜| 亚洲欧美日本韩国| 精品99999| 欧美精品在线一区二区三区| 国产精品一品二品| 日韩专区中文字幕一区二区| 亚洲天堂成人网| 欧美mv和日韩mv国产网站| 成人一区二区三区视频在线观看 | 天天综合网 天天综合色| 久久―日本道色综合久久| 91一区二区在线观看| 国模冰冰炮一区二区| 看电视剧不卡顿的网站| 久久精品一区二区三区不卡牛牛| 国产麻豆午夜三级精品| 精品一区二区av| 国产一区二区影院| 日韩va亚洲va欧美va久久| 一区二区三区91| 亚洲精品亚洲人成人网在线播放| 日韩av不卡在线观看| 日韩一区在线免费观看| 精品成人一区二区三区| 欧洲av一区二区嗯嗯嗯啊| 成人福利视频在线看| 国产精品一级片在线观看| 久久国产精品露脸对白| 九九**精品视频免费播放| 国产在线精品免费| 高清在线观看日韩| 成人深夜在线观看| 99久久久精品| 欧美日韩dvd在线观看| 欧美日韩视频在线一区二区| 欧美日韩国产一二三| 国产成a人亚洲| 欧美最猛黑人xxxxx猛交| 91麻豆免费观看| 欧美欧美欧美欧美| 久久先锋资源网| 精品福利在线导航| 自拍偷在线精品自拍偷无码专区| 亚洲免费在线播放| 麻豆精品一区二区三区| 91色porny在线视频| 精品成人私密视频| 视频一区二区三区中文字幕| 国产99久久久国产精品| 日本乱人伦一区| 亚洲一区二区精品视频| 精品99999| 91成人网在线| 国产一区在线视频| 亚洲一区二区欧美日韩| 久久久精品免费免费| av中文字幕不卡| 国产精品乱人伦| 日韩欧美在线影院| 国产一二三精品|