Bootstrap

dvwa-csrf

    跨站请求攻击,简单地说,是攻击者通过一些技术手段欺骗用户的浏览器去访问一个自己曾经认证过的网站并执行一些操作(如发邮件,发消息,甚至财产操作如转账和购买商品)。

由于浏览器曾经认证过,所以被访问的网站会认为是真正的用户操作而去执行。这利用了web中用户身份验证的一个漏洞:简单的身份验证只能保证请求发自某个用户的浏览器,却不能保证请求本身是用户自愿发出的。

 

用户过分信赖网站

浅谈csrf http://www.cnblogs.com/hyddd/archive/2009/04/09/1432744.html

 

 

看这篇的dvwa教程有点精神分裂:现在我是希望这个网址正常运行,但是正常运行的方法是,我要隐瞒自己,不然受害者发现。low

 

<?php 

if( isset( $_GET[ 'Change' ] ) ) { 
    // Get input 
    $pass_new  = $_GET[ 'password_new' ]; 
    $pass_conf = $_GET[ 'password_conf' ]; 

    // Do the passwords match? 
    if( $pass_new == $pass_conf ) { 
        // They do! 
        $pass_new = mysql_real_escape_string( $pass_new ); 
        $pass_new = md5( $pass_new ); 

        // Update the database 
        $insert = "UPDATE `users` SET password = '$pass_new' WHERE user = '" . dvwaCurrentUser() . "';"; 
        $result = mysql_query( $insert ) or die( '<pre>' . mysql_error() . '</pre>' ); 

        // Feedback for the user 
        echo "<pre>Password Changed.</pre>"; 
    } 
    else { 
        // Issue with passwords matching 
        echo "<pre>Passwords did not match.</pre>"; 
    } 

    mysql_close(); 
} 

?>

 

 

这个没有啥防御措施。。

 

看上面的url就知道被改了

对于url可以使用短网址生成,但是明显的,会发现密码遭到了改变,真正的环境是网站,这个网站里面隐藏这一个连接,可能是图片或者文字,点击后,发生改变,但是出现的画面要让使用者觉得是发生了错误了的页面。

 

medium

 

<?php

if( isset( $_GET'Change' ] ) ) {
    
// Checks to see where the request came from
    
if( stripos$_SERVER'HTTP_REFERER' ] ,$_SERVER'SERVER_NAME' ])!=-) {//查找http_referer 里有没有 server_name

        // Get input
        
$pass_new  $_GET'password_new' ];
        
$pass_conf $_GET'password_conf' ];

        
// Do the passwords match?
        
if( $pass_new == $pass_conf ) {
            
// They do!
            
$pass_new = ((isset($GLOBALS["___mysqli_ston"]) && is_object($GLOBALS["___mysqli_ston"])) ? mysqli_real_escape_string($GLOBALS["___mysqli_ston"],  $pass_new ) : ((trigger_error("[MySQLConverterToo] Fix the mysql_escape_string() call! This code does not work."E_USER_ERROR)) ? "" ""));
            
$pass_new md5$pass_new );

            
// Update the database
            
$insert "UPDATE `users` SET password = '$pass_new' WHERE user = '" dvwaCurrentUser() . "';";
            
$result mysqli_query($GLOBALS["___mysqli_ston"],  $insert ) or die( '<pre>' . ((is_object($GLOBALS["___mysqli_ston"])) ? mysqli_error($GLOBALS["___mysqli_ston"]) : (($___mysqli_res mysqli_connect_error()) ? $___mysqli_res false)) . '</pre>' );

            
// Feedback for the user
            
echo "<pre>Password Changed.</pre>";
        }
        else {
            
// Issue with passwords matching
            
echo "<pre>Passwords did not match.</pre>";
        }
    }
    else {
        
// Didn't come from a trusted source
        
echo "<pre>That request didn't look correct.</pre>";
    }

    ((
is_null($___mysqli_res mysqli_close($GLOBALS["___mysqli_ston"]))) ? false $___mysqli_res);
}


?>

host和refere的某些一致,是为了自己在登入自己的而不是别人在登入自己的(我是这么理解的)

既然要一样,那么可以在referer中加入包含host的html就行了,让受害者登入我制造的假页面,然后改掉localhost里面的密码。

 

high

 

<?php 

if( isset( $_GET[ 'Change' ] ) ) { 
    // Check Anti-CSRF token 
    checkToken( $_REQUEST[ 'user_token' ], $_SESSION[ 'session_token' ], 'index.php' ); 

    // Get input 
    $pass_new  = $_GET[ 'password_new' ]; 
    $pass_conf = $_GET[ 'password_conf' ]; 

    // Do the passwords match? 
    if( $pass_new == $pass_conf ) { 
        // They do! 
        $pass_new = mysql_real_escape_string( $pass_new ); 
        $pass_new = md5( $pass_new ); 

        // Update the database 
        $insert = "UPDATE `users` SET password = '$pass_new' WHERE user = '" . dvwaCurrentUser() . "';"; 
        $result = mysql_query( $insert ) or die( '<pre>' . mysql_error() . '</pre>' ); 

        // Feedback for the user 
        echo "<pre>Password Changed.</pre>"; 
    } 
    else { 
        // Issue with passwords matching 
        echo "<pre>Passwords did not match.</pre>"; 
    } 

    mysql_close(); 
} 

// Generate Anti-CSRF token 
generateSessionToken(); 

?> 

 

随机生成一个token,需要提交token才能提交

 

 

;