Как проверить валидацию квитанции в этом случае?

Я работаю над преобразованием приложения из платного в бесплатное с некоторыми из прежних функций в рамках IAP. В результате существующим пользователям необходимо иметь копию IAP. Для этого я использую код проверки получения из Веб-сайт Apple. Моя цель в этом случае состоит не в том, чтобы на самом деле проверить подлинность квитанции, а вместо этого вернуть номер версии, которую пользователь купил, чтобы я мог определить, является ли он платным пользователем (спасибо этот вопрос для предложения).

NSURL *receiptURL = [[NSBundle mainBundle] appStoreReceiptURL];
NSData *receipt = [NSData dataWithContentsOfURL:receiptURL];
if (!receipt) { NSLog(@"No receipt found"); return; }

Это код, который я использую для получения квитанции пользователя. Он почти идентичен коду на указанном выше официальном сайте Apple. Тем не менее, я все еще хочу протестировать его и следующий за ним код, который предоставляет пользователю IAP.

Однако приведенный выше код будет регистрировать «Квитанция не найдена» и возвращаться, если я запускаю программу в симуляторе, на моем iPhone через Xcode или на моем iPhone через TestFlight. Я установил текущую версию App Store, затем попробовал TestFlight, и он по-прежнему выдавал ту же ошибку о неполучении.

Как мне получить копию квитанции для проверки, и, кроме того, как мне протестировать эту форму проверки квитанции?


person Nick Moody    schedule 15.11.2016    source источник
comment
Насколько я знаю, сборка для разработчиков не будет иметь квитанции, пока вы не завершите IAP в песочнице.   -  person Paulw11    schedule 15.11.2016


Ответы (1)


SKReceiptRefreshRequest предоставит поддельную квитанцию, которую вы проверяете на сервере проверки песочницы Apple. Вызов SKReceiptRefreshRequest был тем элементом, которого мне не хватало.

SKReceiptRefreshRequest *receiptRequest = [[SKReceiptRefreshRequest alloc] initWithReceiptProperties:nil];
receiptRequest.delegate = self;
[receiptRequest start];

-

- (void)requestDidFinish:(SKRequest *)request {
NSURL *receiptURL = [[NSBundle mainBundle] appStoreReceiptURL];
NSData *receipt = [NSData dataWithContentsOfURL:receiptURL];
if (!receipt) { NSLog(@"No receipt found"); return; }
// Create the JSON object that describes the request
NSError *error;
NSDictionary *requestContents = @{
                                  @"receipt-data": [receipt base64EncodedStringWithOptions:0]
                                  };
NSData *requestData = [NSJSONSerialization dataWithJSONObject:requestContents
                                                      options:0
                                                        error:&error];

if (!requestData) { NSLog(@"No request data found"); return; }

// Create a POST request with the receipt data.
NSURL *storeURL = [NSURL URLWithString:@"https://sandbox.itunes.apple.com/verifyReceipt"];
NSMutableURLRequest *storeRequest = [NSMutableURLRequest requestWithURL:storeURL];
[storeRequest setHTTPMethod:@"POST"];
[storeRequest setHTTPBody:requestData];
// Make a connection to the iTunes Store on a background queue.
NSOperationQueue *queue = [[NSOperationQueue alloc] init];
[NSURLConnection sendAsynchronousRequest:storeRequest queue:queue
                       completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
                           if (connectionError) {
                               NSLog(@"Connection error");
                               return;
                           } else {
                               NSError *error;
                               NSDictionary *jsonResponse = [NSJSONSerialization JSONObjectWithData:data options:0 error:&error];
                               if (!jsonResponse) { return; }
                               NSLog(@"JsonResponce: %@",jsonResponse);
                               NSString *version = jsonResponse[@"receipt"][@"original_application_version"];
                               //found version number! Do whatever with it!
                           }
                       }];
person Nick Moody    schedule 16.11.2016