Как отправить запрос POST и GET?

Я хочу отправить свой JSON на URL-адрес (POST и GET).

NSMutableDictionary *JSONDict = [[NSMutableDictionary alloc] init];
[JSONDict setValue:"myValue" forKey:"myKey"];

NSData *JSONData = [NSJSONSerialization dataWithJSONObject:self options:kNilOptions error:nil];

Мой текущий код запроса не работает.

NSMutableURLRequest *requestData = [[NSMutableURLRequest alloc] init];

[requestData setURL:[NSURL URLWithString:@"http://fake.url/"];];

[requestData setHTTPMethod:@"POST"];
[requestData setValue:postLength forHTTPHeaderField:@"Content-Length"];
[requestData setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[requestData setValue:@"application/json" forHTTPHeaderField:@"Accept"];
[requestData setHTTPBody:postData];

Использование ASIHTTPRequest не является ответственным ответом.


person Aleksander Azizi    schedule 06.10.2011    source источник


Ответы (3)


Отправка запросов POST и GET в iOS довольно проста; и нет необходимости в дополнительной структуре.


POST Запрос:

Мы начинаем с создания body нашего POST (то есть того, что мы хотим отправить) как NSString и конвертируем его в NSData.

objective-c

NSString *post = [NSString stringWithFormat:@"test=Message&this=isNotReal"];
NSData *postData = [post dataUsingEncoding:NSASCIIStringEncoding allowLossyConversion:YES];

Затем мы читаем length postData, чтобы мы могли передать его в запросе.

NSString *postLength = [NSString stringWithFormat:@"%d", [postData length]];

Теперь, когда у нас есть то, что мы хотели бы опубликовать, мы можем создать NSMutableURLRequest и включить наш postData.

NSMutableURLRequest *request = [[NSMutableURLRequest alloc] init];
[request setURL:[NSURL URLWithString:@"http://YourURL.com/FakeURL"]];
[request setHTTPMethod:@"POST"];
[request setValue:postLength forHTTPHeaderField:@"Content-Length"];
[request setHTTPBody:postData];

swift

let post = "test=Message&this=isNotReal"
let postData = post.data(using: String.Encoding.ascii, allowLossyConversion: true)

let postLength = String(postData!.count)

var request = URLRequest(url: URL(string: "http://YourURL.com/FakeURL/PARAMETERS")!)
request.httpMethod = "POST"
request.addValue(postLength, forHTTPHeaderField: "Content-Length")
request.httpBody = postData;

И, наконец, мы можем отправить наш запрос и прочитать ответ, создав новый NSURLSession:

objective-c

NSURLSession *session = [NSURLSession sessionWithConfiguration:[NSURLSessionConfiguration defaultSessionConfiguration]];
[[session dataTaskWithRequest:request completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
    NSString *requestReply = [[NSString alloc] initWithData:data encoding:NSASCIIStringEncoding];
    NSLog(@"Request reply: %@", requestReply);
}] resume];

swift

let session = URLSession(configuration: .default)
session.dataTask(with: request) {data, response, error in
    let requestReply = NSString(data: data!, encoding: String.Encoding.ascii.rawValue)
    print("Request reply: \(requestReply!)")
}.resume()

GET Запрос:

С запросом GET в основном то же самое, только без HTTPBody и Content-Length.

objective-c

NSMutableURLRequest *request = [[NSMutableURLRequest alloc] init];
[request setURL:[NSURL URLWithString:@"http://YourURL.com/FakeURL/PARAMETERS"]];
[request setHTTPMethod:@"GET"];

NSURLSession *session = [NSURLSession sessionWithConfiguration:[NSURLSessionConfiguration defaultSessionConfiguration]];
[[session dataTaskWithRequest:request completionHandler:^(NSData *data, NSURLResponse *response, NSError *error) {
    NSString *requestReply = [[NSString alloc] initWithData:data encoding:NSASCIIStringEncoding];
    NSLog(@"Request reply: %@", requestReply);
}] resume];

swift

var request = URLRequest(url: URL(string: "http://YourURL.com/FakeURL/PARAMETERS")!)
request.httpMethod = "GET"

let session = URLSession(configuration: .default)
session.dataTask(with: request) {data, response, error in
    let requestReply = NSString(data: data!, encoding: String.Encoding.ascii.rawValue)
    print("Request reply: \(requestReply!)")
}.resume()

Кстати, вы можете добавить Content-Type (и другие данные), добавив следующее к нашему NSMutableURLRequest. Это может потребоваться серверу при запросе, например,

objective-c

[request setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[request setValue:@"application/json" forHTTPHeaderField:@"Accept"];

Код ответа также можно прочитать с помощью [(NSHTTPURLResponse*)response statusCode].

swift

request.addValue("application/json", forHTTPHeaderField: "Content-Type")
request.addValue("application/json", forHTTPHeaderField: "Accept")

Обновление: sendSynchronousRequest устарело из ios9 и osx-elcapitan (10.11) и выше. <с>

NSURLResponse *requestResponse; NSData *requestHandler = [NSURLConnection sendSynchronousRequest:request returningResponse:&requestResponse error:nil]; NSString *requestReply = [[NSString alloc] initWithBytes:[requestHandler bytes] length:[requestHandler length] encoding:NSASCIIStringEncoding]; NSLog(@"requestReply: %@", requestReply);

person Aleksander Azizi    schedule 17.07.2012
comment
Очень хорошо объяснил. Благодарю вас. :) - person Baby Groot; 26.03.2013
comment
Чистый. +1. @Александр Азизи - person Chisx; 25.01.2014
comment
В моем случае я должен использовать GET, а также отправлять данные json. Могу ли я добавить HTTPBody? - person Satyam; 26.03.2014
comment
Я получаю запросReply to Null. Что будет проблемой? - person niravpatel; 04.12.2014
comment
Скорее всего, это неверный запрос или сбой данных на стороне сервера. - person Aleksander Azizi; 04.12.2014
comment
Привет, как мы можем отправить входные параметры, используя приведенный выше код? пожалуйста, дайте мне знать. - person Narasimha Nallamsetty; 14.04.2015
comment
Привет, @AleksanderAzizi, отличный ответ, но мне интересно, как бы вы вставили данные в определенное поле в объекте JSON? например, я хочу, чтобы у меня был объект с именем Player и поле с именем Name, и я хочу обновить только имя, как мне это сделать? - person App Dev Guy; 16.04.2015
comment
@Satyam С запросом GET вы включаете данные в заголовок и/или URL-адрес. Запрос GET не включает тело. - person Aleksander Azizi; 28.04.2016
comment
Спасибо. Мне помогло. - person ssowri1; 28.03.2017
comment
Большое вам спасибо, перепробовав столько способов, я завершил свою задачу с вашим решением. :-) - person Daya Kevin; 13.10.2017
comment
Можете ли вы объяснить код использования NSURLConnection вместо URLSession в swift. - person Rashid KC; 27.03.2018
comment
Функции @KayCee NSURLConnection для асинхронной загрузки данных устарели. См. документацию Apple по NSURLConnection. - person Aleksander Azizi; 29.03.2018

Используя RestKit, вы можете сделать простой запрос POST (см. этот GitHub для получения более подробной информации).

Импортируйте RestKit в файл заголовка.

#import <RestKit/RestKit.h>

Затем вы можете начать с создания нового файла RKRequest.

RKRequest *MyRequest = [[RKRequest alloc] initWithURL:[[NSURL alloc] initWithString:@"http://myurl.com/FakeUrl/"]];

Затем укажите, какой запрос вы хотите сделать (в данном случае POST запрос).

MyRequest.method = RKRequestMethodPOST;
MyRequest.HTTPBodyString = YourPostString;

А затем установите свой запрос как JSON в additionalHTTPHeaders.

MyRequest.additionalHTTPHeaders = [[NSDictionary alloc] initWithObjectsAndKeys:@"application/json", @"Content-Type", @"application/json", @"Accept", nil];

Наконец, вы можете отправить запрос.

[MyRequest send];

Кроме того, вы можете NSLog свой запрос увидеть результат.

RKResponse *Response = [MyRequest sendSynchronously];
NSLog(@"%@", Response.bodyAsString);

Источники: RestKit.org и Я.

person Aleksander Azizi    schedule 12.06.2012

просмотр control.h

@interface ViewController     UIViewController<UITableViewDataSource,UITableViewDelegate>

  @property (weak, nonatomic) IBOutlet UITableView *tableView;
  @property (strong,nonatomic)NSArray *array;
  @property NSInteger select;
  @end

вид.м

  - (void)viewDidLoad {
 [super viewDidLoad];
 NSString *urlString = [NSString stringWithFormat:    @"https://maps.googleapis.com/maps/api/place/nearbysearch/json?location=11.021459,76.916332&radius=2000&types=atm&sensor=false&key=AIzaS yD7c1IID7zDCdcfpC69fC7CUqLjz50mcls"];
 NSURL *url = [NSURL URLWithString: urlString];
 NSData *data = [NSData dataWithContentsOfURL:url];
 NSDictionary *jsonData = [NSJSONSerialization JSONObjectWithData:      
 data options: 0 error: nil];
 _array = [[NSMutableArray alloc]init];
 _array = [[jsonData objectForKey:@"results"] mutableCopy];
[_tableView reloadData];}
// Do any additional setup after loading the view, typically from a         



 - (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
  }
 - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {

return 1;
  }

  - (NSInteger)tableView:(UITableView *)tableView
  numberOfRowsInSection:(NSInteger)section {

 return _array.count;
  }

 - (UITableViewCell *)tableView:(UITableView *)tableView
     cellForRowAtIndexPath:(NSIndexPath *)indexPath {

 static NSString *cellid = @"cell";
 UITableViewCell *cell = [tableView
                         dequeueReusableCellWithIdentifier:cellid];
 cell = [[UITableViewCell
         alloc]initWithStyle:UITableViewCellStyleSubtitle
        reuseIdentifier:cellid];

 cell.textLabel.text = [[_array
 valueForKeyPath:@"name"]objectAtIndex:indexPath.row]; 
 cell.detailTextLabel.text = [[_array 
 valueForKeyPath:@"vicinity"]objectAtIndex:indexPath.row];
 NSURL *imgUrl = [NSURL URLWithString:[[_array
 valueForKey:@"icon"]objectAtIndex:indexPath.row]];  
 NSData *imgData = [NSData dataWithContentsOfURL:imgUrl];
 cell.imageView.layer.cornerRadius =        
 cell.imageView.frame.size.width/2;
 cell.imageView.layer.masksToBounds = YES;
 cell.imageView.image = [UIImage imageWithData:imgData];

 return cell;
 }

 @end

tablecell.h

 @interface TableViewCell : UITableViewCell
 @property (weak, nonatomic) IBOutlet UIImageView *imgView;
 @property (weak, nonatomic) IBOutlet UILabel *lblName;
 @property (weak, nonatomic) IBOutlet UILabel *lblAddress;
person sasidharan.M    schedule 08.05.2017
comment
код выше предназначен для метода get - person sasidharan.M; 08.05.2017