0

0

PHP如何过滤用户输入_PHP用户输入安全过滤方法详解

蓮花仙者

蓮花仙者

发布时间:2025-09-15 23:03:01

|

328人浏览过

|

来源于php中文网

原创

过滤用户输入可降低sql注入、xss等风险,核心是对$_get、$_post、$_cookie处理。使用filter_var()进行通用过滤,如filter_sanitize_string、filter_validate_email;防sql注入应使用预处理语句(pdo/mysqli);防xss需用htmlspecialchars()输出转义;富文本用htmlpurifier净化;csrf防护通过csrf token、samesite cookie等实现;同时需合理配置php安全选项,如禁用危险函数、关闭display_errors、限制文件上传、使用最新版本等。

php如何过滤用户输入_php用户输入安全过滤方法详解

直接说吧,PHP过滤用户输入,是为了防止各种攻击,比如SQL注入、XSS等等。别想着完全杜绝,但做好过滤能大大降低风险。

解决方案

PHP里过滤用户输入,核心就是对

$_GET
$_POST
$_COOKIE
这些超全局变量进行处理。

  1. 通用过滤:

    filter_var()

    立即学习PHP免费学习笔记(深入)”;

    这函数相当强大,可以针对不同类型的数据进行过滤。

    • FILTER_SANITIZE_STRING
      : 移除 HTML 标签,编码特殊字符。但注意,它不适合所有场景,比如需要保留某些HTML标签的情况。

      $input = "<p>Hello, <b>World!</b></p>";
      $filtered = filter_var($input, FILTER_SANITIZE_STRING);
      echo $filtered; // 输出: Hello, World!
    • FILTER_VALIDATE_EMAIL
      : 验证邮箱格式。

      $email = "test@example.com";
      if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
          echo "邮箱格式正确";
      } else {
          echo "邮箱格式错误";
      }
    • FILTER_SANITIZE_NUMBER_INT
      : 移除所有字符,除了数字和
      +-

      $number = "123abc456";
      $filtered = filter_var($number, FILTER_SANITIZE_NUMBER_INT);
      echo $filtered; // 输出: 123456
  2. 针对SQL注入:预处理语句 (Prepared Statements)

    别再手动拼接SQL语句了!预处理语句才是王道。PDO或MySQLi都支持。

    // PDO 示例
    $dsn = "mysql:host=localhost;dbname=mydb";
    $username = "user";
    $password = "password";
    
    try {
        $pdo = new PDO($dsn, $username, $password);
        $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    
        $stmt = $pdo->prepare("SELECT * FROM users WHERE username = ? AND password = ?");
        $stmt->execute([$_POST['username'], $_POST['password']]);
    
        $user = $stmt->fetch();
    
        if ($user) {
            echo "登录成功";
        } else {
            echo "登录失败";
        }
    
    } catch (PDOException $e) {
        echo "连接失败: " . $e->getMessage();
    }

    预处理语句的优势在于,SQL语句结构和数据是分开的,数据库会先编译SQL结构,然后再把数据放进去。这样,即使你的数据里包含SQL关键字,也不会被当成SQL语句执行。

  3. 针对XSS:

    htmlspecialchars()

    这个函数能把HTML特殊字符转义,比如

    <
    转成
    <
    >
    转成
    >
    。 这样,用户输入的内容就不会被浏览器当成HTML代码执行。

    $input = "<script>alert('XSS');</script>";
    $filtered = htmlspecialchars($input);
    echo $filtered; // 输出: <script>alert('XSS');</script>

    记住,

    htmlspecialchars()
    是在输出的时候用,而不是输入的时候。 因为输入的时候转义了,存到数据库里,再取出来显示,就乱码了。

  4. 白名单验证

    对于一些特定的输入,比如颜色、尺寸,最好使用白名单验证。 只允许特定的值通过。

    $color = $_POST['color'];
    $allowed_colors = ['red', 'green', 'blue'];
    
    if (in_array($color, $allowed_colors)) {
        echo "你选择了颜色: " . $color;
    } else {
        echo "无效的颜色";
    }
  5. 其他小技巧

    • trim()
      : 移除字符串首尾的空白字符。
    • stripslashes()
      : 移除反斜杠。 但现在一般不用,因为PHP配置里可以设置自动转义。

PHP如何处理富文本编辑器中的用户输入?

富文本编辑器允许用户输入带格式的文本,比如加粗、斜体、链接等等。 这给XSS攻击提供了更多可能性。

  1. 使用专门的库

    不要自己写过滤规则! 用成熟的HTML净化库,比如HTMLPurifier。 它能根据配置,移除不安全的HTML标签和属性,保留安全的。

    require_once 'HTMLPurifier.auto.php';
    
    $config = HTMLPurifier_Config::createDefault();
    $purifier = new HTMLPurifier($config);
    
    $dirty_html = $_POST['content'];
    $clean_html = $purifier->purify($dirty_html);
    
    echo $clean_html;
  2. 配置HTMLPurifier

    有道智云AI开放平台
    有道智云AI开放平台

    有道智云AI开放平台

    下载

    HTMLPurifier的默认配置可能过于严格,你需要根据实际需求进行调整。 比如,允许

    @@##@@
    标签,允许
    class
    属性等等。

    $config = HTMLPurifier_Config::createDefault();
    $config->set('HTML.Allowed', 'p,b,i,a[href],img[src]');
    $config->set('Attr.AllowedClasses', ['my-class']);
    $purifier = new HTMLPurifier($config);
  3. 输出时再次转义

    即使经过HTMLPurifier处理,在输出的时候,最好还是用

    htmlspecialchars()
    转义一下。 多一层保护总是好的。

如何防止CSRF攻击?

CSRF (Cross-Site Request Forgery) 攻击是指,攻击者伪造用户请求,以用户的身份执行操作。 比如,用户登录了银行网站,攻击者诱骗用户点击一个链接,这个链接会向银行网站发起转账请求。

  1. 使用CSRF Token

    在每个表单里,都生成一个随机的token,保存在session里。 提交表单的时候,验证token是否一致。

    session_start();
    
    function generate_csrf_token() {
        return bin2hex(random_bytes(32));
    }
    
    if (empty($_SESSION['csrf_token'])) {
        $_SESSION['csrf_token'] = generate_csrf_token();
    }
    
    // 在表单里
    echo '<input type="hidden" name="csrf_token" value="' . $_SESSION['csrf_token'] . '">';
    
    // 提交表单时
    if ($_POST['csrf_token'] !== $_SESSION['csrf_token']) {
        die("CSRF 攻击!");
    }
  2. 验证HTTP Referer

    检查HTTP Referer头部,看请求是否来自自己的网站。 但这个方法不靠谱,因为Referer可以被伪造。 只能作为辅助手段。

  3. 使用SameSite Cookie

    SameSite Cookie可以限制Cookie的发送范围,防止跨站请求携带Cookie。

    setcookie('my_cookie', 'value', ['samesite' => 'Strict']); // 或 'Lax'
    • Strict
      : Cookie只会在同站请求中发送。
    • Lax
      : Cookie会在同站请求和部分跨站请求中发送,比如点击链接。

PHP安全配置还有哪些需要注意的?

除了过滤用户输入,PHP的安全配置也很重要。

  1. 禁用危险函数

    php.ini
    里,用
    disable_functions
    指令禁用一些危险函数,比如
    eval()
    system()
    exec()
    等等。 这些函数可以执行任意代码,很容易被利用。

    disable_functions = eval,system,exec,shell_exec,passthru,phpinfo
  2. 关闭

    display_errors

    在生产环境里,不要显示错误信息。 错误信息可能会泄露敏感信息,比如数据库密码、文件路径等等。 把错误信息记录到日志里。

    display_errors = Off
    log_errors = On
    error_log = /path/to/php_errors.log
  3. 限制文件上传大小

    php.ini
    里,用
    upload_max_filesize
    post_max_size
    指令限制文件上传大小。 防止上传过大的文件,导致服务器崩溃。

    upload_max_filesize = 2M
    post_max_size = 8M
  4. 使用最新的PHP版本

    PHP官方会定期发布安全更新,修复已知的漏洞。 保持PHP版本最新,可以避免被已知的漏洞攻击。

  5. 设置open_basedir

    使用

    open_basedir
    指令限制PHP可以访问的文件目录。这可以防止恶意脚本访问敏感文件。

    open_basedir = /var/www/html:/tmp

记住,安全是一个持续的过程,需要不断学习和更新。没有绝对的安全,只有相对的安全。

PHP如何过滤用户输入_PHP用户输入安全过滤方法详解

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2152

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1683

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP基础入门课程
PHP基础入门课程

共33课时 | 2.2万人学习

MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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