Lompat ke konten

Login Apple di Android

GitHub

Login Apple di Android adalah tidak biasa. Apple tidak memiliki dukungan resmi untuk Sign in with Apple di Android, jadi solusinya sedikit tidak biasa.

Android saat ini menggunakan tab Chrome untuk menampilkan situs web OAuth2. Pendekatan ini memiliki tantangan:

  • Konfigurasi sulit
  • Diperlukan backend

Biarkan saya menggunakan diagram untuk menjelaskan alur di Android:

Sekarang Anda menyadari tantangan dan alur, mari kita mulai dengan konfigurasi.

  1. Masuk ke Portal Pengembang Apple.

  2. Klik pada Identifiers.

    Bagian Identifikasi Portal Pengembang Apple

    Anda harus melihat layar yang terlihat seperti ini:

    Layar Identifikasi Portal Pengembang Apple
    1. Pastikan bidang ini mengatakan App IDs
    2. Pastikan Anda dapat menemukan ID Aplikasi Anda.
  3. Pastikan bahwa Sign in with Apple kemampuan diaktifkan untuk aplikasi Anda

    1. Klik pada aplikasi Anda Mengilih aplikasi Anda dari daftar
    2. Pastikan bahwa Sign in with Apple kemampuan diaktifkan Centang kotak kemampuan Sign in with Apple
    3. Jika tidak diaktifkan, aktifkan.
  4. Kembali ke semua All Identifiers

    Semua Identifikasi navigasi tombol
  5. Klik pada App Ids dan pergi ke Services IDs

    Navigasi ke bagian ID layanan
  6. Buat identifikasi baru

    1. Klik pada tombol plus

      Tambahkan ID layanan baru tombol
    2. Pilih Servcice IDs dan klik Continue

      Pilihan ID layanan
    3. Masukkan deskripsi dan identifikasi dan klik Continuie.

      Menginput detail ID layanan
    4. Silakan verifikasi detail dan klik Register

      Mengkonfirmasi registrasi ID layanan
    5. Klik pada layanan baru yang telah dibuat

      Menggunakan ID layanan baru yang telah dibuat
    6. Aktifkan Sign in with Apple option

      Mengaktifkan Sign in dengan Apple untuk ID layanan
    7. Konfigurasi Sign In with Apple

      Tombol Konfigurasi untuk Sign in dengan Apple
    8. Pastikan bahwa Primary App ID __CAPGO_KEEP_0__ ditetapkan ke ID Aplikasi yang telah dikonfigurasi pada langkah sebelumnya.

      Pengaturan ID Aplikasi Utama dropdown
    9. Tambahkan domain yang akan Anda gunakan untuk menghosting backend Anda.

      Pengaturan bidang domain dan URL kembali
    10. Konfirmasikan data dan klik Done

      Konfirmasi domain dan pengaturan URL kembali
    11. Klik pada Continue

      Tombol Lanjutkan untuk pengaturan layanan
    12. Klik pada Save

      Tombol Simpan untuk pengaturan layanan
  1. Kembali ke semua All Identifiers

    Tombol Navigasi Identifikasi Semua
  2. Klik pada Keys

    Bagian Kunci di Portal Pengembang Apple
  3. Klik ikon plus

    Tombol kunci baru
  4. Berikan nama kunci

    Mengisi bidang nama kunci
  5. Pilih Sign in with Apple dan klik Configure

    Mengaktifkan dan mengonfigurasi Sign in dengan Apple untuk kunci
  6. Pilih ID Aplikasi utama, dan tekan Save

    Mengatur ID Aplikasi utama untuk kunci
  7. Klik pada Continue

    Tombol Lanjutkan untuk pengaturan kunci
  8. Klik pada Register

    Tombol Daftar untuk pembuatan kunci
  9. Salin ID kunci dan download kunci.

    Tampilan tombol ID dan download kunci
  10. Temukan kunci yang diunduh dan simpan di folder backend.

    File kunci yang diunduh

Untuk menggunakan Login with Apple di Android, Anda perlu mendapatkan Team ID. Akan digunakan di backend.

  1. Lihat website ini dan gulir ke bawah

  2. Temukan lokasi ID tim di akun pengembang Team ID

    Konfigurasi pengalihan aplikasi

. Ini memerlukan perubahan manual pada aplikasi Anda. Redirect back to the appUbah

  1. Buka file ini, saya akan menggunakan AndroidManifest.xml
    1. File AndroidManifest.xml di Android Studio AndroidStudio

      Temukan
    2. dan tambahkan filter Intent berikut MainActivity Filter Intent __CAPGO_KEEP_0__ untuk menambahkan di MainActivity

      Intent filter code to add in MainActivity
      <intent-filter>
      <action android:name="android.intent.action.VIEW" />
      <category android:name="android.intent.category.DEFAULT" />
      <category android:name="android.intent.category.BROWSABLE" />
      <data android:scheme="capgo-demo-app" android:host="path" />
      </intent-filter>
  2. Ubahlah MainActivity
    1. Silakan buka file MainActivity.java di Android Studio MainActivity

      Tambahkan kode berikut __CAPGO_KEEP_0__:
    2. code untuk menambahkan fungsi pengiriman tautan dalam ke dalam MainActivity

      Code to add to MainActivity for handling deep links
      @Override
      protected void onNewIntent(Intent intent) {
      String action = intent.getAction();
      Uri data = intent.getData();
      if (Intent.ACTION_VIEW.equals(action) && data != null) {
      PluginHandle pluginHandle = getBridge().getPlugin("SocialLogin");
      if (pluginHandle == null) {
      Log.i("Apple Login Intent", "SocialLogin login handle is null");
      return;
      }
      Plugin plugin = pluginHandle.getInstance();
      if (!(plugin instanceof SocialLoginPlugin)) {
      Log.i("Apple Login Intent", "SocialLogin plugin instance is not SocialLoginPlugin");
      return;
      }
      ((SocialLoginPlugin) plugin).handleAppleLoginIntent(intent);
      return;
      }
      super.onNewIntent(intent);
      }

Diperlukan backend untuk Android, tetapi mengonfigurasi backend juga akan mempengaruhi IOS. Contoh backend disediakan Contoh ini menyediakan:

Database JSON sederhana

  • Database JSON sederhana
  • Cara untuk meminta JWT dari server Apple
  • Verifikasi JWT yang sederhana

Dengan segala yang saya katakan dalam tutorial ini, berikut adalah cara env bagian ini akan terlihat:

  • ANDROID_SERVICE_ID = ID Layanan
  • IOS_SERVICE_ID = ID Aplikasi
env: {
PRIVATE_KEY_FILE: "AuthKey_U93M8LBQK3.p8",
KEY_ID: "U93M8LBQK3",
TEAM_ID: "UVTJ336J2D",
ANDROID_SERVICE_ID: "ee.forgr.io.ionic.starter.service2",
IOS_SERVICE_ID: "me.wcaleniewolny.test.ionic.vue",
PORT: 3000,
REDIRECT_URI: "https://xyz.wcaleniewolny.me/login/callback",
BASE_REDIRECT_URL: "capgo-demo-app://path"
}

Penggunaan dari login fungsi tidak berubah, sama seperti IOS. Silakan lihat bagian tersebut untuk informasi lebih lanjut. TETAPI, metode initialize Salin ke clipboard

await SocialLogin.initialize({
apple: {
clientId: 'ee.forgr.io.ionic.starter.service2',
redirectUrl: 'https://appleloginvps.wcaleniewolny.me/login/callback'
}
})
  1. Jika Anda belum memiliki ID Aplikasi, klik tombol plus

    Tombol plus untuk menambahkan identifier baru
  2. Pilih App IDs dan klik lanjutkan

    Mengilih jenis ID Aplikasi
  3. Klik pada jenis App dan klik Continue

    Mengatur jenis aplikasi
  4. Masukkan deskripsi dan ID aplikasi

    Mengisi deskripsi aplikasi dan ID bundle
  5. Aktifkan Sign with Apple kemampuan

    Mengaktifkan kemampuan Sign in dengan Apple
  6. Klik Continue

    Tombol Lanjutkan untuk registrasi aplikasi
  7. Konfirmasi detail dan klik Register

    Konfirmasi detail registrasi aplikasi

Jika Anda menggunakan Login Apple di Android untuk merencanakan autentikasi dan alur akun, hubungkannya dengan Menggunakan @capgo/capacitor-login-social untuk kemampuan asli di Menggunakan @capgo/capacitor-login-social, @capgo/capacitor-login-social untuk detail implementasi di @capgo/capacitor-login-social, @capgo/capacitor-passkey untuk detail implementasi di @capgo/capacitor-passkey, @capgo/capacitor-biometrik-asli untuk detail implementasi di @capgo/capacitor-native-biometric, dan Autentikasi Dua Faktor untuk detail implementasi di Autentikasi Dua Faktor.