以下是可编码的结构化代码:
import Foundation
public struct TaskID: Codable {
let embedded: Embedded
}
public struct Embedded: Codable {
let task: [Task]
}
public struct Task : Codable {
let embedded: EmbeddedVariable
let id : String
let name: String
let assignee: String
let created: String
let processDefinitionId: String
}
public struct EmbeddedVariable: Codable {
let variable : [Variables]
}
public struct Variables: Codable {
let value : String
let name: String
}
我曾经尝试过codingKey,也尝试过使用_embedded。面对同样的问题。
错误日志:由于错误,无法解码响应:
Alamofire.AFError.
ResponseSerializationFailureReason.decodingFailed(error: Swift.DecodingError.typeMismatch(Swift.Dictionary<Swift.String, Any>, Swift.DecodingError.Context(codingPath: [], debugDescription: "Expected to decode Dictionary<String, Any> but found an array instead.", underlyingError: nil)))))
数据无法读取,因为它的格式不正确。
下面是JSONSerialization的代码:
// MARK: - URLRequestConvertible
func asURLRequest() throws -> URLRequest {
let url = try K.ProductionServer.baseURL.asURL()
var urlRequest = URLRequest(url: url.appendingPathComponent(path))
print(urlRequest)
// HTTP Method
urlRequest.httpMethod = method.rawValue
let authToken = UserDefaults.standard.string(forKey: "authToken")
let bearerToken: String = "Bearer " + (authToken ?? "")
print("baearer token::\(bearerToken)")
// Common Headers
urlRequest.setValue(ContentType.json.rawValue, forHTTPHeaderField: HTTPHeaderField.acceptType.rawValue)
urlRequest.setValue(ContentType.json.rawValue, forHTTPHeaderField: HTTPHeaderField.contentType.rawValue)
urlRequest.setValue(bearerToken, forHTTPHeaderField: HTTPHeaderField.authentication.rawValue)
// Parameters
if let parameters = parameters {
do {
urlRequest.httpBody = try JSONSerialization.data(withJSONObject: parameters, options: [])
} catch {
throw AFError.parameterEncodingFailed(reason: .jsonEncodingFailed(error: error))
}
}
return urlRequest
}
下面是json返回响应的代码:
import Foundation
import Alamofire
public class APIClient {
@discardableResult
private static func performRequest<T:Decodable>(route:APIRouter, decoder: JSONDecoder = JSONDecoder(), completion:@escaping (AFResult<T>)->Void) -> DataRequest {
return AF.request(route)
.responseDecodable (decoder: decoder){ (response: AFDataResponse<T>) in
completion(response.result)
print("framework response::",response.result)
}
}
public static func taskID(id: String, completion:@escaping (AFResult<MyTaskData>)->Void) {
performRequest(route: APIRouter.TaskById(id: id), completion: completion)
}
}//APIClient
发布于 2019-11-15 08:23:19
在JSON有效负载中,键processDefinitionId.的值末尾有一个额外的逗号
尝试这个JSON格式化工具来验证JSON:jsonformatter
"task":[
{
//...
"id": "412a2aca-06ae-11ea-8860-120ef5ab2c25",
"name": "Quick Evaluation",
"assignee": "demo",
"created": "2019-11-14T07:13:27.558+0000",
"processDefinitionId": "quickEvaluation:1:129ce2b1-0616-11ea-8860-120ef5ab2c25", // remove this coma(,) from this line
}
更新:
使用CodingKey
作为_embedded
。尝试以下方法
// MARK: - TaskID
struct TaskID: Codable {
let embedded: Embedded
let count: Int
enum CodingKeys: String, CodingKey {
case embedded = "_embedded"
case count
}
}
// MARK: - Embedded
struct Embedded: Codable {
let task: [Task]
}
// MARK: - Task
struct Task: Codable {
let embedded: EmbeddedVariable
let id, name, assignee, created: String
let processDefinitionID: String
enum CodingKeys: String, CodingKey {
case embedded = "_embedded"
case id, name, assignee, created
case processDefinitionID = "processDefinitionId"
}
}
// MARK: - EmbeddedVariable
struct EmbeddedVariable: Codable {
let variable: [Variable]
}
// MARK: - Variable
struct Variable: Codable {
let links: Links
let name, value, type: String
let valueInfo: ValueInfo
enum CodingKeys: String, CodingKey {
case links = "_links"
case name, value, type, valueInfo
}
}
// MARK: - Links
struct Links: Codable {
let linksSelf: SelfClass
enum CodingKeys: String, CodingKey {
case linksSelf = "self"
}
}
// MARK: - SelfClass
struct SelfClass: Codable {
let href: String
}
// MARK: - ValueInfo
struct ValueInfo: Codable {
}
发布于 2019-11-18 21:51:06
如何将所有embeded
更改为可编码结构中的_embeded
?
在APIClient
类中,默认创建JSONDecoder
实例。而且它在解码时不更改密钥名,包括下划线。
如果不指定
JSONDecoder.KeyDecodingStrategy.useDefaultKeys
策略,则使用该策略。苹果公司的文件
代码
public struct TaskID: Codable {
let _embedded: Embedded
}
public struct Task : Codable {
let _embedded: EmbeddedVariable
let id : String
let name: String
let assignee: String
let created: String
let processDefinitionId: String
}
发布于 2019-11-19 06:10:57
试着使用QuickType.io
// MARK: - Welcome
struct Welcome: Codable {
let embedded: WelcomeEmbedded
let count: Int
enum CodingKeys: String, CodingKey {
case embedded = "_embedded"
case count
}
}
要解析来自Alamofire响应的值: Alamofire.request(url).responseWelcomeEmbedded { welcomeEmbedded = response.result.value {.}中的响应
// MARK: - WelcomeEmbedded
struct WelcomeEmbedded: Codable {
let task: [Task]
}
要解析来自Alamofire响应的值: Alamofire.request(url).responseTask {响应如果让任务= response.result.value {.}
// MARK: - Task
struct Task: Codable {
let embedded: TaskEmbedded
let id, name, assignee, created: String
let processDefinitionID: String
enum CodingKeys: String, CodingKey {
case embedded = "_embedded"
case id, name, assignee, created
case processDefinitionID = "processDefinitionId"
}
}
要解析来自Alamofire响应的值: Alamofire.request(url).responseTaskEmbedded {响应如果taskEmbedded = response.result.value {.}
// MARK: - TaskEmbedded
struct TaskEmbedded: Codable {
let variable: [Variable]
}
要解析来自Alamofire响应的值: Alamofire.request(url).responseVariable {响应如果让变量= response.result.value {.}
// MARK: - Variable
struct Variable: Codable {
let links: Links
let embedded: JSONNull?
let name, value, type: String
let valueInfo: ValueInfo
enum CodingKeys: String, CodingKey {
case links = "_links"
case embedded = "_embedded"
case name, value, type, valueInfo
}
}
要解析来自Alamofire响应的值: Alamofire.request(url).responseLinks {响应如果让链接= response.result.value {.}
// MARK: - Links
struct Links: Codable {
let linksSelf: SelfClass
enum CodingKeys: String, CodingKey {
case linksSelf = "self"
}
}
解析来自Alamofire响应的值: Alamofire.request(url).responseSelfClass { response in if let selfClass = response.result.value {.}}
// MARK: - SelfClass
struct SelfClass: Codable {
let href: String
}
要解析来自Alamofire响应的值: Alamofire.request(url).responseValueInfo {响应如果valueInfo = response.result.value {.}
// MARK: - ValueInfo
struct ValueInfo: Codable {
}
// MARK: - Helper functions for creating encoders and decoders
func newJSONDecoder() -> JSONDecoder {
let decoder = JSONDecoder()
if #available(iOS 10.0, OSX 10.12, tvOS 10.0, watchOS 3.0, *) {
decoder.dateDecodingStrategy = .iso8601
}
return decoder
}
func newJSONEncoder() -> JSONEncoder {
let encoder = JSONEncoder()
if #available(iOS 10.0, OSX 10.12, tvOS 10.0, watchOS 3.0, *) {
encoder.dateEncodingStrategy = .iso8601
}
return encoder
}
// MARK: - Alamofire response handlers
extension DataRequest {
fileprivate func decodableResponseSerializer<T: Decodable>() -> DataResponseSerializer<T> {
return DataResponseSerializer { _, response, data, error in
guard error == nil else { return .failure(error!) }
guard let data = data else {
return .failure(AFError.responseSerializationFailed(reason: .inputDataNil))
}
return Result { try newJSONDecoder().decode(T.self, from: data) }
}
}
@discardableResult
fileprivate func responseDecodable<T: Decodable>(queue: DispatchQueue? = nil, completionHandler: @escaping (DataResponse<T>) -> Void) -> Self {
return response(queue: queue, responseSerializer: decodableResponseSerializer(), completionHandler: completionHandler)
}
@discardableResult
func responseWelcome(queue: DispatchQueue? = nil, completionHandler: @escaping (DataResponse<Welcome>) -> Void) -> Self {
return responseDecodable(queue: queue, completionHandler: completionHandler)
}
}
https://stackoverflow.com/questions/58872760
复制相似问题