PHP 防范xss攻击(转载)

Posted tomcuper

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP 防范xss攻击(转载)相关的知识,希望对你有一定的参考价值。

XSS 全称为 Cross Site Scripting,用户在表单中有意或无意输入一些恶意字符,从而破坏页面的表现!

看看常见的恶意字符XSS 输入:

1.XSS 输入通常包含 javascript 脚本,如弹出恶意警告框:<script>alert("XSS");</script>

2.XSS 输入也可能是 html 代码段,譬如:

(1).网页不停地刷新 <meta http-equiv="refresh" content="0;">

(2).嵌入其它网站的链接 <iframe src=http://xxxx width=250 height=250></iframe>

 
    <?php
    /**
     * @blog http://www.phpddt.com
     * @param $string
     * @param $low 安全别级低
     */
    function clean_xss(&$string, $low = False)
    {
        if (! is_array ( $string ))
        {
            $string = trim ( $string );
            $string = strip_tags ( $string );
            $string = htmlspecialchars ( $string );
            if ($low)
            {
                return True;
            }
            $string = str_replace ( array (‘"‘, "\\", "‘", "/", "..", "../", "./", "//" ), ‘‘, $string );
            $no = ‘/%0[0-8bcef]/‘;
            $string = preg_replace ( $no, ‘‘, $string );
            $no = ‘/%1[0-9a-f]/‘;
            $string = preg_replace ( $no, ‘‘, $string );
            $no = ‘/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]+/S‘;
            $string = preg_replace ( $no, ‘‘, $string );
            return True;
        }
        $keys = array_keys ( $string );
        foreach ( $keys as $key )
        {
            clean_xss ( $string [$key] );
        }
    }
    //just a test
    $str = ‘phpddt.com<meta http-equiv="refresh" content="0;">‘;
    clean_xss($str); //如果你把这个注释掉,你就知道xss攻击的厉害了
    echo $str;
    ?>
 

以上是关于PHP 防范xss攻击(转载)的主要内容,如果未能解决你的问题,请参考以下文章

防范xss的正确姿势

XSS攻击与防范

HTTP攻击与防范 |XSS-简介

简述XSS攻击及其防范措施

web安全防范策略

XSS原理及防范