>  기사  >  백엔드 개발  >  Stripe과 PHP를 사용하여 쉽게 결제를 받으세요

Stripe과 PHP를 사용하여 쉽게 결제를 받으세요

DDD
DDD원래의
2024-09-13 22:15:071133검색

Receive payments easily using Stripe and PHP

소개

당사 애플리케이션에서는 제품이나 서비스 구매를 위한 간편한 결제 방법을 제공해야 하는 경우가 많습니다. Stripe은 지불을 받는 좋은 옵션이 될 수 있습니다. 이번 게시물에서는 사용자를 해당 링크로 리디렉션하여 결제를 보낼 수 있도록 스트라이프 결제 링크를 생성하는 방법을 알아보겠습니다.

스트라이프란 무엇입니까?

Stripe는 기업이 인터넷을 통해 결제를 수락할 수 있도록 온라인 결제 처리 서비스를 제공하는 기술 회사입니다. 이는 기업이 온라인 거래, 구독 및 기타 결제 관련 작업을 관리할 수 있는 도구 및 API 제품군을 제공합니다.

코드 작성을 시작하기 전에 다음 Stripe 구성 요소를 이해해야 합니다.

  • 제품: 제품은 판매하려는 상품이나 서비스를 나타냅니다. 여기에는 이름, 설명, 가격 세부정보 등이 포함됩니다.
  • 가격: 가격은 제품의 특정 가격 구성입니다. 이는 고객이 제품에 대해 지불할 금액뿐만 아니라 통화, 청구 주기, 가격 책정 계층과 같은 추가 가격 세부 정보를 정의합니다. 예를 들어, "커뮤니티 멤버십"이라는 서비스의 경우 두 가지 가격이 있을 수 있습니다.

    • 사용자가 연간 50$를 지불하는 연간
    • 사용자가 한 달에 3.5$를 지불하는 월별.
  • 결제 링크: 결제 링크는 고객이 특정 가격으로 결제할 수 있는 URL입니다. 고객이 결제 링크를 클릭하면 Stripe에서 호스팅하는 결제 페이지로 리디렉션되어 결제 정보를 입력하고 거래를 완료할 수 있습니다. 결제 링크는 이메일, 메시지 앱을 통해 공유하거나 웹사이트에 삽입할 수 있습니다.

또한 가격을 통해 '반복' 또는 '일회성' 결제 유형을 정의할 수 있습니다. "커뮤니티 멤버십 예"의 경우 연간 지불은 one_type이 될 수 있고 월별 지불은 반복될 수 있습니다. 매년 사용자는 멤버십을 갱신(또는 갱신하지 않음)하고 결제 유형을 다시 선택하게 됩니다.

Stripe PHP 구성 요소 설치

스트라이프 PHP 라이브러리는 작곡가를 사용하여 설치할 수 있으므로 설치하려면 프로젝트 루트 폴더에서 다음 명령을 실행하기만 하면 됩니다.

composer require stripe/stripe-php

개발자 API 키 검색

API 키를 검색하려면 먼저 Stripe에 등록해야 합니다. 등록한 경우 다음 단계를 수행할 수 있습니다.

  • Stripe 계정에 로그인하세요.
  • 화면 오른쪽 상단의 톱니바퀴 아이콘을 클릭하고 '개발자'를 선택하세요.
  • "API 키"를 클릭하면 API 키를 생성할 수 있습니다.

스트라이프 가격 생성

먼저 제품을 생성한 다음 가격을 생성하거나 제품 이름을 가격 옵션에 포함하는 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'
]);

위 코드를 단계별로 설명해 보겠습니다.

  • 스트라이프 API 키를 전달하여 새로운 StripeClient를 생성합니다.
  • 그런 다음 "커뮤니티 구독"이라는 새 제품을 만듭니다.
  • 마지막으로 다음 기능을 갖춘 최근 생성된 제품의 가격을 생성합니다.
    • USD 통화를 사용합니다.
    • 생성된 제품을 ID로 참조합니다.
    • 결제는 반복되지 않습니다.

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 create the StripeClient object as before.
  • Then, we create the payment link by using the following options:
    • line_items: Here you can include all the items we want to add for selling. In this case we only add the created price and we only sell one unit.
    • after_completion: We instruct Stripe to redirect to an url after the payment is completed.

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;

Conclusion

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:

  • Keep sensitive payment information, such as the API keys, secure.
  • Gives more control over the payment flow and allows for greater flexibility in handling different payment scenarios.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.