質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Authentication

Authentication(認証)は正当性を認証する為の工程です。ログイン処理等で使われます。

Q&A

0回答

357閲覧

apple認証でのサインイン状態を監視したい

po_tato

総合スコア97

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Authentication

Authentication(認証)は正当性を認証する為の工程です。ログイン処理等で使われます。

0グッド

0クリップ

投稿2020/07/02 10:43

こちらの記事を参考にして、
apple認証の実装を行いました。

一通り、ログインまでの処理は正常に行えております。

■試したいこと
1.ユーザーがアプリを起動しapple認証でログインする
2.ログイン状態でアプリをバックグラウンドにしてホーム画面の「設定」でサインアウトする
3.バックグラウンドのアプリを再度開いたときに認証処理を再度実行したい。

■現時点
1.成功
2.成功
3.認証処理が呼ばれず認証後に表示されるはずのメイン画面が表示される。

バックグラウンドから復帰したときに、addCredentialObserverメソッドが呼ばれるだろうと思ったのですが、
呼ばれていないみたいです。

ちなみに、1の後にアプリをバックグラウンド状態ではなく、一度終了させてからサインアウトして立ち上げると認証処理は実行されます。
ですが、ユーザー側の操作として■試したいことに記載した動きは必ず出てくるものだと思うので修正したいです。

なぜ期待通りに動作しないのかご指摘いただきたいです。

AppDelegate

import UIKit import NCMB import AuthenticationServices @UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate { var window: UIWindow? func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool { // Override point for customization after application launch. // APIキー let applicationKey = "~~~" let clientKey = "~~~" // APIキーの設定とSDK初期化 NCMB.initialize(applicationKey: applicationKey, clientKey: clientKey); // on the initial view controller or somewhere else, check the userdefaults if let userID = UserDefaults.standard.string(forKey: "userID") { // move to main view print("以前にログイン済み") print(userID) self.handleASCredential(userId: userID) }else{ goLoginViewConroller() } return true } //Appleのサインイン状態の確認 private func handleASCredential(userId:String) { let appleIDProvider = ASAuthorizationAppleIDProvider() appleIDProvider.getCredentialState(forUserID: userId) { (credentialState, error) in switch credentialState { case .authorized: print("user remain logged in, proceed to another view") //self.performSegue(withIdentifier: "LoginToUserSegue", sender: nil) case .revoked: print("user logged in before but revoked") self.goLoginViewConroller() case .notFound: print("user haven't log in before") self.goLoginViewConroller() default: print("unknown state") self.goLoginViewConroller() } } } //サインイン状態を監視する private func addCredentialObserver() { let userID = UserDefaults.standard.string(forKey: "userID") let center = NotificationCenter.default let name = ASAuthorizationAppleIDProvider.credentialRevokedNotification let _ = center.addObserver(forName: name, object: nil, queue: nil) { (Notification) in // サインアウトして、再度サインインフローを表示するなど self.handleASCredential(userId: userID!) } } //ログインコントローラーに遷移 func goLoginViewConroller(){ DispatchQueue.main.async { //画面遷移させたい部分に以下の処理を記述 // windowを生成 self.window = UIWindow(frame: UIScreen.main.bounds) // Storyboardを指定 let storyboard = UIStoryboard(name: "Main", bundle: nil) // Viewcontrollerを指定 let loginViewController = storyboard.instantiateViewController(withIdentifier:"login") // rootViewControllerに入れる self.window?.rootViewController = loginViewController // 表示 self.window?.makeKeyAndVisible() } } }

環境
Xcode: Version 11.3.1 (11C504)
実機 : iPhone7 Version 13.3.1

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問