Heim >Backend-Entwicklung >PHP-Tutorial >Erhalten Sie Zahlungen einfach mit Stripe und PHP
Oft müssen unsere Anwendungen eine einfache Möglichkeit bieten, Zahlungen für den Kauf von Produkten oder Dienstleistungen zu tätigen. Stripe kann eine gute Option für den Zahlungsempfang sein. In diesem Beitrag erfahren Sie, wie Sie einen Stripe-Zahlungslink erstellen, damit Sie Ihre Benutzer zu diesem Link weiterleiten können, um ihre Zahlungen zu senden.
Stripe ist ein Technologieunternehmen, das Online-Zahlungsabwicklungsdienste anbietet und es Unternehmen ermöglicht, Zahlungen über das Internet zu akzeptieren. Es bietet eine Reihe von Tools und APIs, die es Unternehmen ermöglichen, Online-Transaktionen, Abonnements und andere zahlungsbezogene Aufgaben zu verwalten.
Bevor wir mit dem Schreiben von Code beginnen, müssen wir die folgenden Stripe-Komponenten verstehen:
Preis: Ein Preis ist eine spezifische Preiskonfiguration für ein Produkt. Es definiert den Betrag, den ein Kunde für ein Produkt zahlen wird, sowie alle zusätzlichen Preisdetails wie Währung, Abrechnungszeitraum und Preisstufen. Für einen Dienst mit dem Namen „Community-Mitgliedschaft“ könnten Sie beispielsweise zwei Preise haben:
Zahlungslink: Ein Zahlungslink ist eine URL, die es Kunden ermöglicht, eine Zahlung für einen bestimmten Preis vorzunehmen. Wenn ein Kunde auf einen Zahlungslink klickt, wird er zu einer von Stripe gehosteten Zahlungsseite weitergeleitet, wo er seine Zahlungsinformationen eingeben und die Transaktion abschließen kann. Zahlungslinks können per E-Mail, über Messaging-Apps geteilt oder auf Ihrer Website eingebettet werden.
Preise ermöglichen es uns auch, die Zahlungsart zu definieren, die „wiederkehrend“ oder „einmalig“ sein kann. Für das Beispiel „Community-Mitgliedschaft“ könnte die jährliche Zahlung ein Typ sein und die monatliche könnte wiederkehrend sein. Jedes Jahr erneuerten die Benutzer ihre Mitgliedschaften (oder auch nicht) und wählten die Zahlungsart erneut.
Die Stripe-PHP-Bibliothek kann mit Composer installiert werden. Um sie zu installieren, müssen Sie einfach den folgenden Befehl in Ihrem Projektstammordner ausführen:
composer require stripe/stripe-php
Bevor Sie Ihren API-Schlüssel abrufen können, müssen Sie bei Stripe registriert sein. Sobald Sie registriert sind, können Sie den nächsten Schritten folgen:
Wir können den Stripe-Preis erstellen, indem wir zuerst das Produkt und dann den Preis erstellen oder den Produktnamen in die Preisoptionen einbetten. Lassen Sie es uns mit der ersten Methode codieren, damit wir den gesamten Prozess sehen können.
$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' ]);
Lassen Sie uns den obigen Code Schritt für Schritt erklären:
Der Parameter unit_amount verdient besondere Aufmerksamkeit. In der Stripe-Dokumentation heißt es zu „unit_amount“: „Eine positive Ganzzahl in Cent (oder 0 für einen kostenlosen Preis), die angibt, wie viel berechnet werden soll.“ Das bedeutet, dass wir den Preis mit 100 multiplizieren müssen, um ihn in Cent umzurechnen, bevor wir ihn an den Parameter „unit_amount“ übergeben. Wenn der Preis beispielsweise 10,99 $ beträgt, würden wir „unit_amount“ auf 1099 setzen. Dies ist ein häufiger Fallstrick. Überprüfen Sie daher unbedingt Ihren Code, um unerwartete Preisprobleme zu vermeiden.
Wenn Sie beispielsweise eine „$amount“-Variable haben, die einen Float-Wert als Betrag enthält, könnten Sie etwa Folgendes codieren:
$formattedAmount = (int)($amount * 100);
Bisher haben wir einen Preis mit korrekt formatiertem Betrag erstellt. Jetzt ist es an der Zeit, den Zahlungslink zu erstellen.
$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> ] ] ]);
Lassen Sie es uns Schritt für Schritt erklären:
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
Das obige ist der detaillierte Inhalt vonErhalten Sie Zahlungen einfach mit Stripe und PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!