Erhalten Sie Zahlungen einfach mit Stripe und PHP

DDD
Freigeben: 2024-09-13 22:15:07
Original
1140 Leute haben es durchsucht

Receive payments easily using Stripe and PHP

Einführung

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.

Was ist Stripe?

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:

  • Produkt: Ein Produkt stellt eine Ware oder Dienstleistung dar, die Sie verkaufen möchten. Es enthält unter anderem den Namen, die Beschreibung und Preisdetails.
  • 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:

    • Jährlich, für das Benutzer 50 $ pro Jahr zahlen würden.
    • Monatlich, für den Benutzer 3,5 $ pro Monat bezahlen würden.
  • 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.

Installieren Sie die Stripe-PHP-Komponente

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
Nach dem Login kopieren

Abrufen des Entwickler-API-Schlüssels

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:

  • Melden Sie sich bei Ihrem Stripe-Konto an.
  • Klicken Sie auf das Zahnradsymbol in der oberen rechten Ecke des Bildschirms und wählen Sie „Entwickler“.
  • Klicken Sie auf „API-Schlüssel“ und Sie können diese erstellen.

Erstellen Sie einen Stripe-Preis

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'
]);
Nach dem Login kopieren

Lassen Sie uns den obigen Code Schritt für Schritt erklären:

  • Wir erstellen einen neuen StripeClient und übergeben unsere Stripe-API-Schlüssel.
  • Dann erstellen wir ein neues Produkt mit dem Namen „Community-Abonnement“.
  • Abschließend erstellen wir einen Preis für das neu erstellte Produkt mit folgenden Merkmalen:
    • Es wird die Währung USD verwendet.
    • Es verweist über seine ID auf das erstellte Produkt.
    • Die Zahlung erfolgt nicht wiederkehrend.

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);
Nach dem Login kopieren

Erstellen Sie den Zahlungslink

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>
        ]
     ]
]);
Nach dem Login kopieren

Lassen Sie es uns Schritt für Schritt erklären:

  • 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);
    }
}
Nach dem Login kopieren

After we have created the PaymentLink object, we can access the string payment url by the url property:

$paymentUrl = $paymentLink->url;
Nach dem Login kopieren

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

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!

Quelle:dev.to
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage