首页 > 解决方案 > 如何解析 APEX REST 服务的 JSON 响应

问题描述

我编写了一个 REST 类,将 url 设置为调用 API 的端点。API 返回时区值。url 传递经度和纬度作为参数。我得到的响应是一个复杂的 JSON 列表,我只需要 Timezone 对象的 Id 值。这是我对传递的经纬度值的 JSON 响应:

{
   "Version":"2019c",
   "ReferenceUtcTimestamp":"2019-12-10T21:14:23.7869064Z",
   "TimeZones":[
      {
         "Id":"America/Los_Angeles",
         "Aliases":[
            "US/Pacific",
            "US/Pacific-New"
         ],
         "Countries":[
            {
               "Name":"United States",
               "Code":"US"
            }
         ],
         "Names":{
            "ISO6391LanguageCode":"No supported language code supplied",
            "Generic":"",
            "Standard":"",
            "Daylight":""
         },
         "ReferenceTime":{
            "Tag":"PST",
            "StandardOffset":"-08:00:00",
            "DaylightSavings":"00:00:00",
            "WallTime":"2019-12-10T13:14:23.7869064-08:00",
            "PosixTzValidYear":2019,
            "PosixTz":"PST+8PDT,M3.2.0,M11.1.0",
            "Sunrise":"2019-12-10T07:42:22.383-08:00",
            "Sunset":"2019-12-10T16:18:49.095-08:00"
         },
         "RepresentativePoint":{
            "Latitude":34.05222222222222,
            "Longitude":-118.24277777777777
         },
         "TimeTransitions":[
            {
               "Tag":"PST",
               "StandardOffset":"-08:00:00",
               "DaylightSavings":"00:00:00",
               "UtcStart":"2019-11-03T09:00:00Z",
               "UtcEnd":"2020-03-08T10:00:00Z"
            },
            {
               "Tag":"PDT",
               "StandardOffset":"-08:00:00",
               "DaylightSavings":"01:00:00",
               "UtcStart":"2020-03-08T10:00:00Z",
               "UtcEnd":"2020-11-01T09:00:00Z"
            },
            {
               "Tag":"PST",
               "StandardOffset":"-08:00:00",
               "DaylightSavings":"00:00:00",
               "UtcStart":"2020-11-01T09:00:00Z",
               "UtcEnd":"2021-03-14T10:00:00Z"
            }
         ]
      }
   ]
}

这是我在 APEX 中的 REST 服务:

public class LPP_AccountTimeZone {
    public static List<String> getTimeZone(String latitude, String longitude){
        Http http = new Http();
        HttpRequest req=new HttpRequest();

         String url = 'https://atlas.microsoft.com/timezone/byCoordinates/json?subscription-key=XXXXXXXXXXXXXXXXXXXXXXXXXXXX&api-version=1.0&options=all&query='+latitude+','+longitude;

         req.SetEndPoint(url);

         req.setMethod('GET');
         HttpResponse res=http.send(req);

        if (res.getStatusCode() == 200) {
        List<String> TimeZone = new List<String>();
        TimeZoneJSON result = TimeZoneJSON.parse(res.getBody());

        for(TimeZoneJSON.TimeZones t : result.timeZones){
            System.debug('TimeZone is' + t.Id);
            TimeZone.add(t.Id);
        }

    }

    else{
        System.debug('The status code returned was not expected: ' + res.getStatusCode() + ' ' + res.getStatus());
    }
    return TimeZone[0];
}

我用这段代码得到的响应(当我在匿名窗口中运行它时)是:

时区是{Aliases=(US/Pacific, US/Pacific-New), countries=({Code=US, Name=United States}), Id=America/Los_Angeles , Names={Daylight=Pacific Daylight Time, Generic=Pacific时间, ISO6391LanguageCode=en, Standard=太平洋标准时间}, ReferenceTime={DaylightSavings=00:00:00, PosixTz=PST+8PDT,M3.2.0,M11.1.0, PosixTzValidYear=2019, StandardOffset=-08:00:00 , 日出=2019-12-12T07:44:13.44-08:00, 日落=2019-12-12T16:18:47.934-08:00, 标签=PST, WallTime=2019-12-12T11:49:25.0802593-08 :00},代表

这是很多信息。我只想要 Id 等于的 America/Los_Angeles 部分(我在回复中有粗体字)。

这段代码的另一个问题是它没有返回任何东西/是 void 类。
我不需要返回该值,因为触发器正在调用该方法并将使用该值来更新字段。

谁能更正我的代码,以便它传递正确的 json 值并返回该值?

编辑/更新:我现在得到的错误是“变量不存在:时区(return 语句所在的位置)

标签: jsonapex

解决方案


您可以使用JSON2APEX从您的 JSON 响应中轻松生成一个顶点类。只需粘贴您的完整回复,然后单击“创建 Apex”。这将创建一个代表您的响应的类,以便您可以轻松地从中检索字段(请记住,这只有在您的响应是静态的时才真正起作用,这意味着结构和命名保持不变)。看看它生成的类,这会让你知道该怎么做。该类有一个parse(String JSON)方法,您可以调用该方法传入您的 JSON 响应,以使用您的响应值检索该类的实例。然后,只需像使用任何对象一样检索所需的字段即可。如果您采用这条路线,以下是获取时区 ID 代码的方式。(笔记:这假设您将类的名称保留为标准 'JSON2Apex'

if (res.getStatusCode() == 200) {
    JSON2Apex result = JSON2Apex.parse(res.getBody()); 

    for(JSON2Apex.TimeZones t: result.timeZones){
        System.debug('TimeZone is' + t.id);
        tId.add(t);
    }
 }

要返回一个值,只需更改void方法签名List<String>并返回 tId 列表,如下所示return tId;


推荐阅读