AFNetworking — перевод запроса на размещение cURL

Это запрос PUT, который выполняется с помощью cURL:

curl -X PUT \
-H 'Accept: application/vnd.layer+json; version=1.1' \
-H 'Authorization: Bearer XXXXXXXXXXX' \
-H 'Content-Type: application/json' \
-d '{"external_unread_count": 13}' \
https://api.layer.com/apps/XXXXX-XXXXX-XXXXX-XXXXX-XXXXXXX/users/XXXXXXX/badge

Вот документация API, которую я пытаюсь имитировать:

введите здесь описание изображения

Я пытаюсь отправить тот же запрос, используя AFNetworking:

NSDictionary *params = @{@"external_unread_count": @13};
NURL *baseURL = [NSURL URLWithString: @"https://api.layer.com/apps/XXXXX-XXXX-XXXX-XXXX-XXXXXXXX/users/XXXXXXX""];
AFHTTPSessionManager *manager = [[AFHTTPSessionManager alloc] initWithBaseURL:[NSURL URLWithString:baseUrl] sessionConfiguration:[NSURLSessionConfiguration defaultSessionConfiguration]];
manager.requestSerializer = [AFJSONRequestSerializer serializer];
manager.responseSerializer = [AFJSONResponseSerializer serializer];
[manager.requestSerializer setValue:@"application/vnd.layer+json; version=1.1" forHTTPHeaderField:@"Accept"];
[manager.requestSerializer setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[manager.requestSerializer setValue:@"Bearer XXXXXXXXXXX" forHTTPHeaderField:@"Authorization"];
[manager PUT:@"/badge"
         parameters:params
         success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
                      NSLog(@"put successful!");
                }
         failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
                      NSLog(@"put error: %@", error);
}];

Но я постоянно получаю эту ошибку:

Domain=com.alamofire.error.serialization.response Code=-1011 "Request failed: unacceptable (406)" UserInfo={com.alamofire.serialization.response.error.response=<NSHTTPURLResponse: 0x125883100> { URL: https://api.layer.com/badge } { status code: 406, headers {
    Connection = "keep-alive";
    "Content-Length" = 227;
    "Content-Type" = "application/json";
    Date = "Tue, 12 Apr 2016 20:17:49 GMT";
    Server = "nginx/1.8.0";
} }, NSErrorFailingURLKey=https://api.layer.com/badge, com.alamofire.serialization.response.error.data=<7b22636f 6465223a 3130372c 22696422 3a22696e 76616c69 645f6865 61646572 222c226d 65737361 6765223a 22496e76 616c6964 20616363 65707420 68656164 65723b20 6d757374 20626520 6f662074 68652066 6f726d20 27617070 6c696361 74696f6e 2f766e64 2e6c6179 65722b6a 736f6e3b 20766572 73696f6e 3d782e79 272e222c 2275726c 223a2268 74747073 3a2f2f64 6576656c 6f706572 2e6c6179 65722e63 6f6d2f64 6f63732f 636c6965 6e742f72 65737423 696e7661 6c69645f 68656164 6572222c 22646174 61223a7b 22686561 64657222 3a226163 63657074 227d7d>, NSLocalizedDescription=Request failed: unacceptable (406)}

После прочтения в Интернете все говорило, что я не обрабатывал правильные типы ответов, поэтому я добавил это в:

[manager.responseSerializer setAcceptableContentTypes:[NSSet setWithObjects:@"application/json", @"text/plain", @"text/html", nil]];

Но все равно не получилось с той же ошибкой. Любая помощь будет принята с благодарностью, спасибо!


person mattyb    schedule 12.04.2016    source источник


Ответы (1)


Удаление "/" из маршрута исправило это. Так:

[manager PUT:@"badge"
         parameters:params
         success:^(NSURLSessionDataTask * _Nonnull task, id  _Nullable responseObject) {
                      NSLog(@"put successful!");
                }
         failure:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
                      NSLog(@"put error: %@", error);
}];

работает!

В будущем я должен был посмотреть журнал ошибок поближе, он дал подсказку о моем неправильном URL-адресе со строкой: NSErrorFailingURLKey=https://api.layer.com/badge

В этой строке говорится, что это неверный URL-адрес, а напечатанный URL-адрес не является полным URL-адресом, поэтому я должен был знать, что я испортил формат URL-адреса.

person mattyb    schedule 12.04.2016