iOS - Facebook Connect 注销不删除登录详细信息?
Posted
技术标签:
【中文标题】iOS - Facebook Connect 注销不删除登录详细信息?【英文标题】:iOS - Facebook Connect logout not deleting login details? 【发布时间】:2012-05-18 08:46:45 【问题描述】:我在另一个问题相对较少的项目中使用了 Facebook Connect,但是在我当前的项目中,当我调用 [facebook logout];
时,它似乎并没有删除用户的详细信息。如果我然后重新启动应用程序,我在 didFinishLaunchingWithOptions 函数中有以下内容:
facebook = [[Facebook alloc] initWithAppId:@"XXXXXXXXXXXXX" andDelegate:self];
NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
if([defaults objectForKey:@"FBAccessTokenKey"]
&& [defaults objectForKey:@"FBExpirationDateKey"])
facebook.accessToken = [defaults objectForKey:@"FBAccessTokenKey"];
facebook.expirationDate = [defaults objectForKey:@"FBExpirationDateKey"];
NSLog(@"startup login");
[self loginToFacebook];//attempt to login automatically on startup
我的 loginToFacebook 函数是这样的:
- (void)loginToFacebook
NSLog(@"Logging into facebook");
//set up facebook and login in automatically if possible
NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
if([defaults objectForKey:@"FBAccessTokenKey"]
&& [defaults objectForKey:@"FBExpirationDateKey"])
facebook.accessToken = [defaults objectForKey:@"FBAccessTokenKey"];
facebook.expirationDate = [defaults objectForKey:@"FBExpirationDateKey"];
if (![facebook isSessionValid])
//get permissions that user will need to agree to us using
NSArray *permissions = [[NSArray alloc] initWithObjects:
@"user_likes",@"read_friendlists",@"offline_access", @"publish_stream",
nil];
//authorise our login
[facebook authorize:permissions];
[permissions release];
else
[facebook authorize:nil];
就我而言,这次应该提示我使用我的电子邮件和密码登录。 我主要使用模拟器,所以 Facebook 应用程序本身不是原因,在 Facebook.h 类中我已经改变了
[self authorizeWithFBAppAuth:NO safariAuth:YES];
到
[self authorizeWithFBAppAuth:NO safariAuth:NO];
然而,Facebook 窗口会短暂闪烁并消失,正如我在我已经登录时所期望的那样。然后它会从我之前的登录详细信息中加载我的 ID、姓名、朋友列表等。我再也不可能更改用户了!我应该补充一点,我有以下代码在“注销”上相应地打印:
- (void)fbDidLogout
NSLog(@"Logged out of facebook");
...当调用 [facebook logout] 时打印到控制台。我也有正确的 url 方案,所以那里没有问题。
正如我所说,我已经在另一个应用程序上进行了这项工作,但我看不出这次我可以忽略什么。 我欢迎任何建议,因为我怀疑这是非常简单的事情。
编辑:我刚刚在设备上对其进行了测试,尝试登录 Facebook 会导致应用程序崩溃。我怀疑这是因为它试图使用“存储的”信息登录,因为我还没有登录设备,所以该信息不存在。我仍在调查,但如果有人能发现明显的缺陷,我将不胜感激。
Edit2:我尝试使用保险箱的示例删除 cookie。我还在 a) didFinishLaunchingWithOptions 和 b) fbDidLogout 期间打印出所有 cookie,我得到以下信息:
一) `2012-05-18 10:40:40.665 我的应用程序 [15545:17003] ( "",
"<NSHTTPCookie version:0 name:\"c_user\" value:\"634361620\" expiresDate:2012-06-17 09:34:33 +0000 created:2012-05-18 09:34:34 +0000 (3.59026e+08) sessionOnly:FALSE domain:\".facebook.com\" path:\"/\" isSecure:TRUE>",
"<NSHTTPCookie version:0 name:\"csm\" value:\"2\" expiresDate:2012-06-17 09:34:33 +0000 created:2012-05-18 09:34:34 +0000 (3.59026e+08) sessionOnly:FALSE domain:\".facebook.com\" path:\"/\" isSecure:FALSE>",
"<NSHTTPCookie version:0 name:\"datr\" value:\"gxe2T8ZyBzMGb5w3LS29Q0kJ\" expiresDate:2014-05-18 09:34:33 +0000 created:2012-05-18 09:34:34 +0000 (3.59026e+08) sessionOnly:FALSE domain:\".facebook.com\" path:\"/\" isSecure:FALSE>",
"<NSHTTPCookie version:0 name:\"locale\" value:\"en_US\" expiresDate:2012-05-25 09:36:43 +0000 created:2012-05-18 09:36:44 +0000 (3.59027e+08) sessionOnly:FALSE domain:\".facebook.com\" path:\"/\" isSecure:FALSE>",
"<NSHTTPCookie version:0 name:\"lu\" value:\"RgayA7CMIlsAl-lOD2-Y-O3g\" expiresDate:2014-05-18 09:34:33 +0000 created:2012-05-18 09:34:34 +0000 (3.59026e+08) sessionOnly:FALSE domain:\".facebook.com\" path:\"/\" isSecure:FALSE>",
"<NSHTTPCookie version:0 name:\"m_user\" value:\"0%3A0%3A0%3A0%3Av_1%2Cajax_1%2Cwidth_320%2Cpxr_1%2Cgps_1%3A1337333673%3A2\" expiresDate:2012-08-16 09:34:33 +0000 created:2012-05-18 09:34:34 +0000 (3.59026e+08) sessionOnly:FALSE domain:\".facebook.com\" path:\"/\" isSecure:FALSE>",
"<NSHTTPCookie version:0 name:\"s\" value:\"Aa4WdKU-oOFathmK\" expiresDate:2012-06-17 09:34:33 +0000 created:2012-05-18 09:34:34 +0000 (3.59026e+08) sessionOnly:FALSE domain:\".facebook.com\" path:\"/\" isSecure:TRUE>",
"<NSHTTPCookie version:0 name:\"xs\" value:\"125%3AFFIWXjAXDXUMmw%3A2%3A1337333673\" expiresDate:2012-06-17 09:34:33 +0000 created:2012-05-18 09:34:34 +0000 (3.59026e+08) sessionOnly:FALSE domain:\".facebook.com\" path:\"/\" isSecure:TRUE>"
)`
b)
2012-05-18 10:41:16.530 MyApp[15545:17003] (
)
由于它变为空,我认为它们已被删除。但是在重新打开应用程序时,它们又都在那里了。
Edit3:我发现解决此问题的唯一方法是在应用程序打开后立即删除所有 cookie,但这意味着用户每次都必须登录,即使他们在上次使用应用程序时保持登录状态打开。目前这是一个临时修复,我仍然不确定为什么它不能正常工作。
【问题讨论】:
【参考方案1】:当用户单击注销并删除存储在 facebook 的 userdefault 中的所有密钥时,您提供此方法
- (void)fbDidLogout
NSLog(@"Logged out of facebook");
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];
【讨论】:
恐怕完全没有区别。 facebook 类已经在其 invalidateSession 函数中包含了 cookie 删除,该函数在 [facebook logout] 中调用。我仍然尝试将您的代码显式添加到我的 fbDidLogout 函数中,但问题仍然存在。 将其添加到我的代码开头,因此每次启动时它都会擦除登录详细信息。不理想,但现在可以使用。【参考方案2】:注意:除了 FB 应用程序将登录信息存储在 NSUserDefaults
中,它还将登录信息存储在 NSHTTPCookieStorage
使用名称 m_user
。您可以删除这条记录,让 FB 再次询问您的登录信息。
希望这些信息对您有所帮助。
【讨论】:
好的,所以我尝试使用NSLog(@"%@", [[NSHTTPCookieStorage sharedHTTPCookieStorage] cookies]);
来检查那里有哪些 cookie,并且足够 m_user 显示为其中之一。我不明白的是 facebook 类应该删除这些,并且根据 safecase 的建议,我尝试在注销时手动将它们全部显式删除。出于某种原因,它运行了一次,但每隔一次我注销并重新启动它都会保留 cookie。
我记得我在这个 API 中修复了一些源代码。请检查注销方法是否真的向服务器发送注销消息。
需要吗?它这样做的事实:self.accessToken = nil; self.expirationDate = nil; NSHTTPCookieStorage* cookies = [NSHTTPCookieStorage sharedHTTPCookieStorage]; NSArray* facebookCookies = [cookies cookiesForURL: [NSURL URLWithString:@"http://login.facebook.com"]]; for (NSHTTPCookie* cookie in facebookCookies) [cookies deleteCookie:cookie];
是否不足以防止此问题。【参考方案3】:
[appDelegate.session closeAndClearTokenInformation];
就这一行代码,帮助我清除了我的令牌。
【讨论】:
【参考方案4】: [[NSUserDefaults standardUserDefaults] removeObjectForKey:@"FBAccessTokenKey"];
[[NSUserDefaults standardUserDefaults] removeObjectForKey:@"FBExpirationDateKey"];
【讨论】:
以上是关于iOS - Facebook Connect 注销不删除登录详细信息?的主要内容,如果未能解决你的问题,请参考以下文章