189 8069 5689

ios开发第三方登录,ios开发登录功能实现

iOS开发--使用友盟快速分享与第三方登录注意事项

官方说的比较详细,但是就是有些重复,而且有很多坑

10年积累的成都网站建设、网站制作经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有信宜免费网站建设让你可以放心的选择与我们合作。

在info.plist中加入安全域名白名单(右键info.plist用source code打开)

在info.plist的NSAppTransportSecurity下新增NSAllowsArbitraryLoads并设置为YES,指定所有HTTP连接都可正常请求

打开app,用第三方登录,发现没有sso授权页面,或打开QQ失败、微信失败、微博失败等

info.plist增加:

在iOS9下就需要增加一个可跳转的白名单,指定对应跳转App的URL Scheme,否则将在第三方平台判断是否跳转时用到的canOpenURL时返回NO,进而只进行webview授权或授权/分享失败。

iOS. 通过appleId进行苹果第三方登录

2020年4月后,有第三方平台登录的app必须有苹果的第三方登录

开发者账号的app绑定的identifiers 中选中

在Xcode 中的

添加

在登录界面添加 #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: self action: @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"];

} else if ([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这个方法就可以,我甚至去看官方文档,也没有说重新获取token或者删除账号的方法

iOS实现苹果第三方登录功能 - Sign in with apple

闲话少说,直接上码

登陆developer账号,在app bundle ID的Capabilities里,打勾 Sign In with Apple .

打开Xcode 11.0 Beta或更新版本,在项目设置 - Signing Capabilities 里,开启 Sign in with Apple 选项。

实现分四大部分:

在上面 ASAuthorizationControllerDelegate 的用户通过验证的回调里,可以拿到 credential ,这里面有一些信息值得提下:

授权或者用户信息是有可能被改变的,我们能做到就是尽早的检测出这样的改变,并做以应对。

检测授权的状态需要记录在上面所得到的

在 AppleDelegate 里,把之前存的用户ID放到 ASAuthorizationAppleIDProvider 里验证即可,可以得到几种用户授权状态:

如果有错误欢迎指出,也欢迎各种讨论,谢????!


文章名称:ios开发第三方登录,ios开发登录功能实现
URL分享:http://cdxtjz.cn/article/dsiecsp.html

其他资讯