UTF-8 安全等效于 PHP 中的 ord 或 charCodeAt()
2022-08-30 23:21:21
我需要能够使用 ord() 来获得与 javascript 的 charCodeAt() 函数相同的值。问题是 ord() 不支持 UTF8。
如何让 Ą 在 PHP 中转换为 260?我尝试过一些uniord函数,但它们都报告256而不是260。
非常感谢您的任何帮助!
问候
我需要能够使用 ord() 来获得与 javascript 的 charCodeAt() 函数相同的值。问题是 ord() 不支持 UTF8。
如何让 Ą 在 PHP 中转换为 260?我尝试过一些uniord函数,但它们都报告256而不是260。
非常感谢您的任何帮助!
问候
mbstring version:
function utf8_char_code_at($str, $index)
{
$char = mb_substr($str, $index, 1, 'UTF-8');
if (mb_check_encoding($char, 'UTF-8')) {
$ret = mb_convert_encoding($char, 'UTF-32BE', 'UTF-8');
return hexdec(bin2hex($ret));
} else {
return null;
}
}
使用 htmlspecialchars 和 htmlspecialchars_decode 来获取一个字符:
function utf8_char_code_at($str, $index)
{
$char = '';
$str_index = 0;
$str = utf8_scrub($str);
$len = strlen($str);
for ($i = 0; $i < $len; $i += 1) {
$char .= $str[$i];
if (utf8_check_encoding($char)) {
if ($str_index === $index) {
return utf8_ord($char);
}
$char = '';
$str_index += 1;
}
}
return null;
}
function utf8_scrub($str)
{
return htmlspecialchars_decode(htmlspecialchars($str, ENT_SUBSTITUTE, 'UTF-8'));
}
function utf8_check_encoding($str)
{
return $str === utf8_scrub($str);
}
function utf8_ord($char)
{
$lead = ord($char[0]);
if ($lead < 0x80) {
return $lead;
} else if ($lead < 0xE0) {
return (($lead & 0x1F) << 6)
| (ord($char[1]) & 0x3F);
} else if ($lead < 0xF0) {
return (($lead & 0xF) << 12)
| ((ord($char[1]) & 0x3F) << 6)
| (ord($char[2]) & 0x3F);
} else {
return (($lead & 0x7) << 18)
| ((ord($char[1]) & 0x3F) << 12)
| ((ord($char[2]) & 0x3F) << 6)
| (ord($char[3]) & 0x3F);
}
}
PHP 扩展版本:
#include "ext/standard/html.h"
#include "ext/standard/php_smart_str.h"
const zend_function_entry utf8_string_functions[] = {
PHP_FE(utf8_char_code_at, NULL)
PHP_FE_END
};
PHP_FUNCTION(utf8_char_code_at)
{
char *str;
int len;
long index;
unsigned int code_point;
long i;
int status;
size_t pos = 0, old_pos = 0;
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "sl", &str, &len, &index) == FAILURE) {
return;
}
for (i = 0; pos < len; ++i) {
old_pos = pos;
code_point = php_next_utf8_char((const unsigned char *) str, (size_t) len, &pos, &status);
if (i == index) {
if (status == SUCCESS) {
RETURN_LONG(code_point);
} else {
RETURN_NULL();
}
}
}
RETURN_NULL();
}
ord()
每个字节工作(因为大多数PHP标准字符串函数 - 如果不是全部)。您需要将其转换为自己的,例如在多字节字符串扩展的帮助下:
$utf8Character = 'Ą';
list(, $ord) = unpack('N', mb_convert_encoding($utf8Character, 'UCS-4BE', 'UTF-8'));
echo $ord; # 260