2012-07-02 20 views
18

EDIT 07/14AFNetworking - Jak uczynić żądanie POST

Jako Thomas Burgess wymieniono w komentarzu jego odpowiedź na to pytanie jest związane z version 1.3 z AFNetworking. To może być nieaktualne dla nowo przybyłych tutaj.


Jestem zupełnie nowy w rozwoju iPhone i używam AFNetworking jako mojej biblioteki usług.

Wywoływany przeze mnie interfejs API jest RESTULT i muszę wysyłać żądania POST. Aby to zrobić, próbowałem z następującego kodu:

NSDictionary *parameters = [NSDictionary dictionaryWithObjectsAndKeys:@"my_username", @"username", @"my_password", @"password", nil]; 
NSURL *url = [NSURL URLWithString:@"http://localhost:8080/login"]; 

NSURLRequest *request = [NSURLRequest requestWithURL:url]; 
AFJSONRequestOperation *operation = [AFJSONRequestOperation JSONRequestOperationWithRequest:request success:^(NSURLRequest *request, NSHTTPURLResponse *response, id JSON) { 
    NSLog(@"Pass Response = %@", JSON); 
} failure:^(NSURLRequest *request, NSHTTPURLResponse *response, NSError *error, id JSON) { 
    NSLog(@"Failed Response : %@", JSON); 
}]; 
[operation start]; 

Istnieją dwa główne problemy z tym kodem:

  • AFJSONRequestOperation wydaje dokonać GET żądanie, a nie POST jeden.
  • Nie mogę umieścić parametrów tej metody.

Próbowałem też z tym kodem:

NSDictionary *parameters = [NSDictionary dictionaryWithObjectsAndKeys:@"my_username", @"username", @"my_password", @"password", nil]; 
NSURL *url = [NSURL URLWithString:@"http://localhost:8080"]; 
AFHTTPClient *httpClient = [[AFHTTPClient alloc] initWithBaseURL:url]; 

[httpClient postPath:@"/login" parameters:parameters success:^(AFHTTPRequestOperation *operation, id responseObject) { 
    NSLog(@"Succes : %@", responseObject); 
} failure:^(AFHTTPRequestOperation *operation, NSError *error) { 
    NSLog(@"Failure : %@", error); 
}]; 

Czy istnieje lepszy sposób, aby to, co chcę, żeby zrobić to?

Dzięki za pomoc!

Odpowiedz

24

Można zastąpić domyślne zachowanie żądania używane z AFNetworking do przetwarzania jako POST.

NSURLRequest *request = [client requestWithMethod:@"POST" path:path parameters:nil]; 

Zakłada się, że nadpisałeś domyślną konfigurację AFNetworking, aby użyć klienta niestandardowego. Jeśli nie, proponuję to zrobić. Po prostu utwórz klasę niestandardową, aby obsłużyć klienta sieciowego.

MyAPIClient.h

#import <Foundation/Foundation.h> 
#import "AFHTTPClient.h" 

@interface MyAPIClient : AFHTTPClient 

+(MyAPIClient *)sharedClient; 

@end 

MyAPIClient.m

@implementation MyAPIClient 

+(MyAPIClient *)sharedClient { 
    static MyAPIClient *_sharedClient = nil; 
    static dispatch_once_t oncePredicate; 
    dispatch_once(&oncePredicate, ^{ 
     _sharedClient = [[self alloc] initWithBaseURL:[NSURL URLWithString:webAddress]]; 
    }); 
    return _sharedClient; 
} 

-(id)initWithBaseURL:(NSURL *)url { 
    self = [super initWithBaseURL:url]; 
    if (!self) { 
     return nil; 
    } 
    [self registerHTTPOperationClass:[AFJSONRequestOperation class]]; 
    [self setDefaultHeader:@"Accept" value:@"application/json"]; 
    self.parameterEncoding = AFJSONParameterEncoding; 

    return self; 

} 

Następnie powinieneś być w stanie wystrzelić połączeń sieciowych w kolejce pracy bez problemu.

MyAPIClient *client = [MyAPIClient sharedClient]; 
    [[AFNetworkActivityIndicatorManager sharedManager] setEnabled:YES]; 
    [[AFNetworkActivityIndicatorManager sharedManager] incrementActivityCount]; 

    NSString *path = [NSString stringWithFormat:@"myapipath/?value=%@", value]; 
    NSURLRequest *request = [client requestWithMethod:@"POST" path:path parameters:nil]; 

    AFJSONRequestOperation *operation = [AFJSONRequestOperation JSONRequestOperationWithRequest:request success:^(NSURLRequest *request, NSHTTPURLResponse *response, id JSON) { 
     // code for successful return goes here 
     [[AFNetworkActivityIndicatorManager sharedManager] decrementActivityCount]; 

     // do something with return data 
    }failure:^(NSURLRequest *request, NSHTTPURLResponse *response, NSError *error, id JSON) { 
     // code for failed request goes here 
     [[AFNetworkActivityIndicatorManager sharedManager] decrementActivityCount]; 

     // do something on failure 
    }]; 

    [operation start]; 
+0

Dziękujemy za odpowiedź! Tylko jedno pytanie: twój "SIOAPIClient" będzie "MyAPIClient" tutaj nie? –

+0

Masz rację ... Kopiuję/wklejałem to z mojej własnej implementacji i zmieniłem nazwy klas. Zgubiłem miejsce, jak sądzę. Edytowałem swoją odpowiedź na pytanie, jak powinno być. –

+0

Próbowałem zaimplementować klienta niestandardowego dokładnie tak, jak piszesz, ale pojawia się błąd: 'Brak znanej metody klasy dla selektora 'sharedClient''. Nagłówek jest dołączony poprawnie, więc zastanawiam się, dlaczego otrzymuję ten błąd. –