当前位置:首页 > 文章列表 > 文章 > php教程 > PHP输入过滤技巧全解析

PHP输入过滤技巧全解析

2025-09-27 22:13:04 0浏览 收藏

小伙伴们对文章编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《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()

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

    • 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; // 输出: &lt;script&gt;alert('XSS');&lt;/script&gt;

    记住,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

    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 '&lt;input type=&quot;hidden&quot; name=&quot;csrf_token&quot; value=&quot;&apos; . $_SESSION[&apos;csrf_token&apos;] . &apos;&quot;&gt;';
    
    // 提交表单时
    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_filesizepost_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

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

文中关于安全配置,sql注入,xss,csrf,PHP用户输入过滤的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《PHP输入过滤技巧全解析》文章吧,也可关注golang学习网公众号了解相关技术文章。

ZULU转巴黎时间换算方法ZULU转巴黎时间换算方法
上一篇
ZULU转巴黎时间换算方法
高并发优化:数据库与缓存技巧解析
下一篇
高并发优化:数据库与缓存技巧解析
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI 试衣:潮际好麦,电商营销素材一键生成
    潮际好麦-AI试衣
    潮际好麦 AI 试衣平台,助力电商营销、设计领域,提供静态试衣图、动态试衣视频等全方位服务,高效打造高质量商品展示素材。
    34次使用
  • 蝉妈妈AI:国内首个电商垂直大模型,抖音增长智能助手
    蝉妈妈AI
    蝉妈妈AI是国内首个聚焦电商领域的垂直大模型应用,深度融合独家电商数据库与DeepSeek-R1大模型。作为电商人专属智能助手,它重构电商运营全链路,助力抖音等内容电商商家实现数据分析、策略生成、内容创作与效果优化,平均提升GMV 230%,是您降本增效、抢占增长先机的关键。
    85次使用
  • 社媒分析AI:数说Social Research,用AI读懂社媒,驱动增长
    数说Social Research-社媒分析AI Agent
    数说Social Research是数说故事旗下社媒智能研究平台,依托AI Social Power,提供全域社媒数据采集、垂直大模型分析及行业场景化应用,助力品牌实现“数据-洞察-决策”全链路支持。
    91次使用
  • 先见AI:企业级商业智能平台,数据驱动科学决策
    先见AI
    先见AI,北京先智先行旗下企业级商业智能平台,依托先知大模型,构建全链路智能分析体系,助力政企客户实现数据驱动的科学决策。
    91次使用
  • 职优简历:AI驱动的免费在线简历制作平台,提升求职成功率
    职优简历
    职优简历是一款AI辅助的在线简历制作平台,聚焦求职场景,提供免费、易用、专业的简历制作服务。通过Markdown技术和AI功能,帮助求职者高效制作专业简历,提升求职竞争力。支持多格式导出,满足不同场景需求。
    85次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码