php转义字符串特殊字符
巴扎黑
巴扎黑 2017-04-11 09:41:49
[PHP讨论组]

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

巴扎黑
巴扎黑

全部回复(3)
黄舟

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那就得自己做好过滤处理了,如下推荐一个我用过的方法,仅供参考

function isEscape($val, $isboor = false) {
    if (! get_magic_quotes_gpc ()) {
        $val = addslashes ( $val );
    }
    if ($isboor) {
        $val = strtr ( $val, array (
                "%" => "\%",
                "_" => "\_" 
        ) );
    }
    return $val;
}
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号