出于显而易见的原因,我具有“使用Facebook登录”功能的全功能应用程序昨天停止工作。
我深入研究该错误,发现由于某种原因内部无法构建身份验证URL,从而使整个过程失败。
问题来自+ (NSURL *)URLWithScheme:(NSString *)scheme host:(NSString *)host path:(NSString *)path queryParameters:(NSDictionary *)queryParameters error:(NSError *__autoreleasing *)errorRef
类中的FBSDKInternalUtility
方法。
在第430行中,它尝试构建URL:
NSURL *URL = [[NSURL alloc] initWithString:[NSString stringWithFormat:
@"%@://%@%@%@",
scheme ?: @"",
host ?: @"",
path ?: @"",
queryString ?: @""]];
我已逐步完成代码。 scheme
,host
,path
和queryString
均已设置。尽管它返回nil
而不是URL。我尝试用一个空的查询字符串调用该方法,它实际上建立了URL。由于某些原因,queryString
导致URL构建不正确。
这里是queryString
:(我用123456789替换了我的应用ID)
(lldb) po queryString
?auth_type=rerequest&client_id=123456789&default_audience=friends&display=touch&e2e={%22init%22%3A70747.196361124996}&fbapp_pres=1&redirect_uri=fb123456789%3A%2F%2Fauthorize%2F&response_type=token%2Csigned_request&return_scopes=true&scope=user_birthday%2Cemail%2Cuser_friends%2Cuser_photos&sdk=ios&sdk_version=4.39.0&state={%22challenge%22%3A%22yi8jE3mok79u9BheN8dzCMCviGY%253D%22%2C%220_auth_logger_id%22%3A%22329202ED-2F9B-4DBC-A191-E2C720D9779C%22%2C%22com.facebook.sdk_client_state%22%3Atrue%2C%223_method%22%3A%22sfvc_auth%22}
可能是什么原因造成的?几天前它还在工作。
答案 0 :(得分:1)
在模拟器上遇到相同的错误后,我更详细地检查了我的应用程序所做的更改。这是最新的Facebook SDK(4.39)。我运行pod update
来更新其他一些Pod,这也将Facebook SDK从4.38.1更新到了4.39。
我恢复到4.38.1,问题消失了。换句话说, Facebook SDK 4.39打破了自己的登录功能,实际上使他们自己的SDK无法使用。
强制使用以下旧版本解决了该问题:
pod 'FBSDKCoreKit', '~> 4.38.1'
pod 'FBSDKLoginKit', '~> 4.38.1'