How To Integrate Stripe Payment Gateway In Laravel 8


Today we learn Stripe payment gateway integration in Laravel example. In this tutorial, we will show you how to use stripe payment gateway in laravel.

You will learn step by step integrate stripe payment gateway in laravel 8.

Stripe payment gateway is the most popular payment gateway which is integrated into many websites, Stripe payment is easy to integrate any website like e-commerce, etc. Stripe is a very simple and most powerful and flexible payment gateway.

How To Integrate Stripe Payment Gateway In Laravel 8

Stripe Payment Gateway Integration In Laravel 8 With example

  • Step 1: Install Laravel 8 App
  • Step 2: Install stripe Package
  • Step 3: Stripe Configuration
  • Step 4: Make Route
  • Step 5: Create Controller
  • Step 6: Create a Blade View file
  • Step 7: Run Development Server
Step 1: Install Laravel 8 App

In this step, execute the following command on the terminal to install Laravel 8 app. So, Open the command prompt and execute the following command:

composer create-project --prefer-dist laravel/laravel stripe_payment_gateway
Step 2: Install Stripe Package

Install Stripe-php integration Laravel package in laravel 8 project by executing the following command on terminal:

composer require stripe/stripe-php


After that, you need to set the stripe key and secret. So, visit on Stripe website and create a development stripe account. And get key and secret from stripe.com.

Step 3: Stripe Configuration
How To Integrate Stripe Payment Gateway In Laravel 8

Now open the .evn file and set the secret credential provided by a stripe payment gateway

STRIPE_KEY=pk_test_xxxxxxxxxxxxxxxxxxx 
STRIPE_SECRET=sk_test_xxxxxxxxxxxxxx 
  1. STRIPE_KEY=pk_test_xxxxxxxxxxxxxxxxxxx
  2. STRIPE_SECRET=sk_test_xxxxxxxxxxxxxx
STRIPE_KEY=pk_test_xxxxxxxxxxxxxxxxxxx 
STRIPE_SECRET=sk_test_xxxxxxxxxxxxxx 

Next step, you need to set up the Stripe API key, open or create the config/services.php file, and add or update the 'stripe' array:

'stripe' => [
     'secret' => env('STRIPE_SECRET'),
 ],
  1. 'stripe' => [
  2. 'secret' => env('STRIPE_SECRET'),
  3. ],
'stripe' => [
     'secret' => env('STRIPE_SECRET'),
 ],
Step 4: Make Route

In this step, open the web.php file, which is placed inside the routes directory. And add the following routes into it:

  1. <?php
  2. use Illuminate\Support\Facades\Route;
  3. use App\Http\Controllers\StripeController;
  4. /*
  5. |--------------------------------------------------------------------------
  6. | Web Routes
  7. |--------------------------------------------------------------------------
  8. |
  9. | Here is where you can register web routes for your application. These
  10. | routes are loaded by the RouteServiceProvider within a group which
  11. | contains the "web" middleware group. Now create something great!
  12. |
  13. */
  14. Route::get('stripe', [StripeController::class, 'stripe']);
  15. Route::post('stripe', [StripeController::class, 'stripePost'])->name('stripe.post');
<?php
    
use Illuminate\Support\Facades\Route;
   
use App\Http\Controllers\StripeController;
   
/*
|--------------------------------------------------------------------------
| Web Routes
|--------------------------------------------------------------------------
|
| Here is where you can register web routes for your application. These
| routes are loaded by the RouteServiceProvider within a group which
| contains the "web" middleware group. Now create something great!
|
*/
   
Route::get('stripe', [StripeController::class, 'stripe']);
Route::post('stripe', [StripeController::class, 'stripePost'])->name('stripe.post');
Step 5: Create Controller

In this step, execute the following command on the terminal to create the controller name StripeController. We learn Stripe-php integration Laravel.

php artisan make:controller StripeController


Then go app/Http/Controllers/ directory and open StripeController. Then add the following code into StripeController.php.

  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Http\Request;
  4. use Session;
  5. use Stripe;
  6. class StripeController extends Controller
  7. {
  8. /**
  9. * success response method.
  10. *
  11. * @return \Illuminate\Http\Response
  12. */
  13. public function stripe()
  14. {
  15. return view('stripe');
  16. }
  17. /**
  18. * success response method.
  19. *
  20. * @return \Illuminate\Http\Response
  21. */
  22. public function stripePost(Request $request)
  23. {
  24. Stripe\Stripe::setApiKey(env('STRIPE_SECRET'));
  25. Stripe\Charge::create ([
  26. "amount" => 100 * 100,
  27. "currency" => "usd",
  28. "source" => $request->stripeToken,
  29. "description" => "This payment is tested purpose phpcodingstuff.com"
  30. ]);
  31. Session::flash('success', 'Payment successful!');
  32. return back();
  33. }
  34. }
<?php
    
namespace App\Http\Controllers;
    
use Illuminate\Http\Request;
use Session;
use Stripe;
    
class StripeController extends Controller
{
    /**
     * success response method.
     *
     * @return \Illuminate\Http\Response
     */
    public function stripe()
    {
        return view('stripe');
    }
   
    /**
     * success response method.
     *
     * @return \Illuminate\Http\Response
     */
    public function stripePost(Request $request)
    {
        Stripe\Stripe::setApiKey(env('STRIPE_SECRET'));
        Stripe\Charge::create ([
                "amount" => 100 * 100,
                "currency" => "usd",
                "source" => $request->stripeToken,
                "description" => "This payment is tested purpose phpcodingstuff.com"
        ]);
   
        Session::flash('success', 'Payment successful!');
           
        return back();
    }
}
Step 6: Create Blade View File

In this step, Visit app/resources/views/ and create one blade view file name stripe.blade.php. Then add the following code into the Stripe.blade.php file:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>stripe payment gateway integration in php - phpcodingstuff.com</title>
  5. <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
  6. <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
  7. <style type="text/css">
  8. .panel-title {
  9. display: inline;
  10. font-weight: bold;
  11. }
  12. .display-table {
  13. display: table;
  14. }
  15. .display-tr {
  16. display: table-row;
  17. }
  18. .display-td {
  19. display: table-cell;
  20. vertical-align: middle;
  21. width: 61%;
  22. }
  23. </style>
  24. </head>
  25. <body>
  26. <div class="container">
  27. <h1>stripe payment gateway integration in php - phpcodingstuff.com</h1>
  28. <div class="row">
  29. <div class="col-md-6 col-md-offset-3">
  30. <div class="panel panel-default credit-card-box">
  31. <div class="panel-heading display-table" >
  32. <div class="row display-tr" >
  33. <h3 class="panel-title display-td" >Payment Details</h3>
  34. <div class="display-td" >
  35. <img class="img-responsive pull-right" src="http://i76.imgup.net/accepted_c22e0.png">
  36. </div>
  37. </div>
  38. </div>
  39. <div class="panel-body">
  40. @if (Session::has('success'))
  41. <div class="alert alert-success text-center">
  42. <a href="#" class="close" data-dismiss="alert" aria-label="close">×</a>
  43. <p>{{ Session::get('success') }}</p>
  44. </div>
  45. @endif
  46. <form
  47. role="form"
  48. action="{{ route('stripe.post') }}"
  49. method="post"
  50. class="require-validation"
  51. data-cc-on-file="false"
  52. data-stripe-publishable-key="{{ env('STRIPE_KEY') }}"
  53. id="payment-form">
  54. @csrf
  55. <div class='form-row row'>
  56. <div class='col-xs-12 form-group required'>
  57. <label class='control-label'>Name on Card</label> <input
  58. class='form-control' size='4' type='text'>
  59. </div>
  60. </div>
  61. <div class='form-row row'>
  62. <div class='col-xs-12 form-group card required'>
  63. <label class='control-label'>Card Number</label> <input
  64. autocomplete='off' class='form-control card-number' size='20'
  65. type='text'>
  66. </div>
  67. </div>
  68. <div class='form-row row'>
  69. <div class='col-xs-12 col-md-4 form-group cvc required'>
  70. <label class='control-label'>CVC</label> <input autocomplete='off'
  71. class='form-control card-cvc' placeholder='ex. 311' size='4'
  72. type='text'>
  73. </div>
  74. <div class='col-xs-12 col-md-4 form-group expiration required'>
  75. <label class='control-label'>Expiration Month</label> <input
  76. class='form-control card-expiry-month' placeholder='MM' size='2'
  77. type='text'>
  78. </div>
  79. <div class='col-xs-12 col-md-4 form-group expiration required'>
  80. <label class='control-label'>Expiration Year</label> <input
  81. class='form-control card-expiry-year' placeholder='YYYY' size='4'
  82. type='text'>
  83. </div>
  84. </div>
  85. <div class='form-row row'>
  86. <div class='col-md-12 error form-group hide'>
  87. <div class='alert-danger alert'>Please correct the errors and try
  88. again.
  89. </div>
  90. </div>
  91. </div>
  92. <div class="row">
  93. <div class="col-xs-12">
  94. <button class="btn btn-primary btn-lg btn-block" type="submit">Pay Now ($100)</button>
  95. </div>
  96. </div>
  97. </form>
  98. </div>
  99. </div>
  100. </div>
  101. </div>
  102. </div>
  103. </body>
  104. <script type="text/javascript" src="https://js.stripe.com/v2/"></script>
  105. <script type="text/javascript">
  106. $(function() {
  107. var $form = $(".require-validation");
  108. $('form.require-validation').bind('submit', function(e) {
  109. var $form = $(".require-validation"),
  110. inputSelector = ['input[type=email]', 'input[type=password]',
  111. 'input[type=text]', 'input[type=file]',
  112. 'textarea'
  113. ].join(', '),
  114. $inputs = $form.find('.required').find(inputSelector),
  115. $errorMessage = $form.find('div.error'),
  116. valid = true;
  117. $errorMessage.addClass('hide');
  118. $('.has-error').removeClass('has-error');
  119. $inputs.each(function(i, el) {
  120. var $input = $(el);
  121. if ($input.val() === '') {
  122. $input.parent().addClass('has-error');
  123. $errorMessage.removeClass('hide');
  124. e.preventDefault();
  125. }
  126. });
  127. if (!$form.data('cc-on-file')) {
  128. e.preventDefault();
  129. Stripe.setPublishableKey($form.data('stripe-publishable-key'));
  130. Stripe.createToken({
  131. number: $('.card-number').val(),
  132. cvc: $('.card-cvc').val(),
  133. exp_month: $('.card-expiry-month').val(),
  134. exp_year: $('.card-expiry-year').val()
  135. }, stripeResponseHandler);
  136. }
  137. });
  138. function stripeResponseHandler(status, response) {
  139. if (response.error) {
  140. $('.error')
  141. .removeClass('hide')
  142. .find('.alert')
  143. .text(response.error.message);
  144. } else {
  145. /* token contains id, last4, and card type */
  146. var token = response['id'];
  147. $form.find('input[type=text]').empty();
  148. $form.append("<input type='hidden' name='stripeToken' value='" + token + "'/>");
  149. $form.get(0).submit();
  150. }
  151. }
  152. });
  153. </script>
  154. </html>
<!DOCTYPE html>
<html>
   <head>
      <title>stripe payment gateway integration in php - phpcodingstuff.com</title>
      <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css">
      <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
      <style type="text/css">
         .panel-title {
         display: inline;
         font-weight: bold;
         }
         .display-table {
         display: table;
         }
         .display-tr {
         display: table-row;
         }
         .display-td {
         display: table-cell;
         vertical-align: middle;
         width: 61%;
         }
      </style>
   </head>
   <body>
      <div class="container">
         <h1>stripe payment gateway integration in php - phpcodingstuff.com</h1>
         <div class="row">
            <div class="col-md-6 col-md-offset-3">
               <div class="panel panel-default credit-card-box">
                  <div class="panel-heading display-table" >
                     <div class="row display-tr" >
                        <h3 class="panel-title display-td" >Payment Details</h3>
                        <div class="display-td" >                            
                           <img class="img-responsive pull-right" src="http://i76.imgup.net/accepted_c22e0.png">
                        </div>
                     </div>
                  </div>
                  <div class="panel-body">
                     @if (Session::has('success'))
                     <div class="alert alert-success text-center">
                        <a href="#" class="close" data-dismiss="alert" aria-label="close">×</a>
                        <p>{{ Session::get('success') }}</p>
                     </div>
                     @endif
                     <form
                        role="form"
                        action="{{ route('stripe.post') }}"
                        method="post"
                        class="require-validation"
                        data-cc-on-file="false"
                        data-stripe-publishable-key="{{ env('STRIPE_KEY') }}"
                        id="payment-form">
                        @csrf
                        <div class='form-row row'>
                           <div class='col-xs-12 form-group required'>
                              <label class='control-label'>Name on Card</label> <input
                                 class='form-control' size='4' type='text'>
                           </div>
                        </div>
                        <div class='form-row row'>
                           <div class='col-xs-12 form-group card required'>
                              <label class='control-label'>Card Number</label> <input
                                 autocomplete='off' class='form-control card-number' size='20'
                                 type='text'>
                           </div>
                        </div>
                        <div class='form-row row'>
                           <div class='col-xs-12 col-md-4 form-group cvc required'>
                              <label class='control-label'>CVC</label> <input autocomplete='off'
                                 class='form-control card-cvc' placeholder='ex. 311' size='4'
                                 type='text'>
                           </div>
                           <div class='col-xs-12 col-md-4 form-group expiration required'>
                              <label class='control-label'>Expiration Month</label> <input
                                 class='form-control card-expiry-month' placeholder='MM' size='2'
                                 type='text'>
                           </div>
                           <div class='col-xs-12 col-md-4 form-group expiration required'>
                              <label class='control-label'>Expiration Year</label> <input
                                 class='form-control card-expiry-year' placeholder='YYYY' size='4'
                                 type='text'>
                           </div>
                        </div>
                        <div class='form-row row'>
                           <div class='col-md-12 error form-group hide'>
                              <div class='alert-danger alert'>Please correct the errors and try
                                 again.
                              </div>
                           </div>
                        </div>
                        <div class="row">
                           <div class="col-xs-12">
                              <button class="btn btn-primary btn-lg btn-block" type="submit">Pay Now ($100)</button>
                           </div>
                        </div>
                     </form>
                  </div>
               </div>
            </div>
         </div>
      </div>
   </body>
   <script type="text/javascript" src="https://js.stripe.com/v2/"></script>
   <script type="text/javascript">
      $(function() {
    var $form = $(".require-validation");
    $('form.require-validation').bind('submit', function(e) {
        var $form = $(".require-validation"),
            inputSelector = ['input[type=email]', 'input[type=password]',
                'input[type=text]', 'input[type=file]',
                'textarea'
            ].join(', '),
            $inputs = $form.find('.required').find(inputSelector),
            $errorMessage = $form.find('div.error'),
            valid = true;
        $errorMessage.addClass('hide');
        $('.has-error').removeClass('has-error');
        $inputs.each(function(i, el) {
            var $input = $(el);
            if ($input.val() === '') {
                $input.parent().addClass('has-error');
                $errorMessage.removeClass('hide');
                e.preventDefault();
            }
        });
        if (!$form.data('cc-on-file')) {
            e.preventDefault();
            Stripe.setPublishableKey($form.data('stripe-publishable-key'));
            Stripe.createToken({
                number: $('.card-number').val(),
                cvc: $('.card-cvc').val(),
                exp_month: $('.card-expiry-month').val(),
                exp_year: $('.card-expiry-year').val()
            }, stripeResponseHandler);
        }
    });

    function stripeResponseHandler(status, response) {
        if (response.error) {
            $('.error')
                .removeClass('hide')
                .find('.alert')
                .text(response.error.message);
        } else {
            /* token contains id, last4, and card type */
            var token = response['id'];
            $form.find('input[type=text]').empty();
            $form.append("<input type='hidden' name='stripeToken' value='" + token + "'/>");
            $form.get(0).submit();
        }
    }
});
   </script>
</html>
Step 7: Run Development Server

In this step, execute the PHP artisan serve command on the terminal to start the development server:

php artisan serve


If you want to run the project different port so use this below command

php artisan serve --port=8080


Testing Card Credential

Card No: 4242424242424242

Month: any future month

Year: any future Year

CVV: 123


Stripe payment gateway integration in laravel 8 tutorial with example, you have learned how to integrate the stripe payment gateway in laravel 8.


I hope it can help you...

Leave a Reply

Your privacy will not be published. Required fields are marked *

We'll share your Website Only Trusted.!!

close