Capacitor 앱에서 새로운 애플 지침에 따라 Stripe 결제 링크를 구현하는 방법
2025년 5월 1일부터, 애플은 에픽 v. 애플 사례 판결에 따라 앱 스토어 리뷰 지침을 크게 변경했습니다. 이 변경 사항은 미국의 앱 개발자에게 디지털 상품과 서비스에 대한 외부 결제 방법에 대한 링크를 제공하는 것을 허용하여 애플의 내 앱 구매 시스템에 대한 대안을 열어줍니다. 모바일 결제를 영원히 바꾼 에픽의 대결__CAPGO_KEEP_0__에서 Stripe 결제: 새로운 애플 지침
__CAPGO_KEEP_0__ 앱에서 새로운 애플 지침에 따라 Stripe 결제 링크를 구현하는 방법을 알아보세요. 새로운 애플 지침에 따라 2025년 5월 1일부터 디지털 상품 결제를 처리할 수 있습니다.
The path to this moment has been long and contentious. It all began in August 2020 when Epic Games, the creator of the wildly popular game Fortnite, deliberately violated Apple’s App Store guidelines by implementing a direct payment option that bypassed Apple’s 30% commission. Apple promptly removed Fortnite from the App Store, and Epic responded by filing a lawsuit challenging Apple’s control over iOS app distribution and in-app payments.
여러 해 동안의 법적 분쟁, 항소, 그리고 반항소로 이어진 끝에, 법원은 iOS 앱 배포 및 인앱 결제에 대한 Apple의 통제를 주장하는 Epic의 소송을 기각하고 Apple이 개발자에게 앱 외부의 대안 결제 방법을 사용하도록 허용해야 한다고 판결했습니다. 이 결정은 2008년부터 시작된 App Store 생태계의 기본적인 금융 모델을 바꾸는 것입니다.
최종 판결 - 더 이상 항소할 수 없음
이 판결이 특히 중요한 이유는 그것이 최종적이고 더 이상 항소할 수 없다는 것입니다. Apple의 항소가 2025년 초에 미국 대법원에서 기각되었으며, 이로써 하급 법원의 판결이 법률의 원칙이 됩니다. 따라서 개발자는 Apple이 이 결정에 대한 더 이상의 법적 도전을 통해 이를 뒤집을 수 없다는 것을 알면서도 외부 결제 방법을 구현할 수 있습니다.
법률에 의해 보장되는 평등한 대우
중요한 것은 Apple이 외부 결제 방법을 사용하는 앱에 대해 차별할 수 없다는 점입니다. 법원은 Apple이 다음과 같은 것을 금지하는 것을 명령했습니다:
- __CAPGO_KEEP_0__
- __CAPGO_KEEP_0__
- __CAPGO_KEEP_0__
- __CAPGO_KEEP_0__
__CAPGO_KEEP_0__
__CAPGO_KEEP_0__
__CAPGO_KEEP_0__
__CAPGO_KEEP_0__
-
__CAPGO_KEEP_0____CAPGO_KEEP_0__
-
__CAPGO_KEEP_0__: Apple에서 애플리케이션의 지불금을 받는 데 45-90일이 걸리지만, Stripe은 2-3일 이내에 지불금을 은행 계좌에 입금합니다.
-
Simplified Refund Process: Apple의 복잡한 환불 시스템 대신 Stripe의 대시보드에서 환불을 직접 처리하세요.
이러한 비용 절감과 향상된 현금 흐름은 특히 작은 개발자와 기업에게 게임 체이저일 수 있습니다.
이 기사에서는 Capacitor 앱에서 Stripe Payment Links를 구현하는 방법을 설명합니다. 이 구현은 Apple의 업데이트된 지침을 준수하면서 이러한 새로운 규칙을 활용할 수 있도록 합니다. updated guidelines.
이 구현은 Stripe의 Payment Links 공식 문서를 기반으로 하며 __CAPGO_KEEP_0__ 앱에 적합하게 수정되었습니다. Understanding the New Guidelines, adapted specifically for Capacitor apps.
Key points to understand:
__CAPGO_KEEP_0__
__CAPGO_KEEP_0__
- 이제 앱 내에서 디지털 상품에 대한 외부 결제 옵션에 연결할 수 있습니다.
- 이 규칙은 미국 앱 스토어에만 적용됩니다.
- 애플의 공개 요구 사항에 따라야 합니다.
- 고객 지원 및 환불 처리에 대한 모든 책임은 여전히 당신에게 있습니다.
Capacitor 앱에서 Stripe 결제 링크 설정
기술 구현에 대해 자세히 알아보겠습니다.
1단계: Stripe 대시보드에서 결제 링크 만들기
먼저 Stripe 대시보드에서 결제 링크를 만드세요.
- Stripe 대시보드의 결제 링크 섹션으로 이동하세요.
- 새 결제 링크를 만들기 위해 '+' 버튼을 클릭하세요.
- 제품 또는 구독 정보를 정의하세요.
- 결제 후 설정에서 '확인 페이지 표시하지 않기'를 선택하세요.
- 성공 URL로 universal 링크를 설정하세요 (이것은 나중에 설정할 것입니다)
- 결제 링크를 생성하기 위해 "Create Link"을 클릭하세요
2단계: Capacitor 앱에서 Universal 링크 설정
결제 완료 후 사용자에게 앱으로 되돌아가도록 하려면 universal 링크를 구성하세요:
- 결제 링크를 생성하기 위해 "Create Link"을 클릭하세요
apple-app-site-association__CAPGO_KEEP_0__ 앱에 universal 링크를 처리하도록 구성하려면 entitlement을 추가하세요. 먼저, Xcode 프로젝트에서
{
"applinks": {
"apps": [],
"details": [
{
"appIDs": ["YOURTEAMID.com.yourdomain.yourapp"],
"components": [
{
"/": "/checkout_redirect*",
"comment": "Matches any URL whose path starts with /checkout_redirect"
}
]
}
]
}
}
-
__CAPGO_KEEP_0__ 앱에 entitlement을 추가하려면 Xcode 프로젝트를 열어야 합니다.
https://yourdomain.com/.well-known/apple-app-site-association -
Xcode 프로젝트를 열어
application/json -
Configure your Capacitor app to handle universal links by adding the proper entitlement. First, in your
capacitor.config.ts:
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
// Your existing app configuration (appId, appName, etc.)
plugins: {
Geolocation: {
// Request precise location access on iOS
iosLocationAccuracy: 'reduced'
}
}
};
export default config;
- Xcode 프로젝트에서 "Associated Domains" entitlement을 추가하세요
- Xcode 프로젝트를 열어
- 앱 대상 선택
- ‘Signing 및 Capabilities’로 이동하세요
- '+ 기능'을 클릭하고 '연관된 도메인'을 선택하세요
- 추가
applinks:yourdomain.com
3단계: 폴백 페이지 만들기
앱이 설치되지 않은 경우를 처리하기 위해 리다이렉트 URL에서 폴백 페이지를 만드세요:
<!DOCTYPE html>
<html>
<head>
<title>Redirecting...</title>
<meta http-equiv="refresh" content="0;url=https://yourdomain.com/app-download">
</head>
<body>
<p>Redirecting to download page...</p>
</body>
</html>
4단계: Capacitor 앱에 결제 버튼을 Implement하세요
앱에 결제 버튼을 추가하세요:
import { Capacitor } from '@capacitor/core';
export async function openPaymentLink(userEmail, userId) {
// Use your actual Stripe payment link
const baseUrl = 'https://buy.stripe.com/your_payment_link';
// Add URL parameters to customize the experience
const params = new URLSearchParams({
prefilled_email: encodeURIComponent(userEmail),
client_reference_id: userId
});
const fullUrl = `${baseUrl}?${params.toString()}`;
// Simple window.open works in both web and Capacitor
// Using _blank opens in Safari on iOS which is important for users with saved Stripe Link credentials
window.open(fullUrl, '_blank');
}
사파리 왜 중요합니까?: 사용자가 이전에 스티프 링크와 함께 결제 정보를 저장한 경우, 사용자가 사파리(via )를 통해 결제 링크를 열 때 자동으로 인증 정보가 사용할 수 있습니다.
window.open사파리(via )를 사용하여 결제 링크를 열 때, 사용자가 이전에 스티프 링크와 함께 결제 정보를 저장한 경우, 사용자가 자동으로 인증 정보를 사용할 수 있습니다.
5단계: 앱에서 Universal 링크를 처리하세요
사용자가 리다이렉트되면 앱을 구성하여 Universal 링크를 처리하세요:
- 먼저 App 플러그인을 설치하세요:
npm install @capacitor/app
- App 플러그인을 앱에 등록하세요:
import { App } from '@capacitor/app';
// In your initialization code
App.addListener('appUrlOpen', (event) => {
// Example URL: https://yourdomain.com/checkout_redirect?session_id=cs_test_...
const url = new URL(event.url);
if (url.pathname.startsWith('/checkout_redirect')) {
// Extract any parameters you need
const params = new URLSearchParams(url.search);
const sessionId = params.get('session_id');
// Handle successful payment
if (sessionId) {
// Verify the payment on your server if needed
verifyPayment(sessionId);
// Update UI to reflect successful purchase
updatePurchaseStatus(true);
}
}
});
async function verifyPayment(sessionId) {
// Call your backend to verify the payment
// This is optional if you're relying on webhooks
}
function updatePurchaseStatus(success) {
// Update your app UI to reflect purchase status
}
6단계: 주문 완료를 위한 웹후크 설정
마지막으로, 서버에서 성공적인 결제를 처리하는 웹후크를 구성하세요:
// Using Express.js as an example
const express = require('express');
const stripe = require('stripe')('sk_test_your_stripe_secret_key');
const app = express();
// Use raw body parser for webhook signature verification
app.post('/webhook', express.raw({type: 'application/json'}), async (req, res) => {
const sig = req.headers['stripe-signature'];
const webhookSecret = 'whsec_your_webhook_secret';
let event;
try {
event = stripe.webhooks.constructEvent(req.body, sig, webhookSecret);
} catch (err) {
console.log(`Webhook Error: ${err.message}`);
return res.status(400).send(`Webhook Error: ${err.message}`);
}
// Handle the checkout.session.completed event
if (event.type === 'checkout.session.completed') {
const session = event.data.object;
// Retrieve client_reference_id (your user ID)
const userId = session.client_reference_id;
// Grant access to the purchased content
await grantAccess(userId, session.id);
}
res.status(200).send();
});
async function grantAccess(userId, sessionId) {
// Your logic to grant access to the purchased content
// This could be updating a database, sending a notification, etc.
}
app.listen(3000, () => console.log('Webhook server running on port 3000'));
안드로이드 호환성
우리는 분명히 말할 것입니다: 에픽 v. 애플 판결은 모바일 결제 환경을根本적으로 바꾸었습니다. iOS 앱에 직접적인 영향을 미치는 것은 물론, 안드로이드 개발자들이 외부 결제 방법을 사용해 왔던 것을 강화시킵니다.
안드로이드 개발자들은 이제 외부 결제 솔루션을 완벽한 자신감으로 implement할 수 있습니다. 애플 판결에 의해 설정된 전제는 플랫폼을 막론하고 개발자들이 잠재적인 미래 제한으로부터 보호합니다. 이 법적 판결은 많은 안드로이드 개발자들이 이미 몇 년 동안 수행해 왔던 것과 동일한 것을 확인했습니다 - 낮은 수수료의 대안 결제 옵션을 제공합니다.
구글 플레이 스토어는 항상 애플보다 외부 결제 방법에 대한 제한이 적었으며, 법적 전제가established되었으므로, 스트라이프 또는 다른 외부 결제 제공자들을 안드로이드 앱에 implement하는 데 virtually의 위험이 없습니다. 이러한 implement들을 진행할 수 있는 것은, 법적 기반에 서 있는 것을 알기 때문입니다.
iOS에 대해 다룬 implement는 안드로이드 기기에 대해 거의 동일하게 작동합니다. 구글 플레이 스토어는 외부 결제 방법에 대한 제한이 없기 때문에, 스트라이프 결제 링크에 대한 동일한 접근 방식을 사용할 수 있습니다. disclosure dialog를 필요로 하지 않습니다.
deep linking을 처리하기 위해(안드로이드에서는 universal links와 동일한 개념), 다음을 수행해야 합니다:
- 앱 링크를 설정하세요.
AndroidManifest.xml__CAPGO_KEEP_0__에서 리다이렉트 URL을 처리하는 - Capacitor에서
.well-known/assetlinks.json__CAPGO_KEEP_0__에 대한 앱의 세부 정보가 포함된 - 동일한
appUrlOpen성공적인 결제를 처리하는
Capacitor의 아름다움은 플랫폼별 구성이 구현된 후 실제 결제 흐름이 code 두 플랫폼 모두에서 동일하게 유지되는 것입니다.
결제 UI를 생성하세요.
Vue에서 다음 결제 버튼 컴포넌트를 Capacitor 앱에 추가할 수 있습니다.
<template>
<div class="payment-container">
<div class="pricing-card">
<h2 class="mb-4 text-xl font-bold">{{ product.name }}</h2>
<p class="mb-6 text-gray-600">{{ product.description }}</p>
<div class="mb-6 price-tag">
<span class="text-2xl font-bold">${{ product.price }}</span>
<span v-if="product.isSubscription" class="text-sm text-gray-500">/month</span>
</div>
<button
@click="handlePayment"
class="py-3 w-full font-medium text-white bg-indigo-600 rounded-lg transition-colors hover:bg-indigo-700"
>
Purchase Now
</button>
</div>
</div>
</template>
<script setup>
import { ref } from 'vue';
import { Dialog } from '@capacitor/dialog';
const props = defineProps({
product: {
type: Object,
required: true
},
userEmail: {
type: String,
default: ''
},
userId: {
type: String,
required: true
}
});
const isLoading = ref(false);
async function showExternalPaymentDisclosure() {
const { value } = await Dialog.confirm({
title: 'Leaving App for Payment',
message: 'You are about to leave this app to make a payment. Apple is not responsible for the privacy or security of payments that are not made through the App Store. All payment-related issues, including refunds, must be handled by our support team.',
okButtonTitle: 'Continue',
cancelButtonTitle: 'Cancel'
});
return value;
}
async function openPaymentLink() {
// Use your actual Stripe payment link
const baseUrl = 'https://buy.stripe.com/your_payment_link';
// Add URL parameters to customize the experience
const params = new URLSearchParams({
prefilled_email: encodeURIComponent(props.userEmail),
client_reference_id: props.userId
});
const fullUrl = `${baseUrl}?${params.toString()}`;
// Simple window.open works in both web and Capacitor
// Using _blank opens in Safari on iOS which is important for users with saved Stripe Link credentials
window.open(fullUrl, '_blank');
}
async function handlePayment() {
isLoading.value = true;
try {
// Only show the disclosure on iOS
if (window.Capacitor?.getPlatform() === 'ios') {
const userConfirmed = await showExternalPaymentDisclosure();
if (!userConfirmed) return;
}
await openPaymentLink();
} catch (error) {
console.error('Payment error:', error);
await Dialog.alert({
title: 'Payment Error',
message: 'There was an error initiating the payment. Please try again.'
});
} finally {
isLoading.value = false;
}
}
</script>
다양한 지역을 처리하세요.
새로운 애플 지침은 미국 앱 스토어에만 적용되므로 사용자 지역을 감지하고 적절한 결제 방법을 적용하는 전략이 필요합니다. IP 지리 정보를 사용하는 더 신뢰할 수 있는 방법입니다.
import { Capacitor } from '@capacitor/core';
async function determinePaymentMethod() {
// Always use Stripe for Android
if (Capacitor.getPlatform() !== 'ios') {
return 'external';
}
try {
// Use a geolocation service to determine user's country
const response = await fetch('https://ipapi.co/json/');
const locationData = await response.json();
// Check if the user is in the United States
if (locationData.country_code === 'US') {
return 'external'; // Can use Stripe Payment Links
} else {
return 'iap'; // Must use In-App Purchases
}
} catch (error) {
console.error('Error detecting region:', error);
return 'iap'; // Default to IAP to be safe
}
}
export async function processPayment(product, userEmail, userId) {
const paymentMethod = await determinePaymentMethod();
if (paymentMethod === 'external') {
// Use Stripe Payment Links
await initiateExternalPayment(userEmail, userId);
} else {
// Use Apple's In-App Purchase
await initiateInAppPurchase(product.appleProductId);
}
}
이 접근법은 무료 ipapi.co __CAPGO_KEEP_0__ 국가를 식별하기 위한 서비스입니다. 사용자의 IP 주소를 기반으로 국가를 식별할 수 있습니다. 다른 지리 정보 서비스인 MaxMind를 사용하거나, 보안을 강화하기 위해 서버 측에서 이 체크를 구현할 수도 있습니다.
주의: IP 기반의 지리 정보는 항상 100% 정확하지 않습니다. mission-critical 애플리케이션을 위한 경우, 여러 감지 방법을 사용하거나 사용자가 지역을 수동으로 선택할 수 있도록 허용하는 것을 고려해 보세요.
더 정확한 위치 감지에 대한 Capacitor 플러그인
더 정확한 위치 감지를 위해 Capacitor 지리 정보 플러그인을 사용할 수 있습니다. @capgo/nativegeocoder와 함께 사용하여 사용자의 국가를 더 높은 정확도로 식별할 수 있습니다.
- 먼저 필요한 플러그인을 설치하세요.
npm install @capacitor/geolocation @capgo/nativegeocoder
- Capacitor 프로젝트에서 플러그인을 구성하세요. 다음을 프로젝트에 추가하세요.
capacitor.config.ts:
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
// Your existing app configuration (appId, appName, etc.)
plugins: {
Geolocation: {
// Request precise location access on iOS
iosLocationAccuracy: 'reduced'
}
}
};
export default config;
- 위치 기반 지역 감지를 구현하세요.
import { Capacitor } from '@capacitor/core';
import { Geolocation } from '@capacitor/geolocation';
import { NativeGeocoder } from '@capgo/nativegeocoder';
async function isUserInUSA() {
try {
// Request permission first
const permissionStatus = await Geolocation.requestPermissions();
if (permissionStatus.location === 'granted') {
// Get current position
const position = await Geolocation.getCurrentPosition({
timeout: 10000,
enableHighAccuracy: false
});
// Use NativeGeocoder to reverse geocode the coordinates
const results = await NativeGeocoder.reverseGeocode({
latitude: position.coords.latitude,
longitude: position.coords.longitude,
useLocale: true,
maxResults: 1
});
if (results.addresses.length > 0) {
// Check if the user is in the USA
return results.addresses[0].countryCode === 'US';
}
}
// If we couldn't determine location or permission denied, fall back to IP detection
return await isUserInUSAByIP();
} catch (error) {
console.error('Error detecting location:', error);
// Fall back to IP detection on error
return await isUserInUSAByIP();
}
}
async function isUserInUSAByIP() {
try {
const response = await fetch('https://ipapi.co/json/');
const data = await response.json();
return data.country_code === 'US';
} catch (error) {
console.error('Error detecting IP location:', error);
return false; // Default to false to be safe
}
}
export async function determinePaymentMethod() {
// Always use Stripe for Android
if (Capacitor.getPlatform() !== 'ios') {
return 'external';
}
// Check if user is in the USA
const isUSA = await isUserInUSA();
return isUSA ? 'external' : 'iap';
}
export async function processPayment(product, userEmail, userId) {
const paymentMethod = await determinePaymentMethod();
if (paymentMethod === 'external') {
// Use Stripe Payment Links
await initiateExternalPayment(userEmail, userId);
} else {
// Use Apple's In-App Purchase
await initiateInAppPurchase(product.appleProductId);
}
}
이 구현은 사용자가 물리적으로 미국에 위치한지 여부를 더 정확하게 식별하는 방법을 제공합니다. 먼저 장치의 GPS와 native geocoder를 사용하여 국가를 식별하려고 시도합니다. 실패(권한 문제 또는 기타 오류)가 발생하면 IP 기반 감지를 사용합니다.
__CAPGO_KEEP_0__에 필요한 권한을 추가하세요. info.plist (iOS) 및 AndroidManifest.xml (Android) 파일에 권한을 추가하세요.
iOS (ios/App/App/Info.plist):
<key>NSLocationWhenInUseUsageDescription</key>
<string>We need your location to determine which payment method to use based on regional availability.</string>
Android (android/app/src/main/AndroidManifest.xml):
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
이 방법을 사용하면 사용자가 새로운 Apple 지침에 따라 외부 결제 옵션을 받을 자격이 있는지 가장 정확하게 판단할 수 있는 방법입니다.
구독 관리
Capacitor 앱에서 구독 관리를 처리하는 방법
1. 구독 관리 페이지 만들기
__CAPGO_KEEP_0__ 앱에 구독 관리 페이지를 추가하여 사용자의 활성 구독을 표시합니다.
<template>
<div class="subscription-manager">
<div v-if="isLoading" class="loading-indicator">
Loading subscription data...
</div>
<div v-else-if="subscription" class="subscription-info">
<h2 class="mb-4 text-xl font-bold">Your Subscription</h2>
<div class="mb-6 plan-details">
<p><span class="font-medium">Plan:</span> {{ subscription.planName }}</p>
<p><span class="font-medium">Status:</span> {{ subscription.status }}</p>
<p><span class="font-medium">Renews:</span> {{ formatDate(subscription.currentPeriodEnd) }}</p>
</div>
<button
@click="manageSubscription"
class="py-3 w-full font-medium text-white bg-indigo-600 rounded-lg transition-colors hover:bg-indigo-700"
>
Manage Subscription
</button>
</div>
<div v-else class="no-subscription">
<p class="mb-4">You don't have an active subscription.</p>
<button
@click="goToPricingPage"
class="py-3 w-full font-medium text-white bg-indigo-600 rounded-lg transition-colors hover:bg-indigo-700"
>
View Plans
</button>
</div>
</div>
</template>
<script setup>
import { ref, onMounted } from 'vue';
import { getUserSubscription } from '../services/subscription';
const subscription = ref(null);
const isLoading = ref(true);
onMounted(async () => {
try {
const userData = await getUserSubscription();
subscription.value = userData.subscription;
} catch (error) {
console.error('Failed to load subscription:', error);
} finally {
isLoading.value = false;
}
});
function formatDate(timestamp) {
return new Date(timestamp * 1000).toLocaleDateString();
}
function manageSubscription() {
// Open Stripe Customer Portal
window.open(subscription.value.portalUrl, '_blank');
}
function goToPricingPage() {
// Navigate to pricing page
// router.push('/pricing');
}
</script>
2. 구독 관리 고객 포털
Stripe은 사용자가 구독을 관리할 수 있는 고객 포털을 제공합니다. 서버에서 이 포털에 대한 링크를 생성할 수 있습니다.
// Server-side code (Node.js)
const stripe = require('stripe')('sk_your_stripe_secret_key');
async function createPortalSession(customerId) {
const session = await stripe.billingPortal.sessions.create({
customer: customerId,
return_url: 'https://yourdomain.com/account',
});
return session.url;
}
애플 스토어 준수
Apple 지침을 준수하기 위해 구현을 확인하려면:
- 외부 구매에 대한 적절한 공개를 포함해야 합니다.
- 사용자가 앱을 떠나는 것을 알리는 모달 시트를 구현하세요 (애플의 요구 사항)
- 앱 내에서 구매한 애플의 수수료를 피하려 하지 마세요
- 사용자에게 거래에 대한 애플의 책임이 없다는 것을 명확하게 알려주세요
필요한 공개 지시 모달을 구현하는 예제입니다:
import { Dialog } from '@capacitor/dialog';
async function showExternalPaymentDisclosure() {
const { value } = await Dialog.confirm({
title: 'Leaving App for Payment',
message: 'You are about to leave this app to make a payment. Apple is not responsible for the privacy or security of payments that are not made through the App Store. All payment-related issues, including refunds, must be handled by our support team.',
okButtonTitle: 'Continue',
cancelButtonTitle: 'Cancel'
});
return value;
}
export async function initiateExternalPayment(userEmail, userId) {
const userConfirmed = await showExternalPaymentDisclosure();
if (userConfirmed) {
await openPaymentLink(userEmail, userId);
}
}
구현을 테스트하세요
구현을 테스트하려면:
- 앱 내에서 결제 버튼을 클릭하여 공개 지시를 표시하고 스트라이프 결제 페이지로 이동하는 것을 확인하세요
- 스트라이프 테스트 카드를 사용하여 테스트 결제를 완료하세요
4242 4242 4242 4242 - 결제 후 앱으로 다시 리다이렉트되어야 합니다
- 웹후크가 이벤트를 받았는지 확인하세요
checkout.session.completed결론
event
iOS 앱에서 디지털 상품에 대한 외부 결제 옵션을 사용할 수 있는 능력은 개발자에게 더 많은 유연성을 제공하는 중요한 변화입니다. 이 변화는 현재 미국 앱 스토어에 있는 앱에만 적용되지만 애플의 내 앱 구매 시스템에 대한 중요한 대안을 제공합니다.
Capacitor에서 Stripe Payment Links를 사용하여, Stripe의 강력한 결제 인프라, 낮은 처리 수수료(3% 대 30%), 빠른ayout(일 단위 대 월 단위)와 같은 이점을 누릴 수 있는 streamlined checkout 경험을 빠르게 구현할 수 있습니다.
Apple의 생태계 외부에서 발생하는 이 거래에 대한 모든 고객 지원 및 환불 문제를 직접 처리해야 합니다.
Capacitor 앱에서 Stripe Payment Links를 구현했습니까? 댓글 아래에 경험을 공유해 보세요!
FAQs
Q: 이 접근 방식은 애플의 지침과 호환되나요?
A: 2025년 5월 1일부터, 미국 앱 스토어에 배포되는 앱에서 디지털 상품 및 서비스에 대한 외부 결제 방법에 대한 링크를 포함하는 경우, 애플은 이 접근 방식이 지침과 호환되다고 허용합니다.
Q: 외부 결제 방법을 사용할 때 애플의 수수료를 지불해야 하나요?
A: 새로운 규칙의 주요 이점 중 하나는 애플의 시스템 외부에서 처리되는 결제에 대한 수수료가 면제된다는 것입니다.
Q: 이 새로운 규칙을 활용하기 위해 회사에 미국에 기반을 두고 있어야 하나요?
A: 미국 앱 스토어에서 앱이 제공되고 구매를 하는 사용자가 미국에 거주하는 경우, 어디서나 세계의 회사도 외부 결제 방법을 implement할 수 있습니다. Apple의 판결은 회사 위치가 아니라, 사용자의 위치와 앱 스토어의 위치에 적용됩니다. 따라서 유럽, 아시아, 남미, 또는 어디서나 개발자는 미국 고객을 위해 Stripe Payment Links를 implement할 수 있습니다.
Q: 미국 밖의 사용자가 외부 결제 옵션을 사용하려고 할 때 어떻게 되나요?
A: 미국 사용자만 외부 결제 옵션을 제공하기 위해 지역 감지 (기사에서 설명한 것처럼)를 implement해야 합니다. 다른 지역의 사용자는 Apple의 앱 내 결제 시스템을 계속 사용해야 합니다.
Q: 이 기능을 물리적 상품이나 앱 외부에서 소비되는 서비스에 사용할 수 있나요?
A: 물리적 상품이나 앱 외부에서 소비되는 서비스에 대해서는 Apple이 항상 외부 결제 방법을 허용했습니다 (예를 들어, 택시나 음식 배달).