OAuth2を使用し、ヘッダー内のすべてのリクエストでアクセストークンを送信する必要があるため、カスタムヘッダーでAlamofire
を使用してPOSTリクエストを実装しました。この場合、カスタムヘッダーを使用する必要があります。
HTTPヘッダーフィールドAuthorization
のアクセストークン値が機能しません。サーバーは、アクセストークンを含むOAuthのヘッダー情報が利用できないため、エラーを生成します。
しかし、私のコードの間違いは何ですか?
ここに私の現在のコードがあります:
let URL = NSURL(string: url + "/server/rest/action")
var mutableURLRequest = NSMutableURLRequest(URL: URL!)
mutableURLRequest.setValue("Bearer \(accessToken)", forHTTPHeaderField: "Authorization")
//this method does not work anymore because it returns an error in the response
//Alamofire.Manager.sharedInstance.session.configuration.HTTPAdditionalHeaders = ["Authorization": "Bearer \(accessToken)"]
Alamofire.Manager.sharedInstance
.request(.POST, mutableURLRequest, parameters: parameters, encoding: .JSON)
.validate()
.responseJSON {
(request, response, data, error) -> Void in
NSLog("REQUEST: \(request)")
NSLog("RESPONSE: \(response)")
NSLog("DATA: \(data)")
NSLog("ERROR: \(error)")
}
カスタムヘッダーで使用する例を次に示します。
_ var manager = Manager.sharedInstance
// Specifying the Headers we need
manager.session.configuration.HTTPAdditionalHeaders = [
"Content-Type": "application/x-www-form-urlencoded",
"Accept": "application/vnd.lichess.v1+json",
"X-Requested-With": "XMLHttpRequest",
"User-Agent": "iMchess"
]
_
これで、リクエストを行うたびに、指定されたヘッダーが使用されます。
コードのリファクタリング:_import Alamofire
_を忘れないでください
_ let aManager = Manager.sharedInstance
manager.session.configuration.HTTPAdditionalHeaders = [
"Authorization": "Bearer \(accessToken)" ]
let URL = url + "/server/rest/action"
request(.POST, URL, encoding: .JSON)
.responseJSON {
(request, response, data, error) -> Void in
println("REQUEST: \(request)")
println("RESPONSE: \(response)")
println("DATA: \(data)")
println("ERROR: \(error)")
}
_
これはリクエストの署名request(method: Method, URLString: URLStringConvertible>, parameters: [String : AnyObject]?, encoding: ParameterEncoding)
です
ご覧のとおり、URLの文字列だけでNSURLを渡す必要はなく、Alamofireが残りを処理します。
Swift 3およびAlamofire 4.0の単一のAlamofireリクエストでパラメーターとヘッダーを送信する簡単なソリューションがあります
let url = "myURL"
let parameters: Parameters = [
"param1": "hello",
"param2": "world"
]
let headers = [
"x-access-token": "myToken",
]
Alamofire.request(url, method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: headers).responseJSON { (response) in
if response.result.isFailure {
//In case of failure
}else {
//in case of success
}
}
let headers: HTTPHeaders = [
"Cookie": UserDefaultsUtil.getString(param: Constants.COOKIE),
"Accept": "application/json"
]
Alamofire.request(url, method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: headers)
.responseObject { (response: DataResponse<Any>) in
if response.result.isSuccess {
}
else {
}
}