php8.4新函数str_contains怎么用_php8.4字符串包含判断教程【方法】

发布时间 - 2025-12-30 00:00:00    点击率:
str_contains自PHP 8.0.0起引入,并非PHP 8.4新特性;它严格要求参数为字符串,区分大小写,空字符串恒为true,旧版本需用stripos !== false替代。

PHP 8.4 并没有 str_contains 函数——它早在 PHP 8.0 就已引入,且是原生函数,不是新特性。如果你在 PHP 8.4 环境下调用失败,大概率是因为版本实际低于 8.0,或启用了严格模式但传入了非字符串参数。

为什么 str_contains 会报 “undefined function”?

这是最常踩的坑:误以为它是 PHP 8.4 新增,结果在旧环境(如 7.4 或未升级的 8.0-)直接使用,导致致命错误。

  • ✅ 正确前提:str_containsPHP 8.0.0 起可用,无需额外扩展
  • ❌ 常见误判:本地开发环境显示 PHP 8.4,但 CLI 和 Web Server(如 Apache mod_php)用的是不同版本,php -vphpinfo() 结果不一致
  • ❌ 参数类型错误:第二个参数 $needle 必须是 string,传 nullintarray 会触发 TypeError

str_contains 的基本用法和参数细节

它只做一件事:判断一个字符串是否包含另一个子串,返回 bool。没有大小写选项,不支持正则,也不修改原始字符串。

  • 函数签名:str_contains(string $haystack, string $needle): bool
  • $haystack$needle 都会被强制转为字符串(但仅当类型兼容;array 会直接报错)
  • 空字符串 '' 被认为包含在任何字符串中(包括空字符串本身):str_contains('abc', '') === true
  • 区分大小写:str_contains('Hello', 'hello') === false
var_dump(str_contains('filename.php', '.php')); // true
var_dump(str_contains('user@example.com', '@')); // true
var_dump(str_contains('test', '')); // true
var_dump(str_contains('TEST', 't')); // false

替代方案:PHP 7.x 或需要忽略大小写的场景

如果确实不能升级到 PHP 8.0+,或需要大小写不敏感匹配,不要用 stripos !== false 手动封装——容易漏掉 0 的边界情况。

  • 安全写法(PHP 7.0+):stripos($haystack, $needle) !== false
  • 更健壮的封装(可复用):
    function str_contains_ci(string $haystack, string $needle): bool {
        return stripos($haystack, $needle) !== false;
    }
  • 注意:strpos/stripos 返回 int|false,必须用严格比较 !==,否则 strpos('abc', 'a') === 0 会被误判为 false

性能与编码注意事项

虽然 str_contains 是底层 C 实现,比 stripos 略快,但差异微乎其微。真正影响性能的是滥用或嵌套调用。

  • 避免在循环内反复对同一长字符串调用多个 str_contains,考虑提前提取或用 str_split + in_array 预处理
  • 如果 $needle 来自用户输入,确保已过滤或验证——该函数不做任何转义或清理
  • UTF-8 多字节字符正常支持(如中文、emoji),但前提是源字符串编码正确;若字符串是 GBK 编码,str_contains 可能因字节截断误判

真正容易被忽略的点:它不处理 null。哪怕你写了 str_contains($filename ?? '', '.php'),也得确认 $filename 不是 0false 或对象——这些在强类型上下文中可能隐式转成空字符串,逻辑就变了。


# php  # php8  # apache  # 编码  # 字节  # ai  # 开发环境  # 为什么  # String  # Array  # NULL  # strpos  # 封装  # 字符串  # bool  # int  # 循环  # undefined  # function  # 对象  # 严格模式  # 的是  # 空字符串  # 会报  # 多字  # 新特性  # 这是  # 也不  # 是因为  # 多个  # 你在 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  Laravel如何与Pusher实现实时通信?(WebSocket示例)  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  Thinkphp 中 distinct 的用法解析  如何快速搭建高效服务器建站系统?  Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册  昵图网官方站入口 昵图网素材图库官网入口  企业网站制作这些问题要关注  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  如何在万网自助建站中设置域名及备案?  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  高防服务器:AI智能防御DDoS攻击与数据安全保障  Angular 表单中正确绑定输入值以确保提交与验证正常工作  昵图网官网入口 昵图网素材平台官方入口  进行网站优化必须要坚持的四大原则  如何在万网自助建站平台快速创建网站?  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解  Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何快速查询网址的建站时间与历史轨迹?  高防服务器租用指南:配置选择与快速部署攻略  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  如何在阿里云购买域名并搭建网站?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  在线制作视频网站免费,都有哪些好的动漫网站?  IOS倒计时设置UIButton标题title的抖动问题  javascript读取文本节点方法小结  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  JavaScript实现Fly Bird小游戏  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  如何在橙子建站上传落地页?操作指南详解  Laravel怎么上传文件_Laravel图片上传及存储配置  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  如何快速搭建二级域名独立网站?  jquery插件bootstrapValidator表单验证详解  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  MySQL查询结果复制到新表的方法(更新、插入)  详解Oracle修改字段类型方法总结  千库网官网入口推荐 千库网设计创意平台入口  百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  如何在IIS7上新建站点并设置安全权限?  如何用PHP快速搭建高效网站?分步指南  公司网站制作需要多少钱,找人做公司网站需要多少钱?  Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门  油猴 教程,油猴搜脚本为什么会网页无法显示?