invalid_token при попытке доступа к Facebook через ACAccount и SLRequest

Я пытаюсь прочитать сообщения из входящих сообщений пользователя в Facebook, но у меня появляется ошибка, которая запрещает мне доступ. Это мой код:

ACAccountStore *accountStore = [[ACAccountStore alloc] init];
    ACAccountType *fbAccountType = [accountStore accountTypeWithAccountTypeIdentifier:ACAccountTypeIdentifierFacebook];
    NSDictionary *options = @{
                              ACFacebookAppIdKey : FacebookAppKey,
                              ACFacebookPermissionsKey : FacebookPermissionsArray
                              };
    [accountStore requestAccessToAccountsWithType:fbAccountType options:options completion:^(BOOL granted, NSError *error)
     {
         if (error || !granted) {
             return;
         }
         NSArray *accounts = [accountStore accountsWithAccountType:fbAccountType];

         if (accounts.count == 0) {
             return;
         }

         ACAccount *facebookAccount = [accounts lastObject];

         NSURL *inboxURL = [NSURL URLWithString:@"https://graph.facebook.com/me/inbox"];
         NSMutableDictionary *parameters = [[NSMutableDictionary alloc] init];

         SLRequest *facebookInfoRequest = [SLRequest requestForServiceType:SLServiceTypeFacebook
                                                             requestMethod:SLRequestMethodGET
                                                                       URL:inboxURL
                                                                parameters:parameters];
         [facebookInfoRequest setAccount:facebookAccount];
         [facebookInfoRequest performRequestWithHandler:^(NSData *responseData, NSHTTPURLResponse *urlResponse, NSError *error) {

             NSLog(@"response data: %i, url response: %@, error: %@", responseData.length, urlResponse, error);
         }];
     }];

Ответ URL на это читает:

<NSHTTPURLResponse: 0xcb5fa10> { URL: https://graph.facebook.com/me/inbox?access_token=XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX } { status code: 400, headers {
    "Access-Control-Allow-Origin" = "*";
    "Cache-Control" = "no-store";
    Connection = "keep-alive";
    "Content-Length" = 194;
    "Content-Type" = "application/json; charset=UTF-8";
    Date = "Tue, 18 Feb 2014 15:29:36 GMT";
    Expires = "Sat, 01 Jan 2000 00:00:00 GMT";
    Pragma = "no-cache";
    "Www-Authenticate" = "OAuth \"Facebook Platform\" \"invalid_token\" \"Error validating access token: Session has expired on Feb 13, 2014 6:17am. The current time is Feb 18, 2014 7:29am.\"";
    "X-FB-Debug" = "XXXXXXXXXXXXXXXX/Y+K0w=";
    "X-FB-Rev" = XXXXXXXX;
} }

Я не уверен, почему эта проблема произошла. Что я могу здесь делать не так?

1 ответ

Решение

Аккаунт Facebook на устройстве не синхронизирован с сервером и кешем SDK. Для принудительного обновления просто позвоните ACAccountStore's метод renewCredentialsForAccount,

- (void)refreshFacebookTokenStatus
{
    ACAccountStore *accountStore;
    ACAccountType *accountTypeFB;

    if ((accountStore = [[ACAccountStore alloc] init]) &&
        (accountTypeFB = [accountStore accountTypeWithAccountTypeIdentifier:ACAccountTypeIdentifierFacebook]))
    {
        NSArray *fbAccounts = [accountStore accountsWithAccountType:accountTypeFB];

        id account;

        if (fbAccounts && [fbAccounts count] > 0 && (account = [fbAccounts objectAtIndex:0]))
        {
            [accountStore renewCredentialsForAccount:account 
                                          completion:^(ACAccountCredentialRenewResult renewResult, NSError *error)
            {
                if (error)
                {
                    NSLog(@"%@", error.localizedDescription);
                }
            }];
        }
    }
}

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

Также убедитесь, что в настройках приложения Facebook нет Sandbox опция, если вы пытаетесь войти с пользователем Facebook, не являющимся разработчиком приложения.

Другие вопросы по тегам