당사 애플리케이션에서는 제품이나 서비스 구매를 위한 간편한 결제 방법을 제공해야 하는 경우가 많습니다. Stripe은 지불을 받는 좋은 옵션이 될 수 있습니다. 이번 게시물에서는 사용자를 해당 링크로 리디렉션하여 결제를 보낼 수 있도록 스트라이프 결제 링크를 생성하는 방법을 알아보겠습니다.
Stripe는 기업이 인터넷을 통해 결제를 수락할 수 있도록 온라인 결제 처리 서비스를 제공하는 기술 회사입니다. 이는 기업이 온라인 거래, 구독 및 기타 결제 관련 작업을 관리할 수 있는 도구 및 API 제품군을 제공합니다.
코드 작성을 시작하기 전에 다음 Stripe 구성 요소를 이해해야 합니다.
가격: 가격은 제품의 특정 가격 구성입니다. 이는 고객이 제품에 대해 지불할 금액뿐만 아니라 통화, 청구 주기, 가격 책정 계층과 같은 추가 가격 세부 정보를 정의합니다. 예를 들어, "커뮤니티 멤버십"이라는 서비스의 경우 두 가지 가격이 있을 수 있습니다.
결제 링크: 결제 링크는 고객이 특정 가격으로 결제할 수 있는 URL입니다. 고객이 결제 링크를 클릭하면 Stripe에서 호스팅하는 결제 페이지로 리디렉션되어 결제 정보를 입력하고 거래를 완료할 수 있습니다. 결제 링크는 이메일, 메시지 앱을 통해 공유하거나 웹사이트에 삽입할 수 있습니다.
또한 가격을 통해 '반복' 또는 '일회성' 결제 유형을 정의할 수 있습니다. "커뮤니티 멤버십 예"의 경우 연간 지불은 one_type이 될 수 있고 월별 지불은 반복될 수 있습니다. 매년 사용자는 멤버십을 갱신(또는 갱신하지 않음)하고 결제 유형을 다시 선택하게 됩니다.
스트라이프 PHP 라이브러리는 작곡가를 사용하여 설치할 수 있으므로 설치하려면 프로젝트 루트 폴더에서 다음 명령을 실행하기만 하면 됩니다.
composer require stripe/stripe-php
API 키를 검색하려면 먼저 Stripe에 등록해야 합니다. 등록한 경우 다음 단계를 수행할 수 있습니다.
먼저 제품을 생성한 다음 가격을 생성하거나 제품 이름을 가격 옵션에 포함하는 Stripe Price를 생성할 수 있습니다. 모든 과정을 볼 수 있도록 첫 번째 방법을 사용하여 코딩해 보겠습니다.
$stripe = new \Stripe\StripeClient(<your_stripe_api_key>); $product = $stripe->products->create([ 'name' => 'Community Subscription', 'description' => 'A Subscription to our community', ]); $price = $stripe->prices->create([ 'currency' => 'usd', 'unit_amount' => 5025, 'product': $product->id, 'type' => 'one_time' ]);
위 코드를 단계별로 설명해 보겠습니다.
unit_amount 매개변수에 특별한 주의가 필요합니다. Stripe 문서에서는 unit_amount에 대해 다음과 같이 설명합니다. "청구할 금액을 나타내는 센트 단위의 양의 정수(또는 무료 가격의 경우 0)입니다." 이는 가격을 unit_amount 매개변수에 전달하기 전에 가격에 100을 곱하여 센트로 변환해야 함을 의미합니다. 예를 들어 가격이 $10.99인 경우 단위 금액을 1099로 설정합니다. 이는 일반적인 문제이므로 코드를 다시 확인하여 예상치 못한 가격 문제가 발생하지 않도록 하세요.
예를 들어 부동 소수점 값을 금액으로 보유하는 "$amount" 변수가 있는 경우 다음과 같이 코딩할 수 있습니다.
$formattedAmount = (int)($amount * 100);
지금까지 올바른 형식의 금액으로 가격이 생성되었습니다. 이제 결제 링크를 생성할 차례입니다.
$stripe = new \Stripe\StripeClient(<your_stripe_api_key>); $paymentLink = $stripe->paymentLinks->create([ 'line_items' => [ [ 'price' => $price->id, 'quantity' => 1, ] ], 'after_completion' => [ 'type' => 'redirect', 'redirect' => [ 'url' => <your redirect link> ] ] ]);
단계별로 설명하자면:
We could redirect to an intermediate url which could perform some stuff such as updating our database register payment. The following code shows a simple Symfony controller which would perform the required tasks and then would redirect to the final url where the user will see that the payment has been completed.
class StripeController extends AbstractController { #[Route('/confirm-payment', name: 'confirm-payment', methods: ['GET'])] public function confirmPayment(Request $request): Response { // Here you perform the necessary stuff $succeedUrl = '...'; return new RedirectResponse($succeedUrl); } }
After we have created the PaymentLink object, we can access the string payment url by the url property:
$paymentUrl = $paymentLink->url;
In this post we have learned how to configure our php backend to easily accept payments with stripe using the stripe-php component.
Processing the payments in your php backend offers some advantages such as:
If you like my content and enjoy reading it and you are interested in learning more about PHP, you can read my ebook about how to create an operation-oriented API using PHP and the Symfony Framework. You can find it here: Building an Operation-Oriented Api using PHP and the Symfony Framework: A step-by-step guide
위 내용은 Stripe과 PHP를 사용하여 쉽게 결제를 받으세요의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!