Saltar a contenido

Configuración de inicio de sesión de Facebook

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)

Si no tiene ya una aplicación de Facebook creada, siga estos pasos:

  1. Crear una aplicación de Facebook

    Sigue el tutorial para Crear una aplicación

  2. 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

  3. Antes de que puedas publicar tu aplicación para el público, sigue este tutorial para publicarla

Aquí es donde encontrarás la información clave que necesitarás para la integración:

  1. CLIENT_TOKEN:

    Panel de control de desarrollador de Facebook mostrando dónde encontrar el token de cliente
  2. APP_ID:

    Panel de desarrolladores de Facebook mostrando dónde encontrar el ID de la aplicación
  3. APP_NAME:

    Panel de desarrolladores de Facebook mostrando dónde encontrar el nombre de la aplicación
  1. Agregar permiso de Internet a tu AndroidManifest.xml

    Asegúrate de que esta línea esté presente:

    <uses-permission android:name="android.permission.INTERNET"/>
  2. 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 -A

    Cuando se te pregunte por una contraseña, utiliza: android

  3. Agregar el hash de clave a tu aplicación de Facebook

    1. Ir a la consola de tu aplicación en Facebook Developers
    2. Navegar a Configuración > Básico
    3. Desplazarse hacia abajo hasta la sección "Android"
    4. Hacer clic en "Agregar plataforma" si Android no está agregado aún y rellenar los detalles
    5. Agregar el hash de clave que generaste
    6. Para producción, agregar ambos hash de clave de depuración y de lanzamiento
  4. Actualice su AndroidManifest.xml para incluir:

    <application>
    ...
    <activity android:name="com.facebook.FacebookActivity"
    android:configChanges="keyboard|keyboardHidden|screenLayout|screenSize|orientation"
    android:label="@string/app_name" />
    <activity
    android: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>
  1. Agregue la plataforma de iOS en el panel de control de desarrolladores de Facebook

    1. Vaya a la consola de desarrolladores de Facebook y agregue la plataforma de iOS
    2. Navegue a Configuración > Básico
    3. Desplácese hacia abajo hasta el final de la página y haga clic en “Agregar Plataforma”
    4. Seleccione iOS y rellene los detalles requeridos
  2. Abra su proyecto de Xcode y navegue a Info.plist

  3. 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>
  4. Modifica el AppDelegate.swift

    import FBSDKCoreKit
    @UIApplicationMain
    class AppDelegate: UIResponder, UIApplicationDelegate {
    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
    // Override point for customization after application launch.
    // Initialize Facebook SDK
    FBSDKCoreKit.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 call
    if (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)
    }
    }
    }
  1. Inicializa el inicio de sesión de Facebook en tu aplicación

    import { SocialLogin } from '@capgo/capacitor-social-login';
    // Initialize during app startup
    await SocialLogin.initialize({
    facebook: {
    appId: 'APP_ID',
    clientToken: 'CLIENT_TOKEN',
    }
    })
  2. 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
    }
    }
  3. 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 login
    async 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 getProfile llamada 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.

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.

plataformaConfiguración de inicio de sesión limitadoElección de usuario de ATTTipo de token de resultado
iOStrueCualquieraToken JWT
iOSfalsePermite el seguimientoToken de Acceso
iOSfalseNo permite el seguimientoToken JWT (auto-sobreescribir)
AndroidCualquieraN/AToken de Acceso (siempre)
  1. 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);
    }
    }
  2. 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 validation
    try {
    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;
    }
    }
  3. Validación de JWT en backend

    // Backend: Validate JWT token from Facebook
    import 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-claims
    const 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 JWT
    const userInfo = {
    id: decoded.sub,
    email: decoded.email,
    name: decoded.name,
    isJWTAuth: true
    };
    // Create your app's session/token
    const 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' });
    }
    });
  4. Manipulador de tokens de backend genérico

    // Handle both token types in your backend
    async function authenticateFacebookUser(tokenData: any) {
    if (tokenData.accessToken) {
    // Handle access token - validate with Facebook Graph API
    const 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-claims
    const 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');
    }
    }

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

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
// ...
}

Problema común: ionic serve La autenticación de Facebook se rompe con URLs HTTP

EntornoCrypto API DisponibleLa 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í
  1. Usar localhost para pruebas web

    Ventana de terminal
    # Instead of ionic serve --host=0.0.0.0
    ionic serve --host=localhost
  2. Habilitar HTTPS en Ionic

    Ventana de terminal
    ionic serve --ssl
  3. Probar en dispositivos reales

    Ventana de terminal
    # Capacitor apps run in secure context on devices
    ionic cap run ios
    ionic cap run android
  4. Generación alternativa de nonce para desarrollo

    async function generateNonce() {
    if (typeof crypto !== 'undefined' && crypto.subtle) {
    // Secure context - use crypto.subtle
    return 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));
    }
    }

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.

  1. 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
  2. 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
  3. 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
  1. 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
  2. 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.