Zum Inhalt springen

iOS App Store Review Richtlinien für IAP

Um Ihre App im App Store zu genehmigen, erfordert es sorgfältige Beachtung der Richtlinien von Apple, insbesondere bei der Implementierung von In-App-Käufen und Abonnements. Diese Anleitung deckt alles ab, was Sie wissen müssen, um die Überprüfung bei Ihrer ersten Einreichung erfolgreich zu bestehen.

iOS App Store-Bewertungsprozess

Bevor Apple Ihren Kauffluss überprüft, stellen Sie sicher, dass das App-Record selbst vollständig ist:

  • Fügen Sie ein URL der Datenschutzrichtlinie in App Store Connect
  • Fügen Sie ein Support-URL hinzu der zu realen Kontaktinformationen für Benutzer führt
  • Complete the Altersfreigabeerklärung Beantworte das Fragebogen, damit die App veröffentlicht werden kann
  • Add Kontaktinformationen für App-Überprüfungen und klare Notizen für den Rezensenten Wenn ein Login erforderlich ist, stelle einen
  • Demo-Konto bereit, das während der Überprüfung nicht abläuft Hinweis
App Store-Liste mit Richtlinien und Support-Links

Echte Bildschirmfotos vorbereiten

Abschnitt: "Echte Bildschirmfotos vorbereiten"
  • Verwenden Sie die aktuellen Bildschirmfotos aus dem tatsächlichen Build, der zur Überprüfung steht
  • Für iPhone ist 1290 x 2796 (6,7 Zoll) die einfachste Standardgröße
  • Wenn Ihre App auf iPad läuft, laden Sie auch iPad-Bildschirmfotos hoch
  • Die aktuellen akzeptierten großen iPad-Größen umfassen 2064 x 2752 (13 Zoll) und 2048 x 2732 (12,9 Zoll)
  • Strecken Sie iPhone-Bildschirmfotos nie, um eine fiktive iPad-Unterstützung vorzutäuschen

Durchführen Sie einen Trockentest der Rezensionsreise in TestFlight

Abschnitt: "Durchführen Sie einen Trockentest der Rezensionsreise in TestFlight"

Führen Sie den genauen Pfad aus, den Apple auf einem echten Gerät verfolgt:

  • Installieren Sie die neueste Version aus TestFlight
  • Melden Sie sich mit dem Rezensionskonto an, das Sie bereitstellen möchten
  • Erreichen Sie die Bezahlwand ohne versteckte Gesten oder Debug-Menüs
  • Abschließen Sie Kauf-, Wiederherstellungs- und Abonnement-Flüsse
  • Überprüfen Sie, ob die App korrekt verhält, wenn die Berechtigungen verweigert werden

Apple erfordert eine klare Preisoffenlegung vor jedem Kauf:

Pflichtelemente:

  • Preis angeben, bevor der Kaufbutton angezeigt wird
  • Rechnungsperiode anzeigen (z.B. „9,99 €/Monat“)
  • Klare Aussage darüber, was Benutzer für ihr Geld bekommen
  • Anzeigen, wann Gebühren anfallen

Häufige Ablehnung:

“Subscription pricing must be clear and upfront.”

:::Vorsicht Preis Konsistenz Alle Preise müssen übereinstimmen in:

  • App Store-Metadaten-Liste
  • In-App-Kaufschirm
  • Abonnement-Verwaltungsschirm

Even ein 1 €-Widerspruch zwischen der Store-Liste (4,99 €) und der App (5,99 €) wird automatische Ablehnung auslösen. :::

Erforderliche Offenlegungen:

  • Alle verfügbaren Abonnementebenen werden gemeinsam angezeigt
  • Klare Vergleichbarkeit der Funktionen pro Ebene
  • Keine automatische Umleitung auf Premiumebenen durch UI-Trick
  • Einfache, leicht zu lokalisierende Anweisungen zur Kündigung

UI-Design-Regeln und -Verfehlungen

Paywall mit Wiederherstellung von Kaufleistungen und rechtlichen Links

Beispiel für eine konforme UI:

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>
);
}

Erforderliche Implementierung:

Jedes App mit IAP muss eine Möglichkeit bereitstellen, damit Benutzer vorherige Kaufs anhand von vorherigen Einkäufen wiederherstellen können, ohne das Support zu kontaktieren.

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>

Warum es scheitert:

  • Die App stürzt beim Start ab
  • Der Kauffluss schlägt fehl
  • Die in den Screenshots gezeigten Funktionen funktionieren nicht

Verhütung:

  • Testen Sie auf echten Geräten (nicht nur auf Simulatoren)
  • Testen Sie alle Abonnement-Flüsse von Anfang bis Ende
  • Überprüfen Sie die Gültigkeit von Erhaltungen
  • Überprüfen Sie die Fehlerbehandlung bei Netzwerkfehlern

Warum es scheitert:

  • Bildschirme zeigen Funktionen, die nicht im aktuellen Build enthalten sind
  • Beschreibung erwähnt Funktionen, die nicht existieren
  • Preise in den Metadaten unterscheiden sich von den in-App-Preisen

Metadaten-Checkliste

Prävention:

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

Warum es scheitert:

  • Kamera/Standort/Gesundheitsdaten anfordern ohne Erläuterung
  • Erlaubnisanfragen in mehreren Bildschirmen tief verborgen
  • Vage oder allgemeine Erlaubnisbeschreibungen

Verhütung:

Aktualisieren Sie Ihr Info.plist mit klaren Erläuterungen:

Erlaubnis-Kopie, die für eine Überprüfung zu vage ist Erlaubnis-Kopie mit kläreren Erläuterungen
<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>

Warum es scheitert:

  • Behauptungen wie „Nummer 1-App in der Welt“ ohne Beweise
  • „Unbegrenzte“ Funktionen mit versteckten Grenzen
  • Taktiken mit fiktiver Dringlichkeit („Nur noch 2 Plätze frei!“)

Beispielbeschreibungen für die Beschreibung

Zusätzliche Beschreibungshinweise

Vorbeugung:

  • Seien Sie spezifisch und faktisch in Beschreibungen
  • Vermeiden Sie Superlativen ohne Beweise
  • Dränge die Benutzer nicht mit falscher Knappheit

Warum es scheitert:

  • Keine Angabe, wie man stornieren kann
  • Stornierungsbutton versteckt oder behindert
  • Mehrschrittiger Stornierungsprozess ohne Apple-Fluss

Prävention:

// 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 hat die Datenschutzanforderungen 2025 erheblich verschärft.

Für jede Erlaubnis:

  1. Warum Sie es benötigen (spezifischer Einsatzfall)
  2. Wenn es verwendet wird
  3. Wie Daten gespeichert/geshared werden
  4. Ob es optional oder erforderlich ist
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';
}

Stellen Sie sicher, dass Ihre App-Store-Privatsphäre-Etiketten genau wie folgt aussehen:

  • Kaufhistorie-Sammlung
  • E-Mail-Adressen (für Rechnungen)
  • Geräte-IDs (für Betrugsprävention)
  • Verwendungsdaten (für Analysen)

Unzutreffende Privatsphäre-Etiketten sind eine häufige Ablehnungsgrundlage im Jahr 2025. Überprüfen Sie Ihre Datensammlung sorgfältig.

Vor-Abgabeverifizierung

  1. Testen Sie alle Kaufflüsse

    • Kostenlosen Versuch
    • Kostenlosen Versuch
    • Überprüfen Sie, ob die Einführungsangebote korrekt angewendet werden
    • Testen Sie die Wiederherstellung von Kaufleistungen
    • Überprüfen Sie die Familienfreigabe (wenn aktiviert)
    • Testen Sie auf mehreren Geräten
  2. Überprüfen Sie die Preisgerechtigkeit

    • Überprüfen Sie, ob die App-Store-Metadaten mit den in-app-Preisen übereinstimmen
    • Überprüfen Sie, ob alle Währungen korrekt sind
    • Bestätigen Sie, dass die Dauer der kostenlosen Probezeit den Beschreibungen entspricht
    • Überprüfen Sie, ob die Bedingungen der Einführungsangebote genau sind
  3. Überprüfen Sie alle Kopien

    • Entfernen Sie den Platzhaltertext
    • Überprüfen Sie, ob die Behauptungen testbar sind
    • Überprüfen Sie Grammatik und Rechtschreibung
    • Stellen Sie sicher, dass Beschreibungen der aktuellen Build entsprechen
    • Entfernen Sie Erwähnungen von Konkurrenten
  4. Testen Sie Berechtigungen

    • Fordern Sie nur notwendige Berechtigungen an
    • Zeigen Sie klare Erklärungen vor der Anfrage an
    • Testen Sie 'Ablehnen'-Flüsse (die App sollte weiterhin funktionieren)
    • Überprüfen Sie, ob die Beschreibungen in Info.plist klar sind
  5. Vorbereiten Sie ein Testkonto

    • Erstellen Sie ein Rezensionskonto, das während der Rezension gültig bleibt
    • Dokumentieren Sie Anmeldeinformationen in der App-Bewertungsinformation
    • Überprüfen Sie, ob der Rezensent den Paywall erreichen und den Kaufprozess abschließen kann
    • Fügen Sie zusätzliche Konten oder App-spezifische Schalter in der Notes-Feld, wenn erforderlich
  6. Überprüfen Sie die Metadaten

    • Bildschirminhalte entsprechen der aktuellen Benutzeroberfläche
    • Die Support-URL enthält reale Kontaktinformationen
    • Die URL der Datenschutzrichtlinie ist ausgefüllt
    • Die Altersfreigabe entspricht dem Inhalt im Build
    • Die App-Videovorschau (wenn vorhanden) zeigt die aktuelle Version
    • Die Beschreibung beschreibt die Funktionen genau
    • Die Datenschutzrichtlinie ist in der App und im Laden-Listing zugänglich
  7. Schreiben Sie detaillierte Notizen für die Bewertung

    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.

App Store-Überprüfungszeitplan

Standard-Überprüfung: 24-48 Stunden Hochbelastungszeiträume: 3-5 Tage (App Store-Holiday-Veröffentlichungen) Wochenenden: Keine Überprüfungen verarbeitet Geschwindige Überprüfung: Verfügbar für kritische Fehlerbehebungen (Anfrage über App Store Connect)

Gemeinsame Status, die Sie in App Store Connect sehen werden:

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

Aktuelle Schwerpunktbereiche

Abschnitt: "Aktuelle Schwerpunktbereiche"

1. Abonnementklarheit

  • Seitliche Vergleiche von Planvergleichen erforderlich
  • Keine " dunklen Muster", die günstigere Optionen verbergen
  • Klare Ab- und Aufstiegswege

2. Metadatengenauigkeit

  • Bildschirmfotos müssen dem zu überprüfenden Build entsprechen
  • iPad-Screenshots sind erforderlich, wenn iPad-Unterstützung aktiviert ist
  • Die Support-URL und die Datenschutzrichtlinie sollten bereits vor der Einreichung live sein

3. Datenschutz und Bewertungsdetailqualität

  • Die Datenschutzmitteilungen müssen den tatsächlich von Ihren SDKs gesammelten Daten entsprechen
  • Die Kontaktinformationen und Notizen für App Review sollten auf der ersten Einreichung vollständig sein
  • Die Demo-Anmeldeinformationen müssen während der gesamten Bewertungszeit gültig bleiben

4. Einreichereife

  • Apple updates minimum SDK requirements regularly, so confirm the current deadline before uploading a release build
  • TestFlight ist der sichere Ort, um den genauen Prüferweg vor der Einreichung zu überprüfen
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. Lesen Sie die Ablehnung sorgfältig

    • Beachten Sie die spezifische Richtlinie, die zitiert wird (z.B. 3.1.1, 5.1.1)
    • Verstehen Sie genau, was Apple beanstandet hat
  2. Beheben Sie das Problem gründlich

    • Heben Sie nicht nur ein Loch auf - beheben Sie die Ursache
    • Überprüfen Sie den Fix ausgiebig
    • Dokumentieren Sie, was Sie geändert haben
  3. Antworten Sie im Resolution Center

    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. Bewerben Sie sich schnellstmöglich erneut

    • Wiederbewerbungen werden in der Regel schneller geprüft
    • In der Regel innerhalb von 24 Stunden

Wenn Sie glauben, dass die Ablehnung falsch ist:

App Store-Klarstellungsverfahren

  1. Klicken Sie auf „Berufung“ in App Store Connect
  2. Bieten Sie klare Beweise an:
    • Bildschirmfotos, die die Einhaltung nachweisen
    • Verweise auf spezifische Richtlinien
    • Erklärung, wie Sie die Anforderungen erfüllen
  3. Seien Sie professionell und faktenbasiert
  4. Fügen Sie ein Testkonto hinzu, wenn die Funktionalität schwer zu finden ist

Beispiel für eine Anfrage nach Dokumenten

Wenn Sie weiterhin Probleme haben:

Haben Sie Schwierigkeiten bei der App-Bewertung oder benötigen Sie eine persönliche Unterstützung? Buchen Sie einen Beratungstermin mit unserem Team für eine dedizierte Unterstützung mit:

  • Überprüfung und Optimierung der IAP-Implementierung
  • Vorbereitung und Strategie für die App-Store-Bewertung
  • Überprüfung des Einreichungschecklisten
  • Widerstandsaufhebungsverfahren und Beschwerden
  • Vollständige Testung und Validierung

Unsere Experten haben bereits hunderte von Apps erfolgreich bei der Überprüfung unterstützt!