Configuración de inicio de sesión de Facebook
Copie un prompt de configuración con los pasos de instalación y la guía de markdown completa para este plugin.
Introducción
Sección titulada “Introducción”En esta guía, aprenderá a configurar el inicio de sesión de Facebook con Capgo Inicio de sesión social. Necesitará lo siguiente:
- Una cuenta de desarrollador de Facebook
- El nombre de paquete/app de su aplicación o el ID de paquete
- Acceso a una terminal para generar claves de hash (Android)
Configuración general
Sección titulada “Configuración general”Si no tiene ya una aplicación de Facebook creada, siga estos pasos:
-
Crear una aplicación de Facebook
Sigue el tutorial para Crear una aplicación
-
Agregar inicio de sesión de Facebook a tu aplicación
En tu panel de control de desarrollador de Facebook, agrega el producto de inicio de sesión de Facebook a tu aplicación
-
Antes de que puedas publicar tu aplicación para el público, sigue este tutorial para publicarla
Información importante
Sección titulada “Información importante”Aquí es donde encontrarás la información clave que necesitarás para la integración:
-
CLIENT_TOKEN:
-
APP_ID:
-
APP_NAME:
Configuración de Android
Sección titulada “Configuración de Android”-
Agregar permiso de Internet a tu
AndroidManifest.xmlAsegúrate de que esta línea esté presente:
<uses-permission android:name="android.permission.INTERNET"/> -
Generar tu hash de clave de Android
Este es un paso crucial de seguridad requerido por Facebook. Abre tu terminal y ejecuta:
Ventana de terminal keytool -exportcert -alias androiddebugkey -keystore ~/.android/debug.keystore | openssl sha1 -binary | openssl base64 -ACuando se te pregunte por una contraseña, utiliza:
android -
Agregar el hash de clave a tu aplicación de Facebook
- Ir a la consola de tu aplicación en Facebook Developers
- Navegar a Configuración > Básico
- Desplazarse hacia abajo hasta la sección "Android"
- Hacer clic en "Agregar plataforma" si Android no está agregado aún y rellenar los detalles
- Agregar el hash de clave que generaste
- Para producción, agregar ambos hash de clave de depuración y de lanzamiento
-
Actualice su
AndroidManifest.xmlpara incluir:<application>...<activity android:name="com.facebook.FacebookActivity"android:configChanges="keyboard|keyboardHidden|screenLayout|screenSize|orientation"android:label="@string/app_name" /><activityandroid:name="com.facebook.CustomTabActivity"android:exported="true"><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="FB[APP_ID]" /></intent-filter></activity></application>
Configuración de iOS
Sección titulada “Configuración de iOS”-
Agregue la plataforma de iOS en el panel de control de desarrolladores de Facebook
- Vaya a la consola de desarrolladores de Facebook y agregue la plataforma de iOS
- Navegue a Configuración > Básico
- Desplácese hacia abajo hasta el final de la página y haga clic en “Agregar Plataforma”
- Seleccione iOS y rellene los detalles requeridos
-
Abra su proyecto de Xcode y navegue a Info.plist
-
Agregue los siguientes registros a su Info.plist:
<key>FacebookAppID</key><string>[APP-ID]</string><key>FacebookClientToken</key><string>[CLIENT-TOKEN]</string><key>FacebookDisplayName</key><string>[APP-NAME]</string><key>LSApplicationQueriesSchemes</key><array><string>fbapi</string><string>fb-messenger-share-api</string></array><key>CFBundleURLTypes</key><array><dict><key>CFBundleURLSchemes</key><array><string>fb[APP-ID]</string></array></dict></array> -
Modifica el
AppDelegate.swiftimport FBSDKCoreKit@UIApplicationMainclass AppDelegate: UIResponder, UIApplicationDelegate {func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {// Override point for customization after application launch.// Initialize Facebook SDKFBSDKCoreKit.ApplicationDelegate.shared.application(application,didFinishLaunchingWithOptions: launchOptions)return true}func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) -> Bool {// Called when the app was launched with a url. Feel free to add additional processing here,// but if you want the App API to support tracking app url opens, make sure to keep this callif (FBSDKCoreKit.ApplicationDelegate.shared.application(app,open: url,sourceApplication: options[UIApplication.OpenURLOptionsKey.sourceApplication] as? String,annotation: options[UIApplication.OpenURLOptionsKey.annotation])) {return true;} else {return ApplicationDelegateProxy.shared.application(app, open: url, options: options)}}}
Usando Facebook Login en tu aplicación
Sección titulada “Usando Facebook Login en tu aplicación”-
Inicializa el inicio de sesión de Facebook en tu aplicación
import { SocialLogin } from '@capgo/capacitor-social-login';// Initialize during app startupawait SocialLogin.initialize({facebook: {appId: 'APP_ID',clientToken: 'CLIENT_TOKEN',}}) -
Implementa la función de inicio de sesión
async function loginWithFacebook() {try {const result = await SocialLogin.login({provider: 'facebook',options: {permissions: ['email', 'public_profile'],limitedLogin: false // See Limited Login section below for important details}});console.log('Facebook login result:', result);// Handle successful login} catch (error) {console.error('Facebook login error:', error);// Handle error}} -
Obtener datos del perfil del usuario
Después de un inicio de sesión exitoso, puedes recuperar información de perfil adicional:
async function getFacebookProfile() {try {const profileResponse = await SocialLogin.providerSpecificCall({call: 'facebook#getProfile',options: {fields: ['id', 'name', 'email', 'first_name', 'last_name', 'picture']}});console.log('Facebook profile:', profileResponse.profile);return profileResponse.profile;} catch (error) {console.error('Failed to get Facebook profile:', error);return null;}}// Example usage after loginasync function loginAndGetProfile() {const loginResult = await loginWithFacebook();if (loginResult) {const profile = await getFacebookProfile();if (profile) {console.log('User ID:', profile.id);console.log('Name:', profile.name);console.log('Email:', profile.email);console.log('Profile Picture:', profile.picture?.data?.url);}}}Límite de tipo de token : La
getProfilellamada solo funciona cuando tienes un token de acceso (iniciación estándar con seguimiento permitido). Si el usuario denegó el seguimiento o estás utilizando inicio de sesión limitado (solo token JWT), esta llamada fallará. En ese caso, utiliza los datos de perfil proporcionados en la respuesta de inicio de sesión inicial.
⚠️ Crítico: Manejo de tokens de backend
Sección titulada “⚠️ Crítico: Manejo de tokens de backend”Su servidor debe manejar dos tipos de tokens ya que los usuarios de iOS pueden recibir tokens de acceso o tokens JWT dependiendo de su elección de seguimiento de aplicaciones de transparencia, mientras que los usuarios de Android siempre reciben tokens de acceso.
Tipos de tokens por plataforma
Sección titulada “Tipos de tokens por plataforma”| plataforma | Configuración de inicio de sesión limitado | Elección de usuario de ATT | Tipo de token de resultado |
|---|---|---|---|
| iOS | true | Cualquiera | Token JWT |
| iOS | false | Permite el seguimiento | Token de Acceso |
| iOS | false | No permite el seguimiento | Token JWT (auto-sobreescribir) |
| Android | Cualquiera | N/A | Token de Acceso (siempre) |
Implementación de Backend
Sección titulada “Implementación de Backend”-
Detectar tipo de Token y manejar según corresponda
async function loginWithFacebook() {try {const loginResult = await SocialLogin.login({provider: 'facebook',options: {permissions: ['email', 'public_profile'],limitedLogin: false // iOS: depends on ATT, Android: ignored}});if (loginResult.accessToken) {// Access token (Android always, iOS when tracking allowed)return handleAccessToken(loginResult.accessToken.token);} else if (loginResult.idToken) {// JWT token (iOS only when tracking denied or limitedLogin: true)return handleJWTToken(loginResult.idToken);}} catch (error) {console.error('Facebook login error:', error);}} -
Ejemplo de integración con Firebase
import { OAuthProvider, FacebookAuthProvider, signInWithCredential } from 'firebase/auth';async function handleAccessToken(accessToken: string, nonce: string) {// For access tokens, use OAuthProvider (new method)const fbOAuth = new OAuthProvider("facebook.com");const credential = fbOAuth.credential({idToken: accessToken,rawNonce: nonce});try {const userResponse = await signInWithCredential(auth, credential);return userResponse;} catch (error) {console.error('Firebase OAuth error:', error);return false;}}async function handleJWTToken(jwtToken: string) {// For JWT tokens, send to your backend for validationtry {const response = await fetch('/api/auth/facebook-jwt', {method: 'POST',headers: {'Content-Type': 'application/json',},body: JSON.stringify({ jwtToken })});const result = await response.json();return result;} catch (error) {console.error('JWT validation error:', error);return false;}} -
Validación de JWT en backend
// Backend: Validate JWT token from Facebookimport jwt from 'jsonwebtoken';import { Request, Response } from 'express';app.post('/api/auth/facebook-jwt', async (req: Request, res: Response) => {const { jwtToken } = req.body;try {// Verify JWT token with Facebook's public key// See: https://developers.facebook.com/docs/facebook-login/limited-login/token/validating/#standard-claimsconst decoded = jwt.verify(jwtToken, getFacebookPublicKey(), {algorithms: ['RS256'],audience: process.env.FACEBOOK_APP_ID,issuer: 'https://www.facebook.com' // From: https://www.facebook.com/.well-known/openid-configuration/?_rdr});// Extract user info from JWTconst userInfo = {id: decoded.sub,email: decoded.email,name: decoded.name,isJWTAuth: true};// Create your app's session/tokenconst sessionToken = createUserSession(userInfo);res.json({success: true,token: sessionToken,user: userInfo});} catch (error) {console.error('JWT validation failed:', error);res.status(401).json({ success: false, error: 'Invalid token' });}}); -
Manipulador de tokens de backend genérico
// Handle both token types in your backendasync function authenticateFacebookUser(tokenData: any) {if (tokenData.accessToken) {// Handle access token - validate with Facebook Graph APIconst response = await fetch(`https://graph.facebook.com/me?access_token=${tokenData.accessToken}&fields=id,name,email`);const userInfo = await response.json();return {user: userInfo,tokenType: 'access_token',expiresIn: tokenData.expiresIn || 3600};} else if (tokenData.jwtToken) {// Handle JWT token - decode and validate// See: https://developers.facebook.com/docs/facebook-login/limited-login/token/validating/#standard-claimsconst decoded = jwt.verify(tokenData.jwtToken, getFacebookPublicKey());return {user: {id: decoded.sub,name: decoded.name,email: decoded.email},tokenType: 'jwt',expiresIn: decoded.exp - Math.floor(Date.now() / 1000)};} else {throw new Error('No valid token provided');}}
Consideraciones clave
Sección titulada “Consideraciones clave”Token de Acceso (Inicio de Sesión estándar):
- ✅ Android: Siempre disponible (las restricciones de iOS no se aplican)
- ✅ iOS: Solo cuando el usuario permite explícitamente el seguimiento de la aplicación
- ✅ Puede usarse para acceder al gráfico de Facebook API
- ✅ Tiempos de expiración más largos
- ✅ Más datos de usuario disponibles
- ❌ Se está volviendo menos común en iOS ya que los usuarios deniegan cada vez más el seguimiento
Token JWT (Modo de privacidad de iOS solo):
- ❌ Android: Nunca ocurre (no soportado)
- ✅ iOS: Cuando se deniega el seguimiento o
limitedLogin: true - ✅ Respeto las preferencias de privacidad del usuario de iOS
- ❌ Contiene información básica de usuario solo
- ❌ Tiempos de expiración más cortos
- ❌ Sin acceso al Gráfico de Facebook API
- ⚠️ Ahora el escenario más común para usuarios de iOS
Comportamiento específico de plataforma:
- Aplicaciones de iOS: Deben manejar tanto tokens de acceso como tokens JWT
- Aplicaciones de Android: Solo necesitan manejar tokens de acceso
- Aplicaciones híbridas: Deben implementar ambos métodos de manejo de tokens
Requisitos de contexto seguro (Web/Capacitor)
Título de la sección “Requisitos de contexto seguro (Web/Capacitor)”Limitaciones de API de criptografía
Título de la sección “Limitaciones de API de criptografía”El flujo de inicio de sesión de Facebook actualizado requiere el Web Crypto API para la generación de nonce, que solo está disponible en contextos seguros:
// This requires secure context (HTTPS or localhost)async function sha256(message: string) { const msgBuffer = new TextEncoder().encode(message); const hashBuffer = await crypto.subtle.digest("SHA-256", msgBuffer); // ❌ Fails in insecure context // ...}Problemas en el entorno de desarrollo
Sección titulada “Problemas del Entorno de Desarrollo”Problema común: ionic serve La autenticación de Facebook se rompe con URLs HTTP
| Entorno | Crypto API Disponible | La autenticación de Facebook funciona |
|---|---|---|
http://localhost:3000 | ✅ Sí | ✅ Sí |
http://127.0.0.1:3000 | ✅ Sí | ✅ Sí |
http://192.168.1.100:3000 | ❌ No | ❌ No |
https://any-domain.com | ✅ Sí | ✅ Sí |
Soluciones para Capacitor de desarrollo
Sección titulada “Soluciones para Capacitor de desarrollo”-
Usar localhost para pruebas web
Ventana de terminal # Instead of ionic serve --host=0.0.0.0ionic serve --host=localhost -
Habilitar HTTPS en Ionic
Ventana de terminal ionic serve --ssl -
Probar en dispositivos reales
Ventana de terminal # Capacitor apps run in secure context on devicesionic cap run iosionic cap run android -
Generación alternativa de nonce para desarrollo
async function generateNonce() {if (typeof crypto !== 'undefined' && crypto.subtle) {// Secure context - use crypto.subtlereturn await sha256(Math.random().toString(36).substring(2, 10));} else {// Fallback for development (not secure for production)console.warn('Using fallback nonce - not secure for production');return btoa(Math.random().toString(36).substring(2, 10));}}
Nota de integración de Firebase
Sección titulada “Nota de integración de Firebase”La documentación de Firebase más reciente requiere tokens JWT con nonces para la autenticación de Facebook, independientemente de las configuraciones de inicio de sesión. Esta aproximación funciona tanto con limitedLogin: true y limitedLogin: false:
// Both modes can return JWT tokens depending on user choice const loginResult = await SocialLogin.login({ provider: 'facebook', options: { permissions: ['email', 'public_profile'], limitedLogin: false, // true = always JWT, false = depends on user tracking choice nonce: nonce } });Limitación de desarrollo: Si está utilizando ionic serve en una IP de red (no localhost), la autenticación de Facebook fallará debido a restricciones de criptografía API. Utilice localhost o HTTPS para pruebas web.
Resolución de Problemas
Sección titulada “Resolución de Problemas”Problemas y Soluciones Comunes
Sección titulada “Problemas y Soluciones Comunes”-
Errores de clave hash en Android
- Verifica que has agregado la clave hash correcta a la consola de Facebook
- Asegúrate de que hayas agregado tanto la clave hash de depuración como la de lanzamiento
- Verifica que estás utilizando el keystore correcto al generar la hash
-
El botón de inicio de sesión de Facebook no aparece
- Verifique todas las entradas del manifiesto son correctas
- Compruebe que su ID de aplicación de Facebook y Token de cliente son correctos
- Asegúrese de que ha inicializado correctamente el SDK
-
Problemas comunes de iOS
- Asegúrese de que todas las entradas de Info.plist son correctas
- Verifique que los esquemas de URL están configurados correctamente
- Compruebe que su ID de paquete coincide con lo registrado en la consola de Facebook
-
Antes de realizar pruebas, agregue usuarios de prueba en la consola de desarrolladores de Facebook
- Vaya a Roles > Usuarios de prueba
- Crear un usuario de prueba
- Use these credentials for testing
-
Pruebe tanto los builds de depuración como de liberación
- Build de depuración con clave de hash de depuración
- Build de liberación con clave de hash de liberación
- Pruebe tanto en emuladores como en dispositivos físicos
Recuerde probar el flujo de inicio de sesión completo, incluyendo:
- Inicio de sesión exitoso
- CANCELACIÓN DE INICIO DE SESIÓN
- Manejo de errores
- Funcionalidad de cierre de sesión
Siga adelante desde la configuración de inicio de sesión de Facebook
Sección titulada “Siga adelante desde la configuración de inicio de sesión de Facebook”Si estás utilizando Configuración de inicio de sesión de Facebook para planificar la autenticación y los flujos de cuenta, conectéalo con Usando @capgo/capacitor-login-social para la capacidad nativa en Usando @capgo/capacitor-login-social Usando @capgo/capacitor-login-social para el detalle de implementación en @capgo/capacitor-login-social Usando @capgo/capacitor-clave-secuestrable para el detalle de implementación en @capgo/capacitor-clave-secuestrable Usando @capgo/capacitor-biometría-nativa para el detalle de implementación en @capgo/capacitor-biometría-nativa, y Autenticación en dos factores para el detalle de implementación en la autenticación de dos factores.