返回 haystack
字符串从 needle
第一次出现的位置开始到结尾的字符串。
haystack
在该字符串中查找。
needle
要搜索的字符串。
Prior to PHP 8.0.0, if needle
is 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, the
needle
should 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'); // 输出 ER@EXAMPLE.com
echo stristr($email, 'e', true); // 输出 US
?>
示例 #2 测试字符串的存在与否
<?php
$string = 'Hello World!';
if(stristr($string, 'earth') === FALSE) {
echo '"earth" not found in string';
}
// 输出: "earth" not found in string
?>
示例 #3 使用非字符串 needle
<?php
$string = 'APPLE';
echo stristr($string, 97); // 97 = 小写字母 a
// 输出: APPLE
?>
注意: 此函数可安全用于二进制对象。