调用facebook ios sdk的注销功能不会清除用户凭据

时间:2011-05-20 06:24:34

标签: iphone objective-c facebook logout

在实施facebook SSO时,调用facebook ios sdk的注销功能并不是清除用户凭据,也不会要求下次登录。

2 个答案:

答案 0 :(得分:9)

我使用了图Api .....

- (IBAction)loginButtonPressed:(id)sender {

    NSString *client_id = @"dsfgdgfgfgdfgvdfg";

    //alloc and initalize our FbGraph instance
    self.fbGraph = [[FbGraph alloc] initWithFbClientID:client_id];

    //begin the authentication process.....
    [fbGraph authenticateUserWithCallbackObject:self andSelector:@selector(fbGraphCallback:) 
                         andExtendedPermissions:@"user_photos,user_videos,publish_stream,offline_access,user_checkins,friends_checkins"];
}


- (void)logOutButtonPressed {

    NSLog(@"logout");

    fbGraph.accessToken = nil;
    NSHTTPCookie *cookie;
    NSHTTPCookieStorage *storage = [NSHTTPCookieStorage sharedHTTPCookieStorage];
    for (cookie in [storage cookies])
    {
        NSString* domainName = [cookie domain];
        NSRange domainRange = [domainName rangeOfString:@"facebook"];
        if(domainRange.length > 0)
        {
            [storage deleteCookie:cookie];
        }
    }

    [self loginButtonPressed:nil];
}

这段代码工作很精细......

答案 1 :(得分:0)

我经历过同样的事情,但我认为这不是一个错误,但令人困惑。

Facebook在移动版Safari中放置了一个cookie,它指的是有效会话或访问令牌。如果您使用Facebook lib注销,它将清除访问令牌,并且所有未在移动版Safari中使用的webview的cookie。实际上你不能通过代码来做到这一点。现在,如果您回来并打开移动版Safari,仍然会有一个有效的会话,您无需输入凭据即可再次登录。

您可以提交一个错误,询问Facebook是否可以使访问令牌服务器端无效。