Есть ли в PHP некоторая функция encodeURI(), которая не кодирует: [email protected]#$&*()=:/,;?+'
?
EncodeURI() в PHP?
Ответ 1
Я использую это сейчас
function encodeURI($url) {
// http://php.net/manual/en/function.rawurlencode.php
// https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/encodeURI
$unescaped = array(
'%2D'=>'-','%5F'=>'_','%2E'=>'.','%21'=>'!', '%7E'=>'~',
'%2A'=>'*', '%27'=>"'", '%28'=>'(', '%29'=>')'
);
$reserved = array(
'%3B'=>';','%2C'=>',','%2F'=>'/','%3F'=>'?','%3A'=>':',
'%40'=>'@','%26'=>'&','%3D'=>'=','%2B'=>'+','%24'=>'$'
);
$score = array(
'%23'=>'#'
);
return strtr(rawurlencode($url), array_merge($reserved,$unescaped,$score));
}
Это в основном rawurlencodes все, а затем декодирует несколько вещей назад (как сказал Занлок в своем комментарии). Это должно соответствовать спецификациям Mozilla encodeURI.
Ответ 2
Здесь альтернативная версия, основанная на спецификации MDN:
function encodeURI($uri)
{
return preg_replace_callback("{[^0-9a-z_.!~*'();,/?:@&=+$#-]}i", function ($m) {
return sprintf('%%%02X', ord($m[0]));
}, $uri);
}