从之前的一些帮助中,我能够构建它以从 swift 平台内提交 API POST 请求。
import Foundation
struct requestbody: Codable {
let data: DataClass
}
// MARK: - DataClass
struct DataClass: Codable {
let slices: [Slice]
let passengers: [Passenger]
let cabinClass: String
enum CodingKeys: String, CodingKey {
case slices, passengers
case cabinClass = "cabin_class"
}
}
// MARK: - Passenger
struct Passenger: Codable {
let type: String
}
// MARK: - Slice
struct Slice: Codable {
let origin, destination, departureDate: String
enum CodingKeys: String, CodingKey {
case origin, destination
case departureDate = "departure_date"
}
}
class APIPost {
func getposts(response: requestbody) -> URLRequest? {
guard let url = URL(string: "https://api.duffel.com/air/offer_requests") else { return nil }
var request = URLRequest(url: url)
request.setValue("application/json", forHTTPHeaderField: "Content-Type")
request.setValue("application/json", forHTTPHeaderField: "Accept")
request.setValue("beta", forHTTPHeaderField: "Duffel-Version")
request.setValue("Bearer [redacted]", forHTTPHeaderField: "Authorization")
request.httpMethod = "POST"
request.httpBody = try! JSONEncoder().encode(response)
return request
}
然而,我会说,当谈到如何集成这个方法来解码 JSON 响应,然后在 UI 中使用时,我有点难住了。我也无法在函数中添加完成参数(添加 @escaping),并且相信最好采取此操作并在另一个函数中构建它。任何高级(或详细)的答复将不胜感激。
谢谢!
创建一个URLRequest
实例是不够的,您还必须将此请求发送到您的服务器。您可以通过URLSession
API发送它。
// Notice the change in function signature
func getPost(requestBody: RequestBody, completion: @escaping ((_ posts: [Post]?, _ error: Error?) -> Void)) -> URLRequest? {
// Everything else same up to this point
request.httpBody = try! JSONEncoder().encode(requestBody)
// Send the request to your server
URLSession.shared.dataTask(with: request, completionHandler: { (data, urlResponse, error) in
// Check if there was an error from network/server
if let error = error {
print(error.localizedDescription)
// call completion with error from network/server
completion(nil, error)
return // return early because there was an error
}
// No error if we are, check for data
if let data = data {
do {
// Try decoding your data to your model
let posts = try JSONDecoder().decode([Post].self, from: data)
// call completion with your models array, no error
completion(posts, nil)
}
catch {
// there's a decoding error, call completion with decoding error
completion(nil, error)
}
}
}).resume() // resuming a dataTask is essential, otherwise the call won't be sent to server
return request
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句