在实施facebook SSO时,调用facebook ios sdk的注销功能并不是清除用户凭据,也不会要求下次登录。
答案 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是否可以使访问令牌服务器端无效。