在做接口測試的時候, 我們需要對返回的數據進行分析校驗, 一般返回的都是json格式的數據, 怎么來解析校驗呢? 之前有看過使用遞歸遍歷json數據的, 然后找到了jsonpath, 可以很方便的對json數據進行解析分析。
jsonpath
jsonpath是一種信息抽取類庫, 是從json文檔中抽取指定信息的工具
jsonpath對於json來說, 相當於xpath對於xml
[官方文檔地址](‘http://goessner.net/articles/JsonPath‘)
jsonpath和xpath語法對比
json結構信息, 可讀性高, 復雜度低, 非常容易匹配, 下表對應了xpath的用法
xpath | jsonpath | 描述 |
/ | $ | 根節點 |
. | @ | 現行節點 |
/ | .or[] | 取子節點 |
.. | n/a | 父元素 |
// | .. | 遞歸下降,所有符合條件的 |
* | * | 通配符, 表示所有元素 |
@ | n/a | 屬性訪問字符 |
[] | [] | 子元素操作符 |
[,] | 數組索引 | |
n/a | [start:end:step] | 數組分割 |
[] | ?() | 應用過濾表達式 |
jsonpath例子
{
“store”: {
“book”: [
{
“category”: “reference”,
“author”: “Nigel Rees”,
“title”: “Sayings of the Century”,
“price”: 8.95
},
{
“category”: “fiction”,
“author”: “Evelyn Waugh”,
“title”: “Sword of Honour”,
“price”: 12.99
},
{
“category”: “fiction”,
“author”: “Herman Melville”,
“title”: “Moby Dick”,
“isbn”: “0-553-21311-3”,
“price”: 8.99
},
{
“category”: “fiction”,
“author”: “J. R. R. Tolkien”,
“title”: “The Lord of the Rings”,
“isbn”: “0-395-19395-8”,
“price”: 22.99
}
],
“bicycle”: {
“color”: “red”,
“price”: 19.95
}
},
“expensive”: 10
}
有這樣一個json數據
XPath | JSONPath | 結果 |
/store/book/author | $.store.book[*].author | 所有書的作者 |
//author | $..author | 所有的作者 |
/store/* | $.store.* | store的所有元素。所有的bookst和bicycle |
/store//price | $.store..price | store里面所有東西的price |
//book[3] | $..book[2] | 第三個書 |
//book[last()] | $..book[(@.length-1)] | 最后一本書 |
//book[position()<3] | ..book[:2] | 前面的兩本書 |
//book[isbn] | $..book[?(@.isbn)] | 過濾出所有的包含isbn的書 |
//book[price<10] | $..book[?(@.price<10)] | 過濾出價格低於10的書。 |
//* | $..* | 所有元素。 |