我的项目中使用了Facebook iOS SDK 3.8,现在我将其升级到3.22。
在请求"publish_actions"权限时发生了一件奇怪的事情,即用户需要输入她的帐户&再次输入密码。而在以前的版本中,"再次登录"部分将被跳过。我想知道Facebook SDK中的逻辑是否发生了变化,或者我必须更改会话处理过程。对这个问题有什么想法吗?
我过去请求"publish_actions"权限的方式是:
[activeSession openWithBehavior: FBSessionLoginBehaviorForcingWebView
completionHandler:^(FBSession *session,
FBSessionState state, NSError *error) {
[session reauthorizeWithPermissions:@[@"publish_actions"]
isRead:NO
behavior:FBSessionLoginBehaviorForcingWebView
defaultAudience:FBSessionDefaultAudienceFriends
completionHandler:^(FBSession *session, NSError *error) {
}
我也试过
[FBSession.activeSession requestNewPublishPermissions:[NSArray arrayWithObject:@"publish_actions"]
defaultAudience:FBSessionDefaultAudienceFriends
completionHandler:^(FBSession *session, NSError *error) {
__block NSString *alertText;
__block NSString *alertTitle;
_reauthorizeInProgress = YES;
if (!error) {
if ([FBSession.activeSession.permissions
indexOfObject:@"publish_actions"] == NSNotFound){
// Permission not granted, tell the user we will not publish
alertTitle = @"Permission not granted";
alertText = @"Your action will not be published to Facebook.";
[[[UIAlertView alloc] initWithTitle:alertTitle
message:alertText
delegate:self
cancelButtonTitle:@"OK!"
otherButtonTitles:nil] show];
} else {
// Permission granted, publish the OG story
}
} else {
// There was an error, handle it
// See https://developers.facebook.com/docs/ios/errors/
}
}];
此行为是Facebook设置的默认行为。文件https://developers.facebook.com/docs/facebook-login/ios/v2.2上面写着:
WebView的缺点是:
人们每次通过登录流程时都必须填写他们的登录凭据。
在FBSession.m文件中,我更改了方法中的代码
- (void)retryableAuthorizeWithPermissions:(NSArray *)permissions
defaultAudience:(FBSessionDefaultAudience)defaultAudience
integratedAuth:(BOOL)tryIntegratedAuth
FBAppAuth:(BOOL)tryFBAppAuth
safariAuth:(BOOL)trySafariAuth
fallback:(BOOL)tryFallback
isReauthorize:(BOOL)isReauthorize
canFetchAppSettings:(BOOL)canFetchAppSettings
在请求其他权限时不要删除cookie,替换
// To avoid surprises, delete any cookies we currently have.
[FBUtility deleteFacebookCookies];
带有
// To avoid surprises, delete any cookies we currently have.
if(!isReauthorize){
[FBUtility deleteFacebookCookies];
}
我同意修改SDK源代码不是一个好主意,但我应该在用户体验的一致性和代码风格之间取得一些平衡;(