+
95
-

回答


首先开发者账号的app绑定的identifiers 中选中,操作如下:

在Xcode 中的点击capability


添加sign in with apple,确保前面的勾选上了


下面来写代码:

在登录界面添加 #import <AuthenticationServices/AuthenticationServices.h>

    if(@available(iOS13.0, *)) {

// Sign In With Apple Button

ASAuthorizationAppleIDButton *appleIDBtn = [ASAuthorizationAppleIDButton buttonWithType:ASAuthorizationAppleIDButtonTypeDefault style:ASAuthorizationAppleIDButtonStyleWhite];

appleIDBtn.frame= CGRectMake(50,100,100,40);

appleIDBtn.layer.cornerRadius=5;

appleIDBtn.layer.masksToBounds=YES;

[appleIDBtnaddTarget:selfaction:@selector(handleAuthorizationAppleIDButtonPress)forControlEvents:UIControlEventTouchUpInside];

[self.view addSubview:appleIDBtn];

}



//苹果第三方登录

-(void)handleAuthorizationAppleIDButtonPress{



if(@available(iOS13.0, *)) {

// 基于用户的Apple ID授权用户,生成用户授权请求的一种机制

ASAuthorizationAppleIDProvider *appleIDProvider = [[ASAuthorizationAppleIDProvider alloc] init];

// 创建新的AppleID 授权请求

ASAuthorizationAppleIDRequest*appleIDRequest = [appleIDProvidercreateRequest];

// 在用户授权期间请求的联系信息

appleIDRequest.requestedScopes = @[ASAuthorizationScopeFullName, ASAuthorizationScopeEmail];

// 由ASAuthorizationAppleIDProvider创建的授权请求 管理授权请求的控制器

ASAuthorizationController*authorizationController = [[ASAuthorizationControlleralloc]initWithAuthorizationRequests:@[appleIDRequest]];

// 设置授权控制器通知授权请求的成功与失败的代理

authorizationController.delegate=self;

// 设置提供 展示上下文的代理,在这个上下文中 系统可以展示授权界面给用户

authorizationController.presentationContextProvider=self;

// 在控制器初始化期间启动授权流

[authorizationControllerperformRequests];

}

}

// 如果存在iCloud Keychain 凭证或者AppleID 凭证提示用户

//这个方法在viewDidAppear里添加

- (void)perfomExistingAccountSetupFlows{

NSLog(@"///已经认证过了/////");

if(@available(iOS13.0, *)) {

// 基于用户的Apple ID授权用户,生成用户授权请求的一种机制

ASAuthorizationAppleIDProvider *appleIDProvider = [[ASAuthorizationAppleIDProvider alloc] init];

// 授权请求AppleID

ASAuthorizationAppleIDRequest*appleIDRequest = [appleIDProvidercreateRequest];

// 为了执行钥匙串凭证分享生成请求的一种机制

ASAuthorizationPasswordProvider *passwordProvider = [[ASAuthorizationPasswordProvider alloc] init];

ASAuthorizationPasswordRequest*passwordRequest = [passwordProvidercreateRequest];

// 由ASAuthorizationAppleIDProvider创建的授权请求 管理授权请求的控制器

ASAuthorizationController*authorizationController = [[ASAuthorizationControlleralloc]initWithAuthorizationRequests:@[appleIDRequest, passwordRequest]];

// 设置授权控制器通知授权请求的成功与失败的代理

authorizationController.delegate=self;

// 设置提供 展示上下文的代理,在这个上下文中 系统可以展示授权界面给用户

authorizationController.presentationContextProvider=self;

// 在控制器初始化期间启动授权流

[authorizationControllerperformRequests];

}

}

#pragma mark- delegate

//@optional 授权成功地回调

- (void)authorizationController:(ASAuthorizationController *)controller didCompleteWithAuthorization:(ASAuthorization *)authorization{

NSLog(@"授权完成:::%@", authorization.credential);

NSLog(@"%s", __FUNCTION__);

NSLog(@"%@", controller);

NSLog(@"%@", authorization);

// 测试配置UI显示

NSMutableString *mStr = [NSMutableString string];

if ([authorization.credential isKindOfClass:[ASAuthorizationAppleIDCredential class]]) {

// 用户登录使用ASAuthorizationAppleIDCredential

ASAuthorizationAppleIDCredential*appleIDCredential = authorization.credential;

NSString*user = appleIDCredential.user;

NSString*familyName = appleIDCredential.fullName.familyName;

NSString*givenName = appleIDCredential.fullName.givenName;

NSString*email = appleIDCredential.email;



NSString *authorizationCode = [[NSString alloc] initWithData:appleIDCredential.authorizationCode encoding:NSUTF8StringEncoding]; // refresh token

NSString *identityToken = [[NSString alloc] initWithData:appleIDCredential.identityToken encoding:NSUTF8StringEncoding]; // access token

ASUserDetectionStatusrealUserStatus = appleIDCredential.realUserStatus;





// NSData *identityToken = appleIDCredential.identityToken;

// NSData *authorizationCode = appleIDCredential.authorizationCode;

// Create an account in your system.

// For the purpose of this demo app, store the userIdentifier in the keychain.

// 需要使用钥匙串的方式保存用户的唯一信息

// [mStr appendString:user];

// [mStr appendString:@"\n"];

// [mStr appendString:familyName];

// [mStr appendString:@"\n"];

// [mStr appendString:givenName];

// [mStr appendString:@"\n"];

// [mStr appendString:email];

// NSLog(@"mStr:::%@", mStr);

// [mStr appendString:@"\n"];

}elseif([authorization.credentialisKindOfClass:[ASPasswordCredentialclass]]){

// Sign in using an existing iCloud Keychain credential.

// 用户登录使用现有的密码凭证

ASPasswordCredential*passwordCredential = authorization.credential;

// 密码凭证对象的用户标识 用户的唯一标识

NSString*user = passwordCredential.user;

// 密码凭证对象的密码

NSString*password = passwordCredential.password;

[mStrappendString:user];

[mStrappendString:@"\n"];

[mStrappendString:password];

[mStrappendString:@"\n"];

NSLog(@"mStr:::%@", mStr);

}else{

NSLog(@"授权信息均不符");

mStr = [@"授权信息均不符"copy];

}

}

// 授权失败的回调

- (void)authorizationController:(ASAuthorizationController *)controller didCompleteWithError:(NSError *)error{

// Handle error.

NSLog(@"Handle error:%@", error);

NSString*errorMsg =nil;

switch(error.code) {

case ASAuthorizationErrorCanceled:

errorMsg =@"用户取消了授权请求";

break;

case ASAuthorizationErrorFailed:

errorMsg =@"授权请求失败";

break;

case ASAuthorizationErrorInvalidResponse:

errorMsg =@"授权请求响应无效";

break;

case ASAuthorizationErrorNotHandled:

errorMsg =@"未能处理授权请求";

break;

case ASAuthorizationErrorUnknown:

errorMsg =@"授权请求失败未知原因";

break;

default:

break;

}

// NSMutableString *mStr = [_appleIDInfoLabel.text mutableCopy];

// [mStr appendString:@"\n"];

// [mStr appendString:errorMsg];

// [mStr appendString:@"\n"];

}

// 告诉代理应该在哪个window 展示内容给用户

- (ASPresentationAnchor)presentationAnchorForAuthorizationController:(ASAuthorizationController *)controller{

NSLog(@"88888888888");

// 返回window

return self.view.window;

}
注意:code码-1代表验证通过,验证不通过是重新调用一下handleAuthorizationAppleIDButtonPress这个方法。

网友回复

我知道答案,我要回答