>PHP 프레임워크 >Laravel >Laravel 개발: Laravel Cashier를 사용하여 구독 결제를 구현하는 방법은 무엇입니까?

Laravel 개발: Laravel Cashier를 사용하여 구독 결제를 구현하는 방법은 무엇입니까?

WBOY
WBOY원래의
2023-06-13 14:39:371391검색

Laravel은 웹 애플리케이션 개발 프로세스를 크게 단순화하는 인기 있는 PHP 프레임워크입니다. Laravel Cashier는 구독 결제 처리 기능을 제공하는 결제 처리 라이브러리입니다. Stripe과 통합되어 사용자가 구독 기능이 있는 애플리케이션을 실행할 수 있습니다. 이 글에서는 Laravel Cashier를 사용하여 구독 결제를 구현하는 방법을 소개합니다.

  1. Stripe 계정 만들기

Laravel Cashier를 사용하기 전에 먼저 Stripe 계정을 만들어야 합니다. Stripe은 온라인 결제 처리를 위한 클라우드 플랫폼이며 해당 API는 Laravel Cashier와 쉽게 통합될 수 있습니다. Stripe 웹사이트를 방문하여 계정을 생성하고 콘솔에 로그인하세요. 콘솔에서는 Stripe을 Laravel Cashier에 통합하는데 필요한 핵심 정보인 API Key를 확인할 수 있습니다.

  1. Laravel Cashier 설치

Composer를 사용하여 Laravel 프로젝트에 Laravel Cashier를 설치하세요. 터미널에서 Laravel 프로젝트의 루트 디렉터리로 이동하여 다음 명령을 실행합니다:

composer require laravel/cashier

위 명령을 실행한 후 Composer는 자동으로 필요한 종속성을 설치하고 프로젝트에 Laravel Cashier를 추가합니다.

  1. Laravel Cashier 구성

Laravel Cashier를 설치한 후에는 Stripe API를 올바르게 사용하도록 구성해야 합니다. 먼저, 프로젝트에서 config/services.php 파일을 열고 파일에 다음 코드를 추가하세요:

'stripe' => [
    'model' => AppModelsUser::class,
    'key' => env('STRIPE_KEY'),
    'secret' => env('STRIPE_SECRET'),
],

위 코드는 Laravel Cashier에게 Stripe를 사용하는 데 필요한 API 키와 사용자 모델을 포함하여 필요한 구성 정보를 제공합니다.

그런 다음 .env 파일에서 Stripe API 키와 Stripe Connect 클라이언트 ID를 구성합니다.

STRIPE_KEY=your-stripe-key
STRIPE_SECRET=your-stripe-secret
STRIPE_CLIENT_ID=your-stripe-client-id
  1. 구독 계획 생성

Stripe API를 통합한 후 애플리케이션에서 사용할 구독 계획을 생성해야 합니다. Stripe 콘솔에서 제품 탭으로 이동하고 새 제품을 클릭하여 제품을 생성합니다. 제품을 생성한 후 Billing 탭을 열고 New Plan을 클릭하여 계획을 생성합니다. 필요에 따라 플랜명, 가격, 기간을 입력한 후 "플랜 만들기"를 클릭하세요.

  1. 사용자 모델 업데이트

Laravel Cashier는 사용자 모델을 사용하여 구독을 관리합니다. 따라서 계속 진행하기 전에 사용자 모델에 몇 가지 메서드를 포함해야 합니다. User 모델을 열고 파일 끝에 다음 코드를 추가하세요:

use LaravelCashierBillable;

class User extends Model implements AuthenticatableContract, CanResetPasswordContract
{
    use Authenticatable, CanResetPassword, Billable; 
}

위 코드는 User 모델에서 Laravel Cashier의 Billable 특성을 사용합니다. 이를 통해 사용자 모델에서 Laravel Cashier 관련 메소드를 사용할 수 있습니다.

  1. 구독 기능 구현하기

Laravel Cashier를 사용하면 구독 기능을 구현하는 것은 매우 간단합니다. 보기에 다음 양식을 추가하기만 하면 됩니다.

<form method="POST" action="{{ route('subscribe') }}">
    {{ csrf_field() }}
    <script
        src="https://checkout.stripe.com/checkout.js" class="stripe-button"
        data-key="{{ config('services.stripe.key') }}"
        data-amount="999"
        data-name="My Awesome Website"
        data-description="Monthly Subscription"
        data-image="https://stripe.com/img/documentation/checkout/marketplace.png"
        data-locale="auto">
    </script>
</form>

위 코드는 웹사이트에 Stripe 구독 버튼을 추가합니다. 사용자가 버튼을 클릭하면 Stripe 페이지로 이동하여 구독 프로세스가 완료됩니다.

컨트롤러에서 구독 정보를 사용자 모델과 연결하려면 다음 코드를 추가하기만 하면 됩니다.

public function subscribe(Request $request)
{
    $user = $request->user();
    $user->newSubscription('main', 'plan_id')->create($request->stripeToken);
    return redirect()->back();
}

위 코드는 새 구독을 생성하고 이를 사용자 모델과 연결하며 구독 결제 정보를 Stripe에 저장합니다. 그런 다음 사용자를 다시 페이지로 리디렉션하고 애플리케이션을 계속 실행합니다.

  1. Unsubscribe

Laravel Cashier에서는 구독 취소가 매우 쉽습니다. 특정 구독을 취소하려면 컨트롤러에 다음 코드를 추가하기만 하면 됩니다.

public function cancel(Request $request)
{
    $user = $request->user();
    $user->subscription('main')->cancel();
    return redirect()->back();
}

위 코드는 특정 구독을 취소하고 사용자를 해당 페이지로 다시 리디렉션합니다.

결론

Laravel Cashier는 구독 결제 프로세스를 크게 단순화할 수 있는 강력한 결제 처리 라이브러리입니다. Stripe API를 사용하여 Laravel Cashier는 구독 프로세스를 Laravel 애플리케이션에 쉽게 통합할 수 있습니다. 이 글의 안내를 통해 Laravel Cashier를 사용하여 구독 결제 기능을 쉽게 구현할 수 있습니다.

위 내용은 Laravel 개발: Laravel Cashier를 사용하여 구독 결제를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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