站長資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        PHP8.3要有新函數(shù)了!(json_validate函數(shù)說明)

        本篇文章給大家?guī)砹岁P(guān)于php8.3的最新相關(guān)信息,其中主要介紹了PHP8.3將會(huì)添加名為json_validate的函數(shù),那么這個(gè)函數(shù)有什么用呢?怎么使用它呢?下面一起來看一下,希望對大家有幫助。

        PHP8.3要有新函數(shù)了!(json_validate函數(shù)說明)

        PHP 8.3 前瞻:`json_validate` 函數(shù)

        PHP 8.3 將會(huì)添加名為 json_validate 的函數(shù),用于驗(yàn)證傳入的字符串是否是合法的 JSON 字符串。

        在目前,驗(yàn)證 JSON 字符串的一種通用做法是嘗試將其解碼,并通過捕獲異常來確定。但某些情況下我們可能并不需要獲得具體的內(nèi)容,只需要驗(yàn)證其合法。新的 json_validate 函數(shù)相比 json_decode 耗用的內(nèi)存和資源更少,因?yàn)樗环治鲎址粫?huì)嘗試解碼。

        函數(shù)簽名

        /**  * 驗(yàn)證傳入的字符串是否為合法 JSON 字符串  *  * @param string $json 準(zhǔn)備驗(yàn)證的字符串  * @param int $depth 最大嵌套深度,必須大于 0  * @param int $flags 標(biāo)志掩碼,用于指定行為  * @return bool $json 是合法 JSON 字符串時(shí)返回 true,否則返回 false  */ function json_validate(string $json, int $depth = 512, int $flags = 0): bool {}
        登錄后復(fù)制

        標(biāo)志 Flags

        json_validate 的第三個(gè)參數(shù)是 flags,用于指定函數(shù)的行為。在目前,唯一可用的標(biāo)志是 JSON_INVALID_UTF8_IGNORE。

        該標(biāo)志在 PHP 7.2 中添加,作為 json_decode 的標(biāo)志常量,用于忽略對應(yīng)字符串中的 UTF-8 字符。

        json_validate('[1, 2, 3]', flags: JSON_INVALID_UTF8_IGNORE); // true  json_validate("["xc1xc1","a"]"); // false json_validate("["xc1xc1","a"]", flags: JSON_INVALID_UTF8_IGNORE); // true
        登錄后復(fù)制

        錯(cuò)誤處理

        json_validate 本身并不會(huì)返回錯(cuò)誤碼,如果你想要獲取具體的錯(cuò)誤信息,可用使用 json_last_error 和 json_last_error_msg 獲取。

        json_validate(""); // false  json_last_error(); // 4 json_last_error_msg(); // "Syntax error"
        登錄后復(fù)制

        json_validate("null"); // true  json_last_error(); // 0 json_last_error_msg(); // "No error"
        登錄后復(fù)制

        示例

        驗(yàn)證字符串并拋出異常

        if (json_validate($_GET['json']) === false) {     throw new JsonException(json_last_error_msg(), json_last_error()); }
        登錄后復(fù)制

        替代以前的驗(yàn)證方式

        - $value = json_decode($_GET['json'], flags: JSON_THROW_ON_ERROR); + if (!json_validate($_GET['json'])) { +   throw new JsonException(json_last_error_msg(), json_last_error()); + } + $value = json_decode($_GET['json']);
        登錄后復(fù)制

        Polyfill 搶先適配

        如果你想提前為 PHP 8.3 做適配,以在 8.3 發(fā)布的第一時(shí)間無縫切換到 json_validate,你可以手動(dòng)定義一個(gè)函數(shù),以在之前的版本中模仿 json_validate 的作用。

        if (!function_exists('json_validate')) {     function json_validate(string $json, int $depth = 512, int $flags = 0): bool {     if ($flags !== 0 && $flags !== JSON_INVALID_UTF8_IGNORE) {     throw new ValueError('json_validate(): Argument #3 ($flags) must be a valid flag (allowed flags: JSON_INVALID_UTF8_IGNORE)');     }     if ($depth <= 0 ) {     throw new ValueError('json_validate(): Argument #2 ($depth) must be greater than 0');     }     json_decode($json, null, $depth, $flags);     return json_last_error() === JSON_ERROR_NONE;     }   }
        登錄后復(fù)制

        由于此函數(shù)內(nèi)部依然使用 json_decode,所以其實(shí)際上并沒有性能上的改進(jìn),只是提供了和 json_validate 相似的接口。

        推薦學(xué)習(xí):《PHP視頻教程》

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
        主站蜘蛛池模板: 久久精品国产一区二区三区不卡 | 56prom精品视频在放免费| 精品国产亚洲一区二区在线观看| 精品人妻人人做人人爽| 久久久久无码国产精品不卡| 91无码人妻精品一区二区三区L| 久久香蕉国产线看观看精品yw| 久久精品夜色噜噜亚洲A∨ | 久久97精品久久久久久久不卡 | 在线亚洲精品自拍| 国产亚洲精品拍拍拍拍拍| 精品精品国产自在久久高清| 精品无人区一区二区三区| 亚洲日韩精品射精日| 亚洲国产精品综合久久一线| 精品国产婷婷久久久| 国产精品免费久久久久影院 | 国产精品狼人久久久久影院| 国产精品第13页| 国产精品久久久久AV福利动漫| 日韩国产精品无码一区二区三区| 亚洲精品成人在线| 亚洲精品欧美二区三区中文字幕| 国内精品久久久久久麻豆| 国产香蕉国产精品偷在线观看| 56prom精品视频在放免费| 午夜精品免费在线观看| 国产日韩一区在线精品欧美玲| 6一12呦女精品| 国产夫妇精品自在线| 国产精品福利网站导航| 国产精品你懂的| 热re99久久精品国产99热| 色综合久久精品中文字幕首页 | 亚洲av无码乱码国产精品fc2| 亚洲人成国产精品无码| 亚洲精品无码专区在线播放| 欧美久久亚洲精品| 最新国产精品拍自在线播放| 中文字幕精品视频在线| 久久亚洲国产成人精品性色|