本文實例講述了php使用json-schema模塊實現(xiàn)json校驗。分享給大家供大家參考,具體如下:
客戶端和服務(wù)端的http信息傳遞,采用json幾乎成了標配。json格式簡單,易于處理,不過由于沒有格式規(guī)定,無法校驗。
好在php有json-schema模塊,可以用來驗證json是否符合規(guī)定的格式。
安裝使用composer
composer require justinrainbow/json-schema:~1.3
新建一個schema文件,如:schema.json
{ "type": "object", "properties": { "firstName": { "type": "string", "required": true }, "lastName": { "type": "string" }, "age": { "type": "integer", "minimum": 0 }, "data":{ "type":"object", "required":true, "properties":{ } } } }
可以在字段里嵌套子結(jié)構(gòu),如果properties為空,則可以任意,比如上例的data。
類型有:
array
A JSON array.
boolean
A JSON boolean.
integer
A JSON number without a fraction or exponent part.
number
Any JSON number. Number includes integer.
null
The JSON null value.
object
A JSON object.
string
A JSON string.
php代碼如下:
$json = '{"firstName":"ban", "lastName":"shan","age":1,"data":{"hobby":"coding"} }'; $validator = new JsonSchema\Validator; $schema = file_get_contents("schema.json"); $validator->check(json_decode($json), json_decode($schema)); if ($validator->isValid()) { echo "The supplied JSON validates against the schema.\n"; } else { echo "JSON does not validate. Violations:\n"; foreach ($validator->getErrors() as $error) { echo sprintf("[%s] %s\n", $error['property'], $error['message']); } }
這樣先定義好通信的schema,在json發(fā)送給客戶端之前校驗是否和約定相同,避免不必要的錯誤。
參考鏈接,json-schema 文檔,php的json-schema 實現(xiàn)。
完整的代碼在此。
PS:本站還提供了如下XML與JSON相關(guān)工具,方便大家參考使用:
在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson
php代碼在線格式化美化工具:
http://tools.jb51.net/code/phpformat
在線XML格式化/壓縮工具:
http://tools.jb51.net/code/xmlformat
json代碼在線格式化/美化/壓縮/編輯/轉(zhuǎn)換工具:
http://tools.jb51.net/code/jsoncodeformat
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP中json格式數(shù)據(jù)操作技巧匯總》、《PHP針對XML文件操作技巧總結(jié)》、《PHP基本語法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
下一篇:php寫app用的框架整理