clock  Mon - Sun 8.00 AM - 8.00 PM
fb
instagram
play store
pinterest

How to Integrate Stripe Payment Gateway In Laravel

writter  Sumit Dey Sarkar
Date  22 Mar 2023
Language  Laravel
How to Integrate Stripe Payment Gateway In Laravel

How to Integrate Stripe Payment Gateway In Laravel

In this tutorial we will learn how to integrate stripe payment gateway in laravel.

Integrating Stripe payment gateway in Laravel involves a few steps:

 

Step 1- Install the Stripe PHP library: To use Stripe in Laravel, you'll need to install the Stripe PHP library via Composer. Run the following command in your terminal:

composer require stripe/stripe-php

 

Step 2 - Set up your Stripe account: If you haven't already, sign up for a Stripe account at https://dashboard.stripe.com/register. Once you have created an account, you can obtain your API keys from the dashboard.

 

Step 3 - Add your Stripe API keys to your Laravel environment variables: In your .env file, add the following lines, replacing the placeholders with your actual API keys:

STRIPE_KEY=your_publishable_key
STRIPE_SECRET=your_secret_key

 

Step 4 - Create a Stripe payment form: In your view, create a form that collects the necessary payment information, such as the amount and the customer's card details. For example:

<form action="/charge" method="post">
    @csrf
    <div class="form-group">
        <label for="amount">Amount:</label>
        <input type="text" id="amount" name="amount" class="form-control">
    </div>
    <div class="form-group">
        <label for="card-element">Credit or debit card:</label>
        <div id="card-element">
            <!-- A Stripe Element will be inserted here. -->
        </div>
    </div>
    <button class="btn btn-primary">Pay Now</button>
</form>

In this example, we're using Stripe Elements to create a secure payment form. You can learn more about Stripe Elements in the Stripe documentation.

 

Step 5 - Handle the payment on the server: In your controller, create a method to handle the payment. This method will use the Stripe PHP library to create a charge using the payment information submitted in the form. For example:

use Stripe\Charge;
use Stripe\Customer;
use Stripe\Stripe;

public function charge(Request $request)
{
    Stripe::setApiKey(env('STRIPE_SECRET'));

    $customer = Customer::create([
        'email' => $request->input('email'),
        'source' => $request->input('stripeToken'),
    ]);

    $charge = Charge::create([
        'customer' => $customer->id,
        'amount' => $request->input('amount'),
        'currency' => 'usd',
    ]);

    // Do something with the $charge object, such as store it in your database.

    return view('payment.success');
}

In this example, we're using the `Stripe::setApiKey()` method to set the API key for Stripe. We then create a customer object using the customer's email and Stripe token (generated by Stripe Elements). Finally, we create a charge object using the customer's ID and the payment amount.

 

That's it! By following these steps, you can integrate Stripe payment gateway in Laravel and start accepting payments on your website.

Comments 0

Leave a comment

Coursera, Codeacademy, Udacity, W3Schools, Udemy, Alison, TheNewBoston, edX, P.S.Codewars,Freecodecamp, Managing technical debt blog, Scrimba, Codepen, Codepen/challenges, The Odin Project, htmlreference.​io, cssreference.​io, Frontend Mentor, Dev Challenges, MDN, Code Mentor, Coding Dojo, CSS Battle, Codier, Ace Frontend, Can I Use, CSS Tricks, 30 Seconds of Code,tutorialspoint, Neumorphism, Shaddows Brumm, Fancy Border Radius, Glow Generator, Clothoid Corners, Glassmorphism, Clipy, CSS Filters, Base64 Image, Quantity Queries, Animations, Cubic-Bezier, Keyframes, Wait Animate, Transition.Style, graphic design, web design, website design, website builder, web developer, web designer, webdesign, ecommerce website, web design company, website creator, website designer, responsive web design, web development company, best website design, web design software, web page design, build a website, web developer salary, design website, web design courses, how to design a website, web design inspiration, website layout, web designer salary, web application development, ecommerce website design, web agency, software development company, web design tutorial, web programming, design company, website design templates, what is web designing, web developer jobs, website developer, web design agency, freelance web developer, web design services, freelance web designer, graphic design websites, web solutions, ecommerce website development, free website design, web development courses, webdev, web developers, web development tools, website design services, developpeur web, web design london, website design ideas, web designing and programming, design a website, web design and development, web dev, web development services, homepage design, best designed websites, cheap website design, learn web design, web design templates, web design tools, web design jobs, website design inspiration, web design india, flash website, website developers, designer websites, website services, website design cost, good website design, site design, simple website design, cool website designs, modern website design, graphic designer websites, webcode, best web design software, website making, free web design software, mobile website design, learn web development, front end web developer, how to become a web developer, web developer portfolio, web development company in india, python web development, web development tutorial, website company, website design and development, web company, webdesigning, professional website design, affordable web design, best web design company, creative web design, top website designs, website design pricing, web developer tools, how to develop a website