يمكنك استخدام Firebase Authentication لإنشاء واستخدام حسابات مؤقتة مجهولة الهوية. للمصادقة باستخدام Firebase. يمكن استخدام هذه الحسابات المجهولة مؤقتًا السماح للمستخدمين الذين لم يشتركوا في تطبيقك بعد باستخدام البيانات المحمية وفقًا لقواعد الأمان إذا قرر مستخدم مجهول الهوية الاشتراك في تطبيقك، يمكنك: ربط بيانات اعتماد تسجيل الدخول بحساب مجهول حتى يتمكنوا من مواصلة العمل باستخدام بياناتهم المحمية من خلال الجلسات المستقبلية.
قبل البدء
- إضافة Firebase إلى C++ مشروعك.
- إذا لم تكن قد ربطت تطبيقك بمشروعك في Firebase بعد، يمكنك إجراء ذلك من وحدة تحكّم Firebase.
- تفعيل المصادقة المجهولة:
- في وحدة تحكُّم Firebase، افتح قسم المصادقة.
- في صفحة طرق تسجيل الدخول، فعِّل الخيار مجهول الهوية. تسجيل الدخول.
- اختياري: إذا قمت بترقية مشروعك إلى Firebase Authentication with Identity Platform، يمكنك تفعيل ميزة "إزالة البرامج غير المرغوب فيها تلقائيًا". فعندما بعد تفعيل هذا الإعداد، سيتم تلقائيًا تحديد الحسابات المجهولة الهوية التي مرّ عليها أكثر من 30 يومًا حذف. في المشاريع التي تم فيها تفعيل ميزة "التنظيف التلقائي"، لن يتم تفعيل المصادقة المجهولة بعد ذلك يتم احتسابها ضمن حدود الاستخدام أو حصص الفوترة. عرض إزالة البرامج غير المرغوب فيها تلقائيًا:
المصادقة باستخدام Firebase بهوية مجهولة
عندما يستخدم مستخدم لم يسجّل الدخول ميزة تطبيق تتطلب المصادقة مع Firebase، سجِّل الدخول إلى المستخدم بدون الكشف عن هويتك من خلال إكمال الخطوات التالية:
الفئةAuth
هي مدخل جميع طلبات البيانات من واجهة برمجة التطبيقات.
- إضافة ملفات رؤوس التطبيقات والمصادقة:
#include "firebase/app.h" #include "firebase/auth.h"
- في رمز الإعداد، أنشئ
صف واحد (
firebase::App
).#if defined(__ANDROID__) firebase::App* app = firebase::App::Create(firebase::AppOptions(), my_jni_env, my_activity); #else firebase::App* app = firebase::App::Create(firebase::AppOptions()); #endif // defined(__ANDROID__)
- الحصول على الصف
firebase::auth::Auth
لـfirebase::App
هناك ربط واحد لواحد بينApp
وAuth
.firebase::auth::Auth* auth = firebase::auth::Auth::GetAuth(app);
Auth::SignInAnonymously
firebase::Future<firebase::auth::AuthResult> result = auth->SignInAnonymously();
Auth::SignInAnonymouslyLastResult
:
firebase::Future<firebase::auth::AuthResult> result = auth->SignInAnonymouslyLastResult(); if (result.status() == firebase::kFutureStatusComplete) { if (result.error() == firebase::auth::kAuthErrorNone) { firebase::auth::AuthResult auth_result = *result.result(); printf("Sign in succeeded for `%s`\n", auth_result.user.display_name().c_str()); } else { printf("Sign in failed with error '%s'\n", result.error_message()); } }أو إذا كان برنامجك مستندًا إلى أحداث، قد تفضّل تسجيل معاودة الاتصال على المستقبل:
تحويل حساب مجهول إلى حساب دائم
عند اشتراك مستخدم مجهول في تطبيقك، قد تحتاج إلى السماح له مواصلة عملهم باستخدام حساباتهم الجديدة - على سبيل المثال، قد ترغب في عرض السلع التي أضافها المستخدم إلى سلّة التسوّق قبل الاشتراك متاحة في سلة التسوق الخاصة بالحساب الجديد. لإجراء ذلك، أكمل ما يلي الخطوات:
- عندما يشترك المستخدم، أكمِل إجراءات تسجيل الدخول إلى حساب المستخدم
بمزود مصادقة يصل إلى، ولكن لا يشمل، الاتصال بأحد
Auth::SignInWith
طريقة على سبيل المثال، احصل على الرمز المميز لمعرّف Google للمستخدم، رمز الدخول إلى Facebook، أو عنوان البريد الإلكتروني وكلمة المرور. احصل على
تسجيل الدخول باستخدام حساب Googleauth::Credential
لموفِّر المصادقة الجديد:firebase::auth::Credential credential = firebase::auth::GoogleAuthProvider::GetCredential(google_id_token, nullptr);
تسجيل الدخول إلى Facebookfirebase::auth::Credential credential = firebase::auth::FacebookAuthProvider::GetCredential(access_token);
تسجيل الدخول باستخدام كلمة مرور البريد الإلكترونيfirebase::auth::Credential credential = firebase::auth::EmailAuthProvider::GetCredential(email, password);
تمرير الكائن
auth::Credential
إلى حساب المستخدم الذي سجّل الدخول طريقةLinkWithCredential
:// Link the new credential to the currently active user. firebase::auth::User current_user = auth->current_user(); firebase::Future<firebase::auth::AuthResult> result = current_user.LinkWithCredential(credential);
إذا نجح الاتصال إلى LinkWithCredential
، يمكن إنشاء حساب المستخدم الجديد
الوصول إلى بيانات Firebase للحساب المجهول.
التنظيف التلقائي
في حال ترقية مشروعك إلى Firebase Authentication with Identity Platform، يمكنك: تفعيل الإزالة التلقائية في وحدة تحكّم Firebase. عند تفعيل هذه الميزة، فأنت تسمح Firebase لحذف الحسابات المجهولة الهوية التي مرّ عليها أكثر من 30 يومًا تلقائيًا. في المشروعات التي تتضمن تلقائيًا تمكين تنظيف البيانات، ولن يتم احتساب المصادقة المجهولة ضمن حدود الاستخدام أو حصص الفوترة.
- وقد يتم تلقائيًا حذف أي حسابات مجهولة المصدر تم إنشاؤها بعد تفعيل ميزة "إزالة البرامج غير المرغوب فيها تلقائيًا". يتم حذفه في أي وقت بعد 30 يومًا بعد الإنشاء.
- ستكون الحسابات الحالية المجهولة المصدر مؤهَّلة للحذف التلقائي بعد 30 يومًا. ما يتيح تنظيف البيانات تلقائيًا.
- في حال إيقاف إزالة البرامج غير المرغوب فيها، ستبقى أي حسابات مجهولة الهوية ومجدولة للحذف جدول زمني لحذفه.
- في حال "الترقية" بحساب مجهول من خلال ربطه بأي طريقة تسجيل دخول، فإن الحساب لا يتم حذفها تلقائيًا.
إذا أردت معرفة عدد المستخدمين الذين سيتأثرون قبل تفعيل هذه الميزة،
تمت ترقية مشروعك إلى Firebase Authentication with Identity Platform، ويمكنك الفلترة حسب
is_anon
في السحابة الإلكترونية
التسجيل:
الخطوات التالية
الآن بعد أن أصبح بإمكان المستخدمين المصادقة باستخدام Firebase، يمكنك التحكم في وصولهم إلى في قاعدة بيانات Firebase باستخدام قواعد Firebase.