// Мне очень скучно. У меня вдруг возникла прихоть, и я захотел заново реализовать некоторые инкапсулированные функции PHP с помощью PHP.
//Таким образом, следующий код в основном реализует некоторые функции обработки строк в PHP, а также реализует некоторые функции PHP
// Нет, но те же функции обработки строк также полезны. Эти же функции можно реализовать и на других языках.
// Теперь, например, используя C/VBScript/Perl и т. д., вы можете иметь свою собственную библиотеку функций.
// Следующие функции не обязательно будут работать успешно, они предназначены только для обучения.
//
// Если нет специального заявления, это оригинальная работа heiyeluren. Если вы хотите использовать какую-либо функцию, сохраните информацию об авторе.
/**
* Реконструкция строковых функций
*
* Авторские права (c) 2005 г. heiyeluren < [email protected] >
* Автор: heiyeluren < [email protected] >
* $Id: StringFunctions.php,v 0.1 e 2005-5-29 23:21 heiyeluren Exp $
**/
// {{{ стрлен()
/**
* Подсчет длины строки
*
* @param string $str нужна строковая переменная длины счетчика
* @return int возвращает результат подсчета
* @версия v0.1
* @create 24 мая 2005 г.
* @изменено 24 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция strlen1($str)
{
если ($str == '')
вернуть 0;
$счет = 0;
пока (1)
{
если ($str[$count] != NULL)
{
$счет++;
продолжать;
}
еще
перерыв;
}
вернуть $счет;
}
// }}}
// {{{ субстр()
/**
* Получить подстроку
*
* @param string $str нужно получить переменную подстроки
* @param int $start start получить подстроку
* @param int $length нужно получить длину строки
* @return string возвращает подстроку
* @версия v0.2
* @create 24 мая 2005 г.
* @изменено 25 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция substr1($str, $start, $length=0)
{
если ($str == '')
возвращаться;
если ($start > strlen($str))
возвращаться;
if (($length != NULL) && ($start > 0) && ($length > strlen($str)-$start))
возвращаться;
if (($length != NULL) && ($start < 0) && ($length > strlen($str)+$start))
возврат,
если ($длина == NULL)
$length = (strlen($str) - $start);
если ($start <0)
{
for ($i=(strlen($str)+$start); $i<(strlen($str)+$start+$length); $i++)
{
$substr.= $str[$i];
}
}
if ($длина > 0)
{
for ($i=$start; $i<($start+$length); $i++)
{
$substr.= $str[$i];
}
}
если ($длина <0)
{
for ($i=$start; $i<(strlen($str)+$length); $i++)
{
$substr.= $str[$i];
}
}
вернуть $субстр;
}
// }}}
// {{{ стррев()
/**
* Обратный порядок строк
*
* @param string $str нужна строковая переменная обращения
* @return строка обращения строки
* @версия v0.1 www.knowsky.com
* @create 24 мая 2005 г.
* @изменено 24 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция strrev1($str)
{
если ($str == '')
вернуть 0;
for ($i=(strlen($str)-1); $i>=0; $i--)
{
$rev_str .= $str[$i];
}
вернуть $rev_str;
}
// }}}
// {{{ стркмп()
/**
*Сравнение строк
*
* @param string $s1 первая строка
* @param string $s2 вторая строка
* @return int return -1,str1 < str2 return 1, str1 > str2, str1 = str2,
* вернуть 0, другое, вернуть ложь
* @версия v0.1
* @create 24 мая 2005 г.
* @изменено 24 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция strcmp1($s1, $s2)
{
если (strlen($s1) < strlen($s2))
вернуть -1;
если (strlen($s1) > strlen($s2))
вернуть 1
для ($i=0; $i<strlen($s1); $i++)
{
если ($s1[$i] == $s2[$i])
продолжать;
еще
вернуть ложь;
}
вернуть 0;
}
// }}}
// {{{ strchr(), strstr(), strpos()
/**
* Найти первое вхождение строки
*
* @param string $str родительская строка
* @param string $substr должна соответствовать подстроке
* @return int return найти подстроку на первом месте родительской строки,
* если не найден, верните false
* @версия v0.4
* @create 24 мая 2005 г.
* @изменено 29 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция strchr1($str, $substr)
{
$м = стрлен($стр);
$n = strlen($substr);
если ($m <$n)
вернуть ложь
для ($i=0; $i<=($m-$n+1); $i++)
{
$sub = substr($str, $i, $n);
если (strcmp($sub, $substr) == 0)
вернуть $я;
}
вернуть ложь;
}
// }}}
// {{{ str_replace()
/**
* Замените все вхождения строки поиска строкой замены.
*
* @param string $substr необходимо заменить переменную подстроки
* @param string $newsubstr новая подстрока
* @param string $str управляет родительской строкой
* @return string возвращает замену после новой родительской строки
* @версия v0.2
* @create 24 мая 2005 г.
* @изменено 29 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция str_replace1($substr, $newsubstr, $str)
{
$м = стрлен($стр);
$n = стрлен($substr);
$x = strlen($newsubstr);
если (strchr($str, $substr) == false)
вернуть ложь
для ($i=0; $i<=($m-$n+1); $i++)
{
$i = strchr($str, $substr);
$str = str_delete($str, $i, $n);
$str = str_insert($str, $i, $newstr);
}
вернуть $стр;
}
// }}}
/************ Следующие функции обработки строк недоступны в PHP. Я написал их сам ради развлечения ***************/
// {{. { Insert_str(), delete_str(), index_str()
/**
* Базовая строка работает
*
* @param string $str нужно получить переменную подстроки
* @param int $start start получить подстроку
* @param int $length нужно получить длину строки
* @return string возвращает подстроку
* @версия v0.1
* @create 24 мая 2005 г.
* @изменено 24 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция str_insert($str, $i, $substr)
{
for($j=0; $j<$i; $j++)
{
$startstr .= $str[$j];
}
for ($j=$i; $j<strlen($str); $j++)
{
$laststr .= $str[$j];
}
$str = ($startstr. $substr. $laststr);
вернуть $стр;
}
функция str_delete($str, $i, $j)
{
для ($c=0; $c<$i; $c++)
{
$startstr .= $str[$c];
}
for ($c=($i+$j); $c<strlen($str); $c++)
{
$laststr .= $str[$c];
}
return $str
);
}
// }}}
// {{{ стркпи()
/**
* Используйте назначенную подстроку для замены строки
*
* @param string $str необходимо получить переменную подстроки
* @param int $start start получить подстроку
* @param int $length нужно получить длину строки
* @return string возвращает подстроку
* @версия v0.1
* @create 27 мая 2005 г.
* @изменено 27 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция strcpy($s1, $s2)
{
если (strlen($s1) == NULL)
возвращаться;
если (!isset($s2))
возврат
для ($i=0; $i<strlen($s1); $i++)
{
$s2[] = $s1[$i];
}
вернуть $s2;
}
// }}}
// {{{ стркат()
/**
* Используйте назначенную подстроку для замены строки
*
* @param string $str необходимо получить переменную подстроки
* @param int $start start получить подстроку
* @param int $length нужно получить длину строки
* @return string возвращает подстроку
* @версия v0.1
* @create 27 мая 2005 г.
* @изменено 27 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
функция strcat($s1, $s2)
{
если (!isset($s1))
возвращаться;
если (!isset($s2))
возврат
$newstr = $s1 $s2
возврат $newsstr;
}
// }}}
// {{{ php_encode(), php_decode()
/**
* Простая функция кодирования/декодирования строк.
*
* @param string $str требуется кодировать/закодировать строковую переменную
* @return код строки/кодировать после строки
* @версия v0.2
* @create 11 марта 2005 г.
* @изменено 24 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
/* Функция кодирования строки */
функция php_encode($str)
{
if ($str=='' && strlen($str)>128)
вернуть ложь
для ($i=0; $i<strlen($str); $i++)
{
$c = ord($str[$i]);
если ($c>31 && $c<107)
$с += 20;
если ($c>106 && $c<127)
$с -= 75;
$word = chr($c);
$s .= $word;
}
вернуть $s;
}
/* Функция декодирования строки */
функция php_decode($str)
{
if ($str=='' && strlen($str)>128)
вернуть ложь
для ($i=0; $i<strlen($str); $i++)
{
$c = ord($word);
если ($c>106 && $c<127)
$с = $с-20;
если ($c>31 && $c<107)
$с = $с+75;
$word = chr($c);
$s .= $word;
}
вернуть $s;
}
// }}}
// {{{ php_encrypt(), php_decrypt()
/**
* Простая функция шифрования/дешифрования строк.
*
* @param string $str нужна строковая переменная crypt
* @return строка шифрует/дешифрует после строки
* @версия v0.1
* @create 27 мая 2005 г.
* @изменено 29 мая 2005 г.
* @author heiyeluren < [email protected] >
*/
/* определить ключ шифрования */
$encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890';
$decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359'
/* Функция шифрования строки */
функция php_encrypt($str)
{
глобальный $encrypt_key, $decrypt_key,
если (strlen($str) == 0)
вернуть ложь
для ($i=0; $i<strlen($str); $i++)
{
for ($j=0; $j<strlen($encrypt_key); $j++)
{
if ($str[$i] == $encrypt_key[$j])
{
$enstr .= $decrypt_key[$j];
перерыв;
}
}
}
вернуть $энстр;
}
/* Функция расшифровки строки */
функция php_decrypt($str)
{
глобальный $encrypt_key, $decrypt_key,
если (strlen($str) == 0)
вернуть ложь
для ($i=0; $i<strlen($str); $i++)
{
for ($j=0; $j<strlen($decrypt_key); $j++)
{
if ($str[$i] == $decrypt_key[$j])
{
$enstr .= $encrypt_key[$j];
перерыв;
}
}
}
вернуть $энстр;
}
// }}}
Если код непонятен, рекомендуется проверить ссылку на мой блог на blogchina: