说明
返回 haystack 字符串从 needle 第一次出现的位置开始到结尾的字符串。
参数
haystack-
在该字符串中查找。
needle-
要搜索的字符串。
Prior to PHP 8.0.0, if
needleis not a string, it is converted to an integer and applied as the ordinal value of a character. This behavior is deprecated as of PHP 7.3.0, and relying on it is highly discouraged. Depending on the intended behavior, theneedleshould either be explicitly cast to string, or an explicit call to chr() should be performed. before_needle-
若为
true,strstr() 将返回needle在haystack中的位置之前的部分(不包括 needle)。
参数 needle 和 haystack 将以不区分大小写的方式对待。
返回值
返回匹配的子字符串。如果 needle 未找到,返回 false。
更新日志
| 版本 | 说明 |
|---|---|
| 8.2.0 | 大小写转换不在依赖于使用 setlocale() 设置的区域。只会进行 ASCII 大小写转换。非 ASCII 字节值将通过它们的字节值进行比较。 |
| 8.0.0 |
needle 现在接受空字符串。
|
| 8.0.0 |
不再支持 int 传递给 needle。
|
| 7.3.0 |
弃用 int 传递给 needle。
|
示例
示例 #1 stristr() 示例
<?php
$email = 'USER@EXAMPLE.com';
echo stristr($email, 'e'), PHP_EOL; // 输出 ER@EXAMPLE.com
echo stristr($email, 'e', true), PHP_EOL; // 输出 US
?>
示例 #2 测试字符串的存在与否
<?php
$string = 'Hello World!';
if (stristr($string, 'earth') === FALSE) {
echo '"earth" not found in string';
}
// 输出:"earth" not found in string
?>注释
注意: 此函数可安全用于二进制对象。
参见
- strstr() - 查找字符串的首次出现
- strrchr() - 查找指定字符在字符串中的最后一次出现
- stripos() - 查找字符串首次出现的位置(不区分大小写)
- strpbrk() - 在字符串中查找一组字符的任何一个字符
- preg_match() - 执行匹配正则表达式