PHPerKaigi 2025

stristr

(PHP 4, PHP 5, PHP 7, PHP 8)

stristrCase-insensitive strstr()

Опис

stristr(string $haystack, string $needle, bool $before_needle = false): string|false

Returns all of haystack starting from and including the first occurrence of needle to the end.

Параметри

haystack

The string to search in

needle

The string to search for.

До версії PHP 8.0.0, якщо параметр needle не є рядком, він перетворюється на ціле число і розглядається як код символу. Ця поведінка є застарілою, починаючи з PHP 7.3.0. Вкрай не рекомендується на неї покладатися. Залежно від потрібної поведінки, параметр needle необхідно привести до рядкового типу або обробити функцією chr().

before_needle

If true, stristr() returns the part of the haystack before the first occurrence of the needle (excluding needle).

needle and haystack are examined in a case-insensitive manner.

Значення, що повертаються

Returns the matched substring. If needle is not found, returns false.

Журнал змін

Версія Опис
8.2.0 Приведення до одного регістру не залежить від локалі, що встановлена функцією setlocale(). Перетворюються тільки ASCII-символи. Байти, які не належать до ASCII, порівнюються за своїми значеннями.
8.0.0 Тепер параметр needle може бути порожнім рядком.
8.0.0 Passing an int as needle is no longer supported.
7.3.0 Passing an int as needle has been deprecated.

Приклади

Приклад #1 stristr() example

<?php
$email
= 'USER@EXAMPLE.com';
echo
stristr($email, 'e'); // outputs ER@EXAMPLE.com
echo stristr($email, 'e', true); // outputs US
?>

Приклад #2 Testing if a string is found or not

<?php
$string
= 'Hello World!';
if(
stristr($string, 'earth') === FALSE) {
echo
'"earth" not found in string';
}
// outputs: "earth" not found in string
?>

Приклад #3 Using a non "string" needle

<?php
$string
= 'APPLE';
echo
stristr($string, 97); // 97 = lowercase a
// outputs: APPLE
?>

Примітки

Зауваження: Ця функція є бінарно безпечною.

Прогляньте також

  • strstr() - Find the first occurrence of a string
  • strrchr() - Find the last occurrence of a character in a string
  • stripos() - Find the position of the first occurrence of a case-insensitive substring in a string
  • strpbrk() - Search a string for any of a set of characters
  • preg_match() - Perform a regular expression match

add a note

User Contributed Notes 5 notes

up
17
dpatton.at.confluence.org
22 years ago
There was a change in PHP 4.2.3 that can cause a warning message
to be generated when using stristr(), even though no message was
generated in older versions of PHP.

The following will generate a warning message in 4.0.6 and 4.2.3:
stristr("haystack", "");
OR
$needle = ""; stristr("haystack", $needle);

This will _not_ generate an "Empty Delimiter" warning message in
4.0.6, but _will_ in 4.2.3:
unset($needle); stristr("haystack", $needle);

Here's a URL that documents what was changed:
http://groups.google.ca/groups?selm=cvshholzgra1031224321%40cvsserver
up
7
giz at gbdesign dot net
17 years ago
Just been caught out by stristr trying to converting the needle from an Int to an ASCII value.

Got round this by casting the value to a string.

<?php
if( !stristr( $file, (string) $myCustomer->getCustomerID() ) ) {
// Permission denied
}
?>
up
3
Techdeck at Techdeck dot org
22 years ago
An example for the stristr() function:

<?php
$a
= "I like php";
if (
stristr("$a", "LikE PhP")) {
print (
"According to \$a, you like PHP.");
}
?>

It will look in $a for "like php" (NOT case sensetive. though, strstr() is case-sensetive).

For the ones of you who uses linux.. It is similiar to the "grep" command.
Actually.. "grep -i".
up
-1
notepad at codewalkers dot com
19 years ago
<?php

function stristr_reverse($haystack, $needle) {
$pos = stripos($haystack, $needle) + strlen($needle);
return
substr($haystack, 0, $pos);
}
$email = 'USER@EXAMPLE.com';
echo
stristr_reverse($email, 'er');
// outputs USER

?>
up
-3
jukka
10 years ago
I think there is a bug in php 5.3 in stristr with uppercase Ä containing other character

http://pastebin.com/5bP6uztY

if you search only with täry it works, but as soon as the word is tärylä it does not. TÄRYL works fine
To Top