Saltar al contenido

Directrices de revisión de la Tienda de aplicaciones de iOS para IAP

Proceso de revisión de la App Store de iOS

Antes de Presentar

Título de la sección “Antes de Presentar”

Finalizar la configuración de App Store Connect

Requerimientos de Apple para la aprobación en la App Store

Sección titulada “Finalizar la configuración de App Store Connect”

Antes de que Apple revise su flujo de compra, asegúrese de que el registro de la aplicación esté completo:

  • Agregar un URL de política de privacidad en App Store Connect
  • Agregar un URL de soporte que conduce a información de contacto real para los usuarios
  • Complete el cuestionario de calificación de edad para que la aplicación sea publicable
  • Agregar Detalles de contacto para la revisión de la aplicación y notas de revisión claras
  • Si es necesario el inicio de sesión, proporcione una cuenta de demostración que no caduca durante la revisión
Metadatos de la lista de la App Store con enlaces de política y soporte
  • Utilice pantallas reales del build actual en revisión
  • Para iPhone, 1290 x 2796 (6.7-inch) es el tamaño por defecto más fácil
  • Si tu aplicación se ejecuta en iPad, sube también capturas de pantalla de iPad
  • Los tamaños de iPad grandes aceptados actualmente incluyen 2064 x 2752 (13-inch) y 2048 x 2732 (12.9-inch)
  • Jamás estire capturas de pantalla de iPhone para fingir soporte de iPad

Realiza un recorrido seco de la experiencia del revisor en TestFlight

Título de la sección “Realiza un recorrido seco de la experiencia del revisor en TestFlight”

Ejecuta el camino exacto que seguirá Apple en un dispositivo real:

  • Instala la última versión desde TestFlight
  • Inicia sesión con la cuenta de revisión que planeas proporcionar
  • Accede a la pantalla de pago sin gestos ocultos ni menús de depuración
  • Flujos de compra, restauración y gestión de suscripciones protegidos
  • Verificar que la aplicación sigue comportándose correctamente si se deniegan los permisos

Apple requiere una transparencia de precios cristalina antes de cualquier compra:

Elementos imprescindibles:

  • Muestra el precio exacto antes del botón de compra
  • Muestra la frecuencia de facturación (por ejemplo, “$9.99/mes”)
  • Establece con claridad qué obtienen los usuarios por su dinero
  • Indica cuándo se producirán los cargos

Rechazo Común:

“El precio de la suscripción debe ser claro y transparente.”

:::caution Consistencia de Precios Todos los precios deben coincidir en:

  • Lista de metadatos de la tienda de aplicaciones
  • Pantallas de compras en la aplicación
  • Pantallas de gestión de suscripciones

Even una diferencia de $1 entre la lista de la tienda ($4.99) y la aplicación ($5.99) desencadenará un rechazo automático. :::

Discusiones Requeridas:

  • Todas las opciones de suscripción disponibles se muestran juntas
  • Comparación clara de características por nivel de suscripción
  • No auto-defaulting a capas premium a través de trucos de interfaz de usuario
  • Instrucciones de cancelación fáciles de encontrar

Consejos de diseño de interfaz de usuario

Paywall con restaurar compras y enlaces legales

Ejemplo de interfaz de usuario conforme:

import { NativePurchases } from '@capgo/native-purchases';
function SubscriptionScreen() {
return (
<div>
<h2>Choose Your Plan</h2>
{/* Show all tiers equally */}
<PlanCard
title="Basic"
price="$4.99/month"
features={['Feature A', 'Feature B']}
/>
<PlanCard
title="Premium"
price="$9.99/month"
features={['All Basic', 'Feature C', 'Feature D']}
highlighted={false} // Don't force premium
/>
{/* Clear cancellation info */}
<Text>
Cancel anytime in Settings > Subscriptions.
No refunds for partial periods.
</Text>
</div>
);
}

Implementación requerida:

Cada aplicación con IAP debe proporcionar una forma para que los usuarios restauren compras anteriores sin contactar con el soporte.

import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
async function restorePurchases() {
try {
await NativePurchases.restorePurchases();
const { purchases } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.SUBS,
});
const activeSub = purchases.find(
(purchase) => purchase.isActive && purchase.expirationDate,
);
if (activeSub) {
unlockPremiumFeatures();
showMessage('Purchases restored successfully!');
return;
}
const { purchases: iaps } = await NativePurchases.getPurchases({
productType: PURCHASE_TYPE.INAPP,
});
const hasIap = iaps.some((purchase) => purchase.productIdentifier === 'premium_unlock');
showMessage(
hasIap ? 'Premium purchase restored!' : 'No previous purchases found.',
);
} catch (error) {
showError('Failed to restore purchases. Please try again.');
}
}
// Add a visible "Restore Purchases" button
<Button onClick={restorePurchases}>
Restore Purchases
</Button>

1. La aplicación se cae o no funciona correctamente

Sección titulada “1. La aplicación se cae o no funciona correctamente”

¿Por qué falla?:

  • La aplicación se cae al iniciar
  • El flujo de compra no se completa
  • Las características mostradas en las capturas de pantalla no funcionan

Prevención:

  • Prueba en dispositivos reales (no solo simuladores)
  • Prueba todos los flujos de suscripción de principio a fin
  • Verifica que la validación de recibos funcione
  • Revisa el manejo de errores de red

Por qué Falla:

  • Capturas de pantalla muestran características que no están en la versión actual
  • La descripción menciona funcionalidades que no existen
  • El precio en los metadatos difiere del precio en la aplicación

Lista de Verificación de Metadatos

Prevención:

// Document exactly what's in each tier
const SUBSCRIPTION_FEATURES = {
basic: ['Ad-free', 'Cloud sync', 'Basic themes'],
premium: ['Ad-free', 'Cloud sync', 'All themes', 'Priority support']
};
// Use these in both your app AND App Store description

Por qué Falla:

  • Solicitando cámara/ubicación/salud sin explicación
  • Solicitudes de permiso enterradas en varias pantallas
  • Descripciones de permiso vagas o generales

Prevención:

Actualice su Info.plist con explicaciones claras:

Descripciones de permiso que son demasiado vagas para revisión Descripciones de permiso con explicaciones más claras
<key>NSCameraUsageDescription</key>
<string>Camera access is needed to scan product barcodes for quick subscription upgrades.</string>
<key>NSLocationWhenInUseUsageDescription</key>
<string>Location helps us show relevant local content in your Premium subscription.</string>

Por qué falla:

  • Reclamos como “la aplicación número 1 en el mundo” sin pruebas
  • Características “ilimitadas” con límites ocultos
  • Tácticas de urgencia falsas (“Solo quedan 2 plazas!”)

Ejemplos de Directrices de Descripción

Directrices de Descripción Adicionales

Prevención:

  • Sea específico y factual en las descripciones
  • Evite superlativos sin evidencia
  • No presione a los usuarios con escasez falsa

Por qué Falla:

  • No mención de cómo cancelar
  • Botón de cancelación oculto o obstruido
  • Proceso de cancelación de varios pasos sin el flujo nativo de Apple

Prevención:

// Always inform users about cancellation
function SubscriptionInfo() {
return (
<div>
<h3>How to Cancel</h3>
<ol>
<li>Open iPhone Settings</li>
<li>Tap your name at the top</li>
<li>Tap Subscriptions</li>
<li>Select this app and tap Cancel</li>
</ol>
<p>Or manage directly in the App Store app.</p>
<Button onClick={openSubscriptionManagement}>
Manage Subscription in Settings
</Button>
</div>
);
}
async function openSubscriptionManagement() {
// Direct link to iOS subscription management
await NativePurchases.showManageSubscriptions();
}

Apple ha reforzado significativamente los requisitos de privacidad en 2025.

Para Cada Permiso:

  1. ¿Por qué lo necesita (uso específico de caso)
  2. When se utilizará
  3. Cómo se almacena o comparte los datos
  4. ¿Es obligatorio o opcional?
async function requestCameraPermission() {
// Show explanation BEFORE requesting
await showDialog({
title: 'Camera Access',
message: 'We need camera access to let you scan barcodes for quick product lookup. Your photos are never uploaded or stored.',
buttons: ['Not Now', 'Allow']
});
// Then request permission
const result = await Camera.requestPermissions();
return result.camera === 'granted';
}

Asegúrese de que las etiquetas de privacidad de la Tienda de Aplicaciones reflejen con precisión:

  • La recopilación de historial de compras
  • Direcciones de correo electrónico (para facturas)
  • IDs de dispositivo (para prevención de fraude)
  • Datos de uso (para análisis)

Los etiquetas de privacidad inexactas son una razón común de rechazo en 2025. Audita cuidadosamente la recopilación de datos.

Lista de Verificación Pre-Envío

  1. Prueba todos los flujos de compra

    • Compre cada nivel de suscripción
    • Prueba las pruebas gratuitas
    • Verifique que las ofertas iniciales se apliquen correctamente
    • Prueba la restauración de compras
    • Verifique que la Compartición Familiar (si habilitada) funcione correctamente
    • Prueba en múltiples dispositivos
  2. Verificar Consistencia de Precios

    • Comprobar que los metadatos de la Tienda de Aplicaciones coinciden con los precios en la aplicación
    • Verificar que todos los monedas estén correctos
    • Confirmar que las duraciones de la prueba gratuita coinciden con las descripciones
    • Comprobar que los términos de la oferta inicial son precisos
  3. Revisar Todo el Texto

    • Eliminar texto de reemplazo
    • Verificar que las afirmaciones sean probables
    • Comprobar gramática y ortografía
    • Asegurarse de que las descripciones coincidan con la versión actual
    • Eliminar menciones de competidores
  4. Probar Permisos

    • Solicite solo permisos necesarios
    • Mostrar explicaciones claras antes de solicitar permisos
    • Prueba los flujos de denegación (la aplicación debería seguir funcionando)
    • Verifica que las descripciones de Info.plist sean claras
  5. Prepara Cuenta de Prueba

    • Crear una cuenta de revisión que permanezca válida durante la revisión
    • Documentar las credenciales de inicio de sesión en la información de revisión de la aplicación
    • Verifica que el revisor pueda llegar a la pantalla de pago y completar el flujo de compra
    • Incluir cuentas adicionales o switches específicos de la aplicación en el campo de Notas si es necesario
  6. Verifica la Metadata

    • Las capturas de pantalla coinciden con la interfaz de usuario actual
    • La URL de soporte incluye información de contacto real
    • La URL de la política de privacidad está rellenada
    • La calificación de edad coincide con el contenido en la compilación
    • La vista previa del aplicativo (si la hay) muestra la versión actual
    • La descripción describe con precisión las características
    • La política de privacidad está accesible desde la aplicación y desde la lista de la tienda
  7. Escribe Notas de Revisión Detalladas

    Contact:
    Name: Jane Developer
    Email: review@yourapp.com
    Phone: +1 555-0100
    Test Account:
    Email: reviewer@test.com
    Password: TestPass123!
    This account does not expire during review.
    Testing Instructions:
    1. Log in with test account above
    2. Tap "Upgrade to Premium" button
    3. Select "Monthly Premium" subscription
    4. Complete purchase (no charge in sandbox)
    5. Verify premium features unlock
    Note: Subscription pricing is clearly shown before purchase.
    Cancellation instructions are in Settings > Account.

Cronología de Revisión de la Tienda de Aplicaciones

Revisión estándar: 24-48 horas Periodos de Pico: 3-5 días (lanzamientos de vacaciones de la Tienda de Aplicaciones) Fin de semana: No se procesan reseñas Revisión Acelerada: Disponible para correcciones de errores críticos (solicitar a través de App Store Connect)

Estados comunes que verá en App Store Connect:

  • Waiting for Review
  • In Review
  • Pending Developer Release
  • Rejected

1. Claridad de Suscripción

  • Se requieren comparaciones de planes de lado a lado
  • No se deben utilizar patrones oscuros que oculten opciones más económicas
  • Deben estar claros los caminos de descenso y ascenso

2. Precisión de Metadatos

  • Las capturas de pantalla deben coincidir con la versión que se está revisando
  • Se requieren capturas de pantalla de iPad si se habilita el soporte para iPad
  • La URL de soporte y la política de privacidad deben estar ya disponibles antes de la presentación

3. Calidad de Privacidad y Detalles de Revisión

  • Las declaraciones de privacidad deben coincidir con lo que realmente recopilan sus SDKs
  • La información de contacto y notas de la revisión de la aplicación deben estar completas en la primera presentación
  • Las credenciales de la demo deben permanecer válidas durante toda la ventana de revisión

4. Preparación de la presentación

  • Apple actualiza regularmente los requisitos mínimos SDK, así que confirme la fecha límite actual antes de subir una versión de lanzamiento
  • TestFlight es el lugar más seguro para verificar el camino exacto del revisor antes de presentar

Prácticas recomendadas para el plugin de compras nativas

Sección titulada “Prácticas recomendadas para el plugin de compras nativas”
import { NativePurchases, PURCHASE_TYPE } from '@capgo/native-purchases';
async function handlePurchase(productId: string) {
try {
const transaction = await NativePurchases.purchaseProduct({
productIdentifier: productId,
productType: PURCHASE_TYPE.SUBS,
});
// Success
await validateReceiptOnServer(transaction.receipt);
showSuccess('Subscription activated!');
unlockFeatures();
} catch (error: any) {
// Handle specific error cases
if (error.code === 'USER_CANCELLED') {
// User cancelled - don't show error
console.log('Purchase cancelled by user');
} else if (error.code === 'PAYMENT_PENDING') {
showInfo('Payment is pending. Please check back later.');
} else if (error.code === 'PRODUCT_ALREADY_PURCHASED') {
// Restore instead
await NativePurchases.restorePurchases();
} else {
// Show user-friendly error
showError('Unable to complete purchase. Please try again.');
}
}
}
function PurchaseButton({ productId }: { productId: string }) {
const [loading, setLoading] = useState(false);
const handlePurchase = async () => {
setLoading(true);
try {
await NativePurchases.purchaseProduct({ productIdentifier: productId });
} finally {
setLoading(false);
}
};
return (
<button onClick={handlePurchase} disabled={loading}>
{loading ? 'Processing...' : 'Subscribe Now'}
</button>
);
}
function SubscriptionTerms() {
return (
<div className="terms">
<p>
Subscription automatically renews unless cancelled at least 24 hours
before the end of the current period.
</p>
<p>
Your account will be charged for renewal within 24 hours prior to
the end of the current period.
</p>
<p>
Subscriptions may be managed by the user and auto-renewal may be
turned off in Account Settings after purchase.
</p>
<p>
<a href="/terms">Terms of Service</a> |
<a href="/privacy">Privacy Policy</a>
</p>
</div>
);
}
  1. Lee la rechaza con cuidado

    • Nota la guía específica citada (por ejemplo, 3.1.1, 5.1.1)
    • Entiende exactamente qué Apple marcó
  2. Repara el problema exhaustivamente

    • No solo parche - soluciona la causa raíz
    • Prueba la solución exhaustivamente
    • Documenta los cambios que realizaste
  3. Responder en el Centro de Resolución

    Thank you for your feedback. I have addressed the issue:
    Issue: Subscription pricing not clear upfront
    Fix: Added explicit pricing display on subscription selection
    screen showing "$9.99/month" before purchase button. Also added
    cancellation instructions on the same screen.
    The changes are in this submission and can be tested using the
    provided test account.
  4. Reenviar con prontitud

    • Las reenvíos suelen ser revisados más rápido
    • Suele ser dentro de 24 horas

Si crees que la rechazo es incorrecto:

Proceso de Aclaración de la Tienda de Aplicaciones

  1. Haga clic en ‘Solicitar Revisión’ en App Store Connect
  2. Proporcione evidencia clara:
    • Pantallas de captura que muestran el cumplimiento
    • Referencias a pautas específicas
    • Explicación de cómo cumple con los requisitos
  3. Sea profesional y factual
  4. Incluya cuenta de prueba si la funcionalidad es difícil de encontrar

Ejemplo de solicitud de documentos

Si aún tienes problemas:

¿Tiene dificultades con la revisión de la aplicación o necesita asistencia personalizada? Reserve una llamada de consultación con nuestro equipo para obtener soporte dedicado con:

  • Revisión y optimización de la implementación de IAP
  • Preparación y estrategia de revisión de la tienda App Store
  • Revisión del checklist de presentación
  • Resolución de rechazos y recursos de apelación
  • Pruebas y validación completas

Nuestros expertos han ayudado con éxito a cientos de aplicaciones a superar la revisión!

Siga adelante desde las directrices de revisión de la tienda App Store de iOS para IAP

Mantén el ritmo desde las Directrices de Revisión de la Tienda de Aplicaciones de iOS para IAP

Si estás utilizando Directrices de Revisión de la Tienda de Aplicaciones de iOS para IAP para planificar la aprobación y distribución de la tienda, conecta con Usando @capgo/native-purchases para la capacidad nativa en Usando @capgo/native-purchases, @capgo/capacitor-in-app-review para el detalle de implementación en @capgo/capacitor-in-app-review, Usando @capgo/capacitor-in-app-review para la capacidad nativa en Usando @capgo/capacitor-in-app-review, @capgo/capacitor-native-market para el detalle de implementación en @capgo/capacitor-native-market Usando @capgo/capacitor-native-market para la capacidad nativa en Usando @capgo/capacitor-native-market.