2015-10-12 18 views
9

Desidero impostare i cookie nella mia richiesta HTTP POST.Swift 2.0, Alamofire: imposta i cookie in HTTP Post Request

Qualcosa come il campo cookie nella richiesta HTTP in basso,

version: 0.1.7 
Cookie: client=Android; version=0.1.7; sellerId=SEL5483318784; key=178a0506-0639-4659-9495-67e5dffa42de 
Content-Type: application/x-www-form-urlencoded; charset=UTF-8 
Content-Length: 1431 

Come posso raggiungere questo obiettivo con Alamofire?

Il mio attuale richiesta Alamofire è come questo,

Alamofire.request(.POST, ServerConfig.ADD_PRODUCT_URL, parameters: productJSON, encoding: .JSON, headers: nil) 
    .responseJSON(completionHandler: { responseRequest, responseResponse, responseResult in 
     print(responseRequest!.URL) 
     print(responseResponse) 
     print(responseResult) 
    }) 

risposta

17

Ho avuto lo stesso problema su un progetto e fare qualcosa di simile per risolverlo:

let cookies = NSHTTPCookie.cookiesWithResponseHeaderFields(response.allHeaderFields as! [String: String], forURL: response.URL!) 
Alamofire.Manager.sharedInstance.session.configuration.HTTPCookieStorage?.setCookies(cookies, forURL: response.URL!, mainDocumentURL: nil) 

Devi solo fare questo una volta, perché l'istanza Alamofire è un singleton, quindi per tutte le successive richieste il cookie è impostato.

Spero che sia quello che stai cercando :)

1

Grazie a Jérémy, ero in grado di:

Alamofire.request(.POST, url, ...) 
    .responseJSON { 
    response in 
    HTTPClient.updateCookies(response) 
    ... 
} 

static func updateCookies(response: Response<AnyObject, NSError>) { 
    if let 
     headerFields = response.response?.allHeaderFields as? [String: String], 
     URL = response.request?.URL { 
     let cookies = NSHTTPCookie.cookiesWithResponseHeaderFields(headerFields, forURL: URL) 
     //print(cookies) 
     // Set the cookies back in our shared instance. They'll be sent back with each subsequent request. 
     Alamofire.Manager.sharedInstance.session.configuration.HTTPCookieStorage?.setCookies(cookies, forURL: URL, mainDocumentURL: nil) 
    } 
} 

Si potrebbe molto probabilmente fare questo un'estensione su richiesta, in modo che il .storeCookies() la chiamata sarebbe parte del .validate(). responseJSON() concatenamento.

2

Swift 3:

ho avuto una serie di cookie salvati nei miei UserDefaults e quello che ho fatto per il fissaggio alla richiesta è stata:

var request = URLRequest(url: "https://yourURL.com") 
if let cookies = cookies as? [HTTPCookie] { 
    let headers = HTTPCookie.requestHeaderFields(with: cookies) 
    request.allHTTPHeaderFields = headers 
}