Simple way to implement this function in PHP 4
<?php
if (function_exists('strripos') == false) {
    function strripos($haystack, $needle) {
        return strlen($haystack) - strpos(strrev($haystack), $needle);
    }
}
?>(PHP 5, PHP 7, PHP 8)
strripos — Ищет в строке позицию последнего вхождения подстроки, без учёта регистра
   Функция ищет позицию последнего вхождения подстроки needle
   в строку haystack.
  
Функция strripos() не учитывает регистр символов, в отличие от функции strrpos().
haystackСтрока, в которой выполняется поиск.
needleСтрока, которую требуется найти.
 До PHP 8.0.0 нестроковый аргумент needle
 преобразовывался в целое число и заменялся на символ с этим порядковым значением в однобайтовой таблице символов.
 Начиная с PHP 7.3.0 передача нестроковых значений устарела и полагаться на него настоятельно не рекомендуют.
 Перед вызовом функции нестроковый аргумент needle требовалось
 либо приводить к строке, либо получать строковое значение символа функцией chr().
offset
       При передаче нуля или положительного значения функция пропускает
       с начала строки haystack байты, количество которых указали
       в параметре offset, и начинает поиск слева направо.
      
       При отрицательных значениях функция пропускает
       с конца строки haystack байты, количество которых указали
       в параметре offset, и начинает поиск первого вхождения
       подстроки needle при движении справа налево.
       
Замечание:
Функция ищет последнее вхождение подстроки
needle, если представить поиск как движение с начала строки до точки перед смещением с конца строки в байтах, количество которых указали в параметреoffset.
   Функция возвращает числовую позицию последнего вхождения подстроки
   относительно начала строки haystack независимо от направления поиска и смещения.
   
Замечание: Позици строки начинаются с 0, а не с 1.
   Функция возвращет значение false, если строка не содержит подстроку.
  
Функция
возвращает как логическое значение false,
так и нелогическое значение, которое приводится к false.
Прочитайте раздел
«Логический тип»,
чтобы получить дополнительную информацию.
Используйте оператор ===
для проверки значения, которое возвращает функция.
| Версия | Описание | 
|---|---|
| 8.2.0 | Приведение к единому регистру больше не зависит от региональных настроек, которые установили функцией setlocale(). Преобразовываются только символы кодировки ASCII. Байты, которые не относятся к кодировке ASCII, сравнятся по значению байта. | 
| 8.0.0 | Параметр needleтеперь разрешает пустую строку. | 
| 8.0.0 | Функция перестала поддерживать передачу целого числа (int) в параметр needle. | 
| 7.3.0 | Передача целого числа (int) в needleустарела. | 
Пример #1 Пример поиска позиции последнего вхождения подстроки функцией strripos()
<?php
$haystack = 'ababcd';
$needle   = 'aB';
$pos      = strripos($haystack, $needle);
if ($pos === false) {
    echo "Функция не в строке ($haystack) подстроку ($needle)";
} else {
    echo "Поздравляем!\n";
    echo "Функция нашла в строке ($haystack) подстроку ($needle) на позиции ($pos)";
}
?>Результат выполнения приведённого примера:
Поздравляем! Функция нашла в строке (ababcd) подстроку (aB) на позиции (2)
Simple way to implement this function in PHP 4
<?php
if (function_exists('strripos') == false) {
    function strripos($haystack, $needle) {
        return strlen($haystack) - strpos(strrev($haystack), $needle);
    }
}
?>Suppose you just need a stripos function working backwards expecting that strripos does this job, you better use the following code of a custom function named strbipos:
<?php
function strbipos($haystack="", $needle="", $offset=0) {
// Search backwards in $haystack for $needle starting from $offset and return the position found or false
    $len = strlen($haystack);
    $pos = stripos(strrev($haystack), strrev($needle), $len - $offset - 1);
    return ( ($pos === false) ? false : $len - strlen($needle) - $pos );
}
// Test
$body = "01234Xy7890XYz456xy90";
$str = "xY";
$len = strlen($body);
echo "TEST POSITIVE offset VALUES IN strbipos<br>";
for ($i = 0; $i < $len; $i++) {
    echo "Search in [$body] for [$str] starting from offset [$i]: [" . strbipos($body, $str, $i) . "]<br>";
}
?>
Note that this function does exactly what it says and its results are different comparing to PHP 5 strripos function.I think you shouldn't underestimate the length of $needle in the search of THE FIRST POSITION of it's last occurrence in the string. I improved the posted function, with added support for offset. I think this is an exact copy of the real function:
<?php
if(!function_exists("strripos")){
    function strripos($haystack, $needle, $offset=0) {
        if($offset<0){
            $temp_cut = strrev(  substr( $haystack, 0, abs($offset) )  );
        }
        else{
            $temp_cut = strrev(  substr( $haystack, $offset )  );
        }
        $pos = strlen($haystack) - (strpos($temp_cut, strrev($needle)) + $offset + strlen($needle));
        if ($pos == strlen($haystack)) { $pos = 0; }
        return $pos;
    }/* endfunction strripos*/
}/* endfunction exists strripos*/
?>OK, I guess this will be the final function implementation for PHP 4.x versions ( my previous posts are invalid )
<?php
if(!function_exists("stripos")){
    function stripos(  $str, $needle, $offset = 0  ){
        return strpos(  strtolower( $str ), strtolower( $needle ), $offset  );
    }/* endfunction stripos */
}/* endfunction exists stripos */
if(!function_exists("strripos")){
    function strripos(  $haystack, $needle, $offset = 0  ) {
        if(  !is_string( $needle )  )$needle = chr(  intval( $needle )  );
        if(  $offset < 0  ){
            $temp_cut = strrev(  substr( $haystack, 0, abs($offset) )  );
        }
        else{
            $temp_cut = strrev(    substr(   $haystack, 0, max(  ( strlen($haystack) - $offset ), 0  )   )    );
        }
        if(   (  $found = stripos( $temp_cut, strrev($needle) )  ) === FALSE   )return FALSE;
        $pos = (   strlen(  $haystack  ) - (  $found + $offset + strlen( $needle )  )   );
        return $pos;
    }/* endfunction strripos */
}/* endfunction exists strripos */
?>Generally speaking, linear searches are from start to end, not end to start - which makes sense from a human perspective. If you need to find strings in a string backwards, reverse your haystack and needle rather than manually chopping it up.Sorry, I made that last post a bit prematurely.  One more thing wrong with the simple php4 version is that it breaks if the string is not found.  It should actually look like this:
<?php
if (function_exists('strripos') == false) {
    function strripos($haystack, $needle) {
        $pos = strlen($haystack) - strpos(strrev($haystack), strrev($needle));
        if ($pos == strlen($haystack)) { $pos = 0; }
        return $pos;
    }
}
?>
Note, we now check to see if the $needle was found, and if it isn't, we return 0.