Login Apple di Android
Copy sebuah prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
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
Mengerti alur di Android.
Bagian berjudul “Mengerti alur di Android.”Biarkan saya menggunakan diagram untuk menjelaskan alur di Android:
flowchart TD
A("await SocialLogin.login()") -->|Handled in the plugin|B(Generate the login URL)
B --> |Pass the link| C(Open the Chrome browser)
C --> D(Wait for the user to login)
D --> |Apple redirects to your backend|E(Handle the data returned from Apple)
E --> F(Redirect back to the app)
F --> G(Return to JS) Sekarang Anda menyadari tantangan dan alur, mari kita mulai dengan konfigurasi.
Membuat ID layanan
Judul bagian “Membuat ID layanan”-
Masuk ke Portal Pengembang Apple.
-
Klik pada
Identifiers.
Anda harus melihat layar yang terlihat seperti ini:
- Pastikan bidang ini mengatakan
App IDs - Pastikan Anda dapat menemukan ID Aplikasi Anda.
- Pastikan bidang ini mengatakan
-
Pastikan bahwa
Sign in with Applekemampuan diaktifkan untuk aplikasi Anda- Klik pada aplikasi Anda
- Pastikan bahwa
Sign in with Applekemampuan diaktifkan
- Jika tidak diaktifkan, aktifkan.
- Klik pada aplikasi Anda
-
Kembali ke semua
All Identifiers
-
Klik pada
App Idsdan pergi keServices IDs
-
Buat identifikasi baru
-
Klik pada tombol plus
-
Pilih
Servcice IDsdan klikContinue
-
Masukkan deskripsi dan identifikasi dan klik
Continuie.
-
Silakan verifikasi detail dan klik
Register
-
Klik pada layanan baru yang telah dibuat
-
Aktifkan
Sign in with Appleoption
-
Konfigurasi
Sign In with Apple
-
Pastikan bahwa
Primary App ID__CAPGO_KEEP_0__ ditetapkan ke ID Aplikasi yang telah dikonfigurasi pada langkah sebelumnya.
-
Tambahkan domain yang akan Anda gunakan untuk menghosting backend Anda.
-
Konfirmasikan data dan klik
Done
-
Klik pada
Continue
-
Klik pada
Save
-
Membuat kunci
Bagian berjudul “Membuat kunci”-
Kembali ke semua
All Identifiers
-
Klik pada
Keys
-
Klik ikon plus
-
Berikan nama kunci
-
Pilih
Sign in with Appledan klikConfigure
-
Pilih ID Aplikasi utama, dan tekan
Save
-
Klik pada
Continue
-
Klik pada
Register
-
Salin ID kunci dan download kunci.
-
Temukan kunci yang diunduh dan simpan di folder backend.
Mendapatkan ID Tim
Judul bagian “Mendapatkan ID Tim”Untuk menggunakan Login with Apple di Android, Anda perlu mendapatkan Team ID. Akan digunakan di backend.
-
Lihat website ini dan gulir ke bawah
-
Temukan lokasi ID tim di akun pengembang
Team ID
Bab berjudul “Konfigurasi pengalihan aplikasi”
Seperti yang Anda lihat dalam diagram, backend melakukan langkah yang disebut. Ini memerlukan perubahan manual pada aplikasi Anda. Redirect back to the appUbah
- Buka file ini, saya akan menggunakan
AndroidManifest.xml-
File AndroidManifest.xml di Android Studio
AndroidStudio
-
dan tambahkan filter Intent berikut
MainActivityFilter Intent __CAPGO_KEEP_0__ untuk menambahkan di 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>
-
- Ubahlah
MainActivity-
Silakan buka file MainActivity.java di Android Studio
MainActivity
-
code untuk menambahkan fungsi pengiriman tautan dalam ke dalam MainActivity
@Overrideprotected 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);}
-
Konfigurasi Backend
Bagian berjudul “Konfigurasi Backend”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 LayananIOS_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"}Menggunakan plugin
Bagian berjudul “Menggunakan plugin”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' }})Membuat aplikasi
Judul bagian “Membuat aplikasi”-
Jika Anda belum memiliki ID Aplikasi, klik tombol plus
-
Pilih
App IDsdan klik lanjutkan
-
Klik pada jenis
Appdan klikContinue
-
Masukkan deskripsi dan ID aplikasi
-
Aktifkan
Sign with Applekemampuan
-
Klik
Continue
-
Konfirmasi detail dan klik
Register
Teruskan dari login Apple di Android
Judul bagian “Teruskan dari login Apple di Android”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.