0

我想s.d.url从下面的 JSON 中提取值。
我正在使用下面的语句,如使用 System.out.println 所示,但我没有得到结果。当字段本身包含“。”时,我该怎么做?

JSON

{  
   "data":{  
      "H1":{  
         "com.abc.def":{  
            "a_enabled":false,
            "b_config":true
         },
         "c.s.urls":{  
            "s.d.url":"https://url1.com",
            "w.p.url":"https://url2.com",
            "s.c.url":"https://url3.com"
         },
         "com.abc.con":{  
            "e_n":true,
            "a_r":false,
            "c_t":"XYZMB"
         }
      },
      "dCId":"ABCD"
   }
}

ExtractableResponse<Response> spec =  given()
    .request().log().all()
    .expect().statusCode(200)
    .when()
    .get(EndpointsCloudServices.getConfigUrl() + "?" + params)
    .then().log().body()
            .extract();

            //want to get value of s.d.url
            System.out.println("Triage????  " + spec.path("data.H1.c.s.urls.s.d.url"));
4

1 回答 1

0

尝试以下,它将返回值s.d.url(注意方括号和单引号):

spec.path("data.H1.['c.s.urls'].['s.d.url']")

甚至更短,如果您确定这s.d.url是整个 json 文档中的唯一名称:

spec.path("$.['s.d.url']")

接下来,这只是为了说明使用 JSONPath 表达式在名称中包含点的引用字段的常见情况 - 您只需将字段名称包装在['']

示例 JSON:

{
   "field.name": "value",
   "nested": {
        "field.with.dot": {
             "field.inside": "anotherValue"
        }
    }  
}

用于访问相应字段值的有效 JSONPath 表达式示例:

$['field.name']                                 
$.['field.inside']                            
nested.['field.with.dot'].['field.inside']

提示:您可以使用在线评估器表达式测试器等工具快速测试您的 JSONPaths 和您的 json

于 2017-08-24T21:54:55.770 回答