function isJson($string) {
json_decode($string);
return (json_last_error() == JSON_ERROR_NONE);
}
Мне нужен действительно быстрый метод проверки, является ли строка JSON или нет. Я чувствую, что это не лучший способ:
function isJson($string) {
return ((is_string($string) &&
(is_object(json_decode($string)) ||
is_array(json_decode($string))))) ? true : false;
}
Любые энтузиасты по производительности хотят улучшить этот метод?
php,json,error-handling,json-deserialization,jsonresult,
Ответ на вопрос
Функция json_last_error
возвращает последнюю ошибку, возникшую во время кодирования и декодирования JSON. Таким образом, самый быстрый способ проверить действительный JSON
// decode the JSON data
// set second parameter boolean TRUE for associative array output.
$result = json_decode($json);
if (json_last_error() === JSON_ERROR_NONE) {
// JSON is valid
}
// OR this is equivalent
if (json_last_error() === 0) {
// JSON is valid
}
Обратите внимание, что json_last_error
поддерживается только в PHP> = 5.3.0.
Полная программа для проверки точной ОШИБКИ
Всегда хорошо знать точную ошибку во время разработки. Вот полная программа для проверки точной ошибки на основе документов PHP.
function json_validate($string)
{
// decode the JSON data
$result = json_decode($string);
// switch and check possible JSON errors
switch (json_last_error()) {
case JSON_ERROR_NONE:
$error = ''; // JSON is valid // No error has occurred
break;
case JSON_ERROR_DEPTH:
$error = 'The maximum stack depth has been exceeded.';
break;
case JSON_ERROR_STATE_MISMATCH:
$error = 'Invalid or malformed JSON.';
break;
case JSON_ERROR_CTRL_CHAR:
$error = 'Control character error, possibly incorrectly encoded.';
break;
case JSON_ERROR_SYNTAX:
$error = 'Syntax error, malformed JSON.';
break;
// PHP >= 5.3.3
case JSON_ERROR_UTF8:
$error = 'Malformed UTF-8 characters, possibly incorrectly encoded.';
break;
// PHP >= 5.5.0
case JSON_ERROR_RECURSION:
$error = 'One or more recursive references in the value to be encoded.';
break;
// PHP >= 5.5.0
case JSON_ERROR_INF_OR_NAN:
$error = 'One or more NAN or INF values in the value to be encoded.';
break;
case JSON_ERROR_UNSUPPORTED_TYPE:
$error = 'A value of a type that cannot be encoded was given.';
break;
default:
$error = 'Unknown JSON error occured.';
break;
}
if ($error !== '') {
// throw the Exception or exit // or whatever :)
exit($error);
}
// everything is OK
return $result;
}
Тестирование с помощью действительного JSON INPUT
$json = '[{"user_id":13,"username":"stack"},{"user_id":14,"username":"over"}]';
$output = json_validate($json);
print_r($output);
Действительный ВЫХОД
Array
(
[0] => stdClass Object
(
[user_id] => 13
[username] => stack
)
[1] => stdClass Object
(
[user_id] => 14
[username] => over
)
)
Тестирование с использованием недействительного JSON
$json = '{background-color:yellow;color:#000;padding:10px;width:650px;}';
$output = json_validate($json);
print_r($output);
Недопустимый ВЫХОД
Syntax error, malformed JSON.
Дополнительное примечание для (PHP> = 5.2 && PHP <5.3.0)
Поскольку json_last_error
в PHP 5.2 не поддерживается, вы можете проверить, возвращает ли кодировка или декодирование логическое значение FALSE
. Вот пример
// decode the JSON data
$result = json_decode($json);
if ($result === FALSE) {
// JSON is invalid
}
Надеюсь, это полезно. Счастливое кодирование!
Использование json_decode
для «зондирования» может быть не самым быстрым способом. Если это глубоко вложенная структура, то создание множества объектов массивов, чтобы просто выбросить их, является пустой тратой памяти и времени.
Таким образом, это может быть быстрее использовать, preg_match
и регулярное выражение RFC4627 также гарантирует достоверность :
// in JS:
var my_JSON_object = !(/[^,:{}[]0-9.-+Eaeflnr-u
]/.test(
text.replace(/"(\.|[^"\])*"/g, '')));
То же самое в PHP:
return !preg_match('/[^,:{}\[\]0-9.\-+Eaeflnr-u \n\r\t]/',
preg_replace('/"(\.|[^"\\])*"/', '', $json_string));
Однако недостаточно энтузиастов производительности, чтобы беспокоиться о контрольных показателях.
Это вернет true, если ваша строка представляет собой json-массив или объект :
function isJson($str) {
$json = json_decode($str);
return $json && $str != $json;
}
Он отклоняет строки json, которые содержат только число, строку или логическое значение, хотя эти строки являются технически обоснованными json.
var_dump(isJson('{"a":5}')); // bool(true)
var_dump(isJson('[1,2,3]')); // bool(true)
var_dump(isJson('1')); // bool(false)
var_dump(isJson('1.5')); // bool(false)
var_dump(isJson('true')); // bool(false)
var_dump(isJson('false')); // bool(false)
var_dump(isJson('null')); // bool(false)
var_dump(isJson('hello')); // bool(false)
var_dump(isJson('')); // bool(false)
Это самый короткий путь, который я могу придумать.