>  기사  >  백엔드 개발  >  php转义字符串特殊字符

php转义字符串特殊字符

WBOY
WBOY원래의
2016-08-04 09:19:331328검색

php用什么方法可以将一个字符串中所有特殊字符转义输出?
类似mysql_real_escape_string,但这个已经过时了,而且也不是在数据库上使用。

回复内容:

php用什么方法可以将一个字符串中所有特殊字符转义输出?
类似mysql_real_escape_string,但这个已经过时了,而且也不是在数据库上使用。

htmlspecialchars

PHP5.5以后废弃了mysql扩展,你可以转用mysqli或者pdo_mysql

所以你说的这个mysql_real_escape_string函数,如果用mysqli的话可以用mysqli_real_escape_string代替

不过建议用pdo_mysql,使用预处理语句提高安全性

http://php.net/manual/zh/ref....

htmlspecialchars单双引号、大于和小于号等转化成HTML格式;htmlentities所有字符都转成HTML格式;addslashes单双引号、反斜线及NULL加上反斜线转义;

  • 如其他网友所说,如果你用了pdo就不用考虑数据库操作上注入等问题了,pdo自带的预处理可以有效的防治sql注入以及特殊字符的处理。

  • 如果你不用pdo那就得自己做好过滤处理了,如下推荐一个我用过的方法,仅供参考

<code>function isEscape($val, $isboor = false) {
    if (! get_magic_quotes_gpc ()) {
        $val = addslashes ( $val );
    }
    if ($isboor) {
        $val = strtr ( $val, array (
                "%" => "\%",
                "_" => "\_" 
        ) );
    }
    return $val;
}</code>
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.