W.S*_*W.S 3 session facebook ios ios5 facebook-ios-sdk
我正在使用facebook sdk 3.0.8 for ios.当我尝试使用Facebook登录时,它工作正常,但有时当我在登出后尝试登录时,应用程序正在崩溃.
这是异常消息
*** Assertion failure in -[FBSession close], /Users/jacl/src/ship/ios-sdk/src/FBSession.m:342
Run Code Online (Sandbox Code Playgroud)
你能告诉我哪里出错了吗?
这是AppDelegate中的代码
- (BOOL)application:(UIApplication *)application
openURL:(NSURL *)url
sourceApplication:(NSString *)sourceApplication
annotation:(id)annotation {
// attempt to extract a token from the url
return [FBSession.activeSession handleOpenURL:url];
}
- (void)applicationWillTerminate:(UIApplication *)application {
[self.session close];
}
#pragma mark Template generated code
// FBSample logic
// It is possible for the user to switch back to your application, from the native Facebook application,
// when the user is part-way through a login; You can check for the FBSessionStateCreatedOpenening
// state in applicationDidBecomeActive, to identify this situation and close the session; a more sophisticated
// application may choose to notify the user that they switched away from the Facebook application without
// completely logging in
- (void)applicationDidBecomeActive:(UIApplication *)application {
/*
Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
*/
// FBSample logic
// this means the user switched back to this app without completing a login in Safari/Facebook App
if (self.session.state == FBSessionStateCreatedOpening) {
// BUG: for the iOS 6 preview we comment this line out to compensate for a race-condition in our
// state transition handling for integrated Facebook Login; production code should close a
// session in the opening state on transition back to the application; this line will again be
// active in the next production rev
//[self.session close]; // so we close our session and start over
}
}
Run Code Online (Sandbox Code Playgroud)
代码内部视图控制器
-(IBAction)connectWithFacebook{
DemoAppDelegate *appDelegate = (TotallyCuteAppDelegate *) [[UIApplication sharedApplication]delegate];
if (!appDelegate.session.isOpen && (appDelegate.session.state != FBSessionStateCreated))
{
appDelegate.session = [[FBSession alloc] init];
}
NSArray *permissions = [[NSArray alloc] initWithObjects:
@"publish_actions",
@"email",
nil];
//app crashes here
[FBSession openActiveSessionWithPermissions:permissions allowLoginUI:YES
completionHandler:^(FBSession *session, FBSessionState status, NSError *error) {
if (session.isOpen)
{
NSLog(@"LoginVC->Session is open");
appDelegate.session=session;
[userDefaults setObject:appDelegate.session.accessToken forKey:@"facebook_token"];
[userDefaults setObject:paramFBId forKey:@"facebook_id"];
}
else
{
NSLog(@"LoginVC->Session is not open");
}
}//end completionHandler
];
}
-(IBAction)logout:(id)sender{
DemoAppDelegate *appDelegate = (TotallyCuteAppDelegate *) [[UIApplication sharedApplication]delegate];
if (appDelegate.session.isOpen) {
[appDelegate.session closeAndClearTokenInformation];
[[NSUserDefaults userDefaults] removeObjectForKey:@"facebook_id"];
[[NSUserDefaults userDefaults] removeObjectForKey:@"facebook_token"];
}
}
Run Code Online (Sandbox Code Playgroud)
编辑:
删除了以下代码,现在它工作正常
if (!appDelegate.session.isOpen && (appDelegate.session.state != FBSessionStateCreated))
{
appDelegate.session = [[FBSession alloc] init];
}
Run Code Online (Sandbox Code Playgroud)
这是更新的代码
-(IBAction)connectWithFacebook{
if ([InternetChecker isConnected])
{
DemoAppDelegate *appDelegate = (TotallyCuteAppDelegate *) [[UIApplication sharedApplication]delegate];
/* Removed following if block
if (!appDelegate.session.isOpen && (appDelegate.session.state != FBSessionStateCreated))
{
appDelegate.session = [[FBSession alloc] init];
}
*/
NSArray *permissions = [[NSArray alloc] initWithObjects:
@"publish_actions",
@"email",
nil];
[FBSession openActiveSessionWithPermissions:permissions allowLoginUI:YES
completionHandler:^(FBSession *session, FBSessionState status, NSError *error) {
if (session.isOpen)
{
NSLog(@"LoginVC->Session is open");
appDelegate.session=session;
[userDefaults setObject:appDelegate.session.accessToken forKey:@"facebook_token"];
[userDefaults setObject:paramFBId forKey:@"facebook_id"];
}
else
{
NSLog(@"LoginVC->Session is not open);
}
}//end completionHandler
];
}
}
Run Code Online (Sandbox Code Playgroud)
查看FBSession.m,断言close
如下:
NSAssert(self.affinitizedThread == [NSThread currentThread], @"FBSession: should only be used from a single thread");
Run Code Online (Sandbox Code Playgroud)
你是-close
从一个你创建会话的线程以外的线程调用的吗?
进一步研究这个问题.你误用了API.你正在创造
appDelegate.session = [[FBSession alloc] init];
Run Code Online (Sandbox Code Playgroud)
但是你正在打电话
[FBSession openActiveSessionWithPermissions ...
Run Code Online (Sandbox Code Playgroud)
这会创建一个全新的会话.意思是你永远不会打开appDelegate.session
,因此你不应该试图关闭它.您应该做的是以下内容:
[FBSession openActiveSessionWithPermissions ...
appDelegate.session = [FBSession activeSession];
Run Code Online (Sandbox Code Playgroud)
另一种选择是:
appDelegate.session = [[FBSession alloc] init];
[appDelegate.session openWithCompletionHandler: ...
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
3682 次 |
最近记录: |