Я пытаюсь проанализировать JSON с использованием протокола Codable , но получаю исключение. Это исключение происходит из-за нулевого значения в ответе от nestedkeyedcontainer для второго ответа.
Работает нормально для ответа ниже json
let jsonStr = """
{
"response": {
"PURCHASE_FREE_SIM_RESPONSE": {
"TOPUP": null,
"TOTAL_PAYMENT_AMOUNT": "0",
"TRANSACTION_ID": "MFST0000233010",
"TAX": null,
"VAT": null,
"SHIPPING_AMOUNT": null,
"ITG_TRANSACTION_ID": "ITG000000138832750",
"CHANNEL_TRANSACTION_ID": "8e56ecf01b",
"PAYMENT_RESPONSE": null,
"APM_RESPONSE": null,
"APPLICATION_TYPE": null,
"NAME_OR_PAGE_ID": null,
"URL": null,
"CUSTOM_FIELD_1": null,
"CUSTOM_FIELD_2": null,
"CUSTOM_FIELD_3": null,
"FEE": null
}
},
"API-Code": "engbr_mvnepurchasefreesim",
"statuscode": 200,
"statusMessage": "SUCCESS",
"respCode": {
"ERROR_CODE": "0",
"ERROR_DESC": "Success"
}
}
"""
//=========Second Response===============
let jsonStr = """
{
**"response": null,**
"API-Code": null,
"statuscode": 500,
"statusMessage": "Undefined index: HOUSE_NO",
**"respCode": null**
}
"""
Моя модель выглядит так: -
struct SimPurResponse:Decodable{
let topUp:String
let totalPaymentAmt:String
let transId:String
let apiCode:String
let statuscode:Int
let statusMessage:String
let errorCode:String
let errorDesc:String
private enum ResponseOuter : String, CodingKey {
case response
case apiCode = "API-Code"
case statuscode = "statuscode"
case respCode
case statusMessage = "statusMessage"
}
enum RespCodeKeys : String, CodingKey {
case errorCode = "ERROR_CODE"
case errorDesc = "ERROR_DESC"
}
private enum Response : String, CodingKey {
case PURCHASE_FREE_SIM_RESPONSE
}
private enum purchaseFreeSimResInfo : String, CodingKey {
case topUp = "TOPUP"
case totalPaymentAmt = "TOTAL_PAYMENT_AMOUNT"
case transId = "TRANSACTION_ID"
case tax = "TAX"
case vat = "VAT"
case shipingAmt = "SHIPPING_AMOUNT"
}
init(from decoder :Decoder) throws {
let container = try decoder.container(keyedBy: ResponseOuter.self)
self.apiCode = try container.decodeIfPresent(String.self, forKey: .apiCode) ?? ""
self.statuscode = try container.decodeIfPresent(Int.self, forKey: .statuscode) ?? 600
self.statusMessage = try container.decodeIfPresent(String.self, forKey: .statusMessage) ?? ""
let respCodeCont = try container.nestedContainer(keyedBy: RespCodeKeys.self, forKey: .respCode)
self.errorCode = try respCodeCont.decodeIfPresent(String.self, forKey: .errorCode) ?? ""
self.errorDesc = try respCodeCont.decodeIfPresent(String.self, forKey: .errorDesc) ?? ""
let purcCont = try container.nestedContainer(keyedBy: Response.self, forKey: .response)
let purSimCont = try purcCont.nestedContainer(keyedBy: purchaseFreeSimResInfo.self, forKey: .PURCHASE_FREE_SIM_RESPONSE)
self.topUp = try purSimCont?.decodeIfPresent(String.self, forKey: .topUp) ?? ""
self.totalPaymentAmt = try purSimCont?.decodeIfPresent(String.self, forKey: .totalPaymentAmt) ?? ""
self.transId = try purSimCont?.decodeIfPresent(String.self, forKey: .transId) ?? ""
self.tax = try purSimCont?.decodeIfPresent(String.self, forKey: .tax) ?? ""
self.vat = try purSimCont?.decodeIfPresent(String.self, forKey: .vat) ?? ""
self.shipingAmt = try purSimCont?.decodeIfPresent(String.self, forKey: .shipingAmt) ?? ""
}
}
let dataJosn = Data(jsonStr.utf8)
do {
let simDetail = try JSONDecoder().decode(SimPurResponse.self, from: dataJosn)
print(simDetail)
}catch let error {
print(error)
}
У меня проблема с обработкой обеих ситуаций. Выше полный код