PHP Conference Japan 2024

json_validate

(PHP 8 >= 8.3.0)

json_validate检查字符串是否包含有效的 JSON

描述

json_validate(字符串 $json, 整数 $depth = 512, 整数 $flags = 0): 布尔值

返回给定的 字符串 是否在语法上是有效的 JSON。如果 json_validate() 返回 true,则 json_decode() 使用相同的 depthflags 将成功解码给定的字符串。

如果 json_validate() 返回 false,则可以使用 json_last_error()json_last_error_msg() 获取原因。

json_validate() 如果不使用解码的 JSON 有效负载,则比 json_decode() 使用更少的内存,因为它不需要构建包含有效负载的数组或对象结构。

注意

json_decode() 之前立即调用 json_validate() 将不必要地解析字符串两次,因为 json_decode() 在解码过程中隐式地执行验证。

因此,仅当不立即使用解码的 JSON 有效负载并且需要知道字符串是否包含有效的 JSON 时,才应使用 json_validate()

参数

json

要验证的字符串。

此函数仅适用于 UTF-8 编码的字符串。

注意:

PHP 实现了一个 JSON 的超集,如原始 » RFC 7159 中所指定。

depth

正在解码的结构的最大嵌套深度。该值必须大于 0,并且小于或等于 2147483647

flags

目前仅接受 JSON_INVALID_UTF8_IGNORE

返回值

如果给定的字符串在语法上是有效的 JSON,则返回 true,否则返回 false

错误/异常

如果 depth 超出允许的范围,则会抛出 ValueError

如果 flags 不是有效的标志,则会抛出 ValueError

示例

示例 #1 json_validate() 示例

<?php
var_dump
(json_validate('{ "test": { "foo": "bar" } }'));
var_dump(json_validate('{ "": "": "" } }'));
?>

以上示例将输出

bool(true)
bool(false)

参见

添加注释

用户贡献的注释 2 个注释

20
Behrad
10 个月前
---------------- PHP < 8.3 ----------------

function json_validate(string $string): bool {
json_decode($string);

return json_last_error() === JSON_ERROR_NONE;
}

var_dump(json_validate('{ "test": { "foo": "bar" } }')); // true

---------------- PHP >= 8.3 ----------------

var_dump(json_validate('{ "test": { "foo": "bar" } }')); // true

注意:代码来自 https://php.net/releases/8.3/en.php
10
Julien T.
9 个月前
在 Allan R. 的初始想法的基础上,我为那些使用 PHP 8.2 及更早版本的用户开发了一个改进版本的 json_validate 函数。此函数模拟了 PHP 8.3 中引入的功能,提供了一种在早期 PHP 版本中有效验证 JSON 字符串的方法。

```php
if (!function_exists('json_validate')) {
/**
* 验证 JSON 字符串。
*
* @param string $json 要验证的 JSON 字符串。
* @param int $depth 最大深度。必须大于零。
* @param int $flags JSON 解码选项的位掩码。
* @return bool 如果字符串是有效的 JSON,则返回 true,否则返回 false。
*/
function json_validate($json, $depth = 512, $flags = 0) {
if (!is_string($json)) {
return false;
}

try {
json_decode($json, false, $depth, $flags | JSON_THROW_ON_ERROR);
return true;
} catch (\JsonException $e) {
return false;
}
}
}
```

主要改进

- 字符串检查:添加验证以确保输入为字符串。
- 错误处理:利用 try-catch 有效捕获和处理 JsonException。
- 向后兼容性:可以安全地集成到旧版 PHP 版本中,在 PHP 8.3 及更高版本中自动切换到原生功能。
To Top