json - 如何解析 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 语句所在的位置)
解决方案
您可以使用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;
推荐阅读
- javascript - 删除草稿后的 Gmail API、侧边栏和计数器未更新
- django - Django RestFramework - NOT NULL 约束失败
- html - 页面在 Safari 和 Firefox 中呈现不同
- html - 有没有办法让 iframe 全屏显示?
- javascript - Javascript - 正则表达式不包含某些字符
- pandas - 如果它包含字符串(而不是完全匹配),如何检查 Pandas 数据框列的每一行?
- r - 在 dplyr 管道中,以编程方式重命名列(左侧和右侧)
- sql-server - 无效的列名和无法在 WHERE 子句中绑定多部分标识符
- r - 检查一个表的字符串是否都包含在另一个表中
- php - TYPO3 9.5.3 / Extbase:后端和前端的时区错误