Razorpay Создание и оплата заказов с помощью Laravel

Процесс работы:

  • При нажатии кнопки Buy Now все данные передаются в БД, затем создается заказ в таблице Razorpay и происходит перенаправление на страницу Pay with Razorpay.

  • При нажатии на кнопку Pay with Razorpay происходит проверка платежа Razorpay с помощью try catch и статус платежа в таблице заказов меняется с неоплаченного на оплаченный, razorpay_payment_id, razorpay_signature обновляются в таблице Razorpay путем проверки razorpay_order_id и удаляется идентификатор заказа сессии.

  • Наконец, он направляется в представление Success с переменной данных, которая содержит идентификатор заказа.

N.B: Когда этот «callback_url»: «route(‘frontend.payment_success’)», razorpay отправляет razorpay_payment_id, razorpay_signature, razorpay_order_id и выдает ошибку 419 из-за несоответствия CSRF токена, так как маршрут является POST маршрутом, для этого конкретный маршрут должен быть добавлен в промежуточное ПО VerifyCsrfToken, чтобы исключить несоответствие CSRF токена.

public static function order_payment($request, $data)
{
$payment_arr=[];
        try{
if($request->type_of_payment == 'online')
{
$api = new Api(config()->get('razorpay_key_id'), config()->get('razorpay_key_secret'));
//Create Order and save in Database
//Delete Shopping cart products

//Razorpay Payment            
                        $orderData = [
                            'receipt'         => 'rcpt_'.$order_id,
                            'amount'          => $data['tot_amount'] * 100, // 39900 rupees in paise
                            'currency'        => config()->get('currency_code'),
                            'partial_payment' => false,
                        ];

                        $razorpayOrder = $api->order->create($orderData);
}
//Create data in Razorpay table
 RazorpayPayment::create([
                            'razorpay_order_id' => $razorpayOrder->id,
                            'amount' => $razorpayOrder->amount,
                            'receipt_id' => $razorpayOrder->receipt, 
                            'status' => $razorpayOrder->status,
                            'created_ts' => $razorpayOrder->created_at,
                        ]);

//Put order id in session
 session()->put(['order_id'=>$razorpayOrder->id, 'order_mode'=>'razorpay']);

if(isset($razorpayOrder->id))
            {
                return view('frontend.razorpay-payment', $data);
            }
}
Вход в полноэкранный режим Выход из полноэкранного режима

Платежное лезвие Razorpay:

@extends('layouts.frontendLayout')

@push('head_script')
@endpush

@section('content')

<button id="rzp-button1" class="btn btn-primary mb-3 mt-3">Pay with Razorpay</button>


@endsection

@push('footer_script')
<script src="https://checkout.razorpay.com/v1/checkout.js"></script>
<script>
var options = {
    "key": "{{config()->get('razorpay_key_id')}}", // Enter the Key ID generated from the Dashboard
    "amount": "{{$payment_arr['razorpayOrder']->amount}}", // Amount is in currency subunits. Default currency is INR. Hence, 50000 refers to 50000 paise
    "currency": "{{config()->get('currency_code')}}",
    "name": "{{config()->get('setting.siteName')}}",
    "description": "Test Transaction for purchasing {{$payment_arr['order_id']}}",
    "image": "{{asset('customResource/apy-frontend/images/oxgo.jpg')}}",
    "order_id": "{{$payment_arr['razorpayOrder']->id}}", //This is a sample Order ID. Pass the `id` obtained in the response of Step 1
    "callback_url": "{{route('frontend.payment_success')}}",
    "prefill": {
        "name": "{{session()->get('user.name')}}",
        "email": "{{session()->get('user.email')}}",
        "contact": "1234567890"
    },
    "notes": {
        "address": "Some address"
    },
    "theme": {
        "color": "#3399cc"
    }
};
var rzp1 = new Razorpay(options);
document.getElementById('rzp-button1').onclick = function(e){
    rzp1.open();
    e.preventDefault();
}
</script>
@endpush
Войти в полноэкранный режим Выход из полноэкранного режима

Переход к контроллеру проверки платежей

public function payment_success(Request $request)
{
$data['order_id'] = session()->get('order_id');
if($request->filled('razorpay_payment_id'))
       $api = new Api(config()->get('razorpay_key_id'), config()->get('razorpay_key_secret'));
            try{
                $attributes = array(
                    'razorpay_order_id' =>  $data['order_id'],
                    'razorpay_payment_id' => $request->razorpay_payment_id,
                    'razorpay_signature' => $request->razorpay_signature,
                );

                $api->utility->verifyPaymentSignature($attributes);

                $rzr_record = RazorpayPayment::where('razorpay_order_id',  $data['order_id'])->first();
                Order::where('order_unique_id', substr($rzr_record->receipt_id,5))->update([
                    'payment_status' => 'paid',
                ]);
                $rzr_record->update([
                    'razorpay_payment_id' => $request->razorpay_payment_id,
                    'razorpay_order_id' => session()->get('order_id'),
                    'razorpay_signature' => $request->razorpay_signature,
                ]);
                session()->forget('order_id');
            }
            catch(SignatureVerificationError $e)
            {
                $success = false;
                $error = 'Razorpay Error : '. $e->getMessage();
                $data['error'] =  $error;
                return view('frontend.order-success',$data); //If error
            }
 return view('frontend.order-success', $data); //If success
}
Войти в полноэкранный режим Выход из полноэкранного режима

Маршруты:

Route::any('/checkout', [HomepageController::class, 'checkout'])->middleware('customer','roleif:customer')->name('checkout');//used any for flash message
        Route::post('/checkout-cart', [HomepageController::class, 'checkout_post'])->name('checkout_post');
        Route::post('/payment-success', [HomepageController::class, 'payment_success'])->name('payment_success'); //Hitting when the payment is done and also verified
Войти в полноэкранный режим Выйти из полноэкранного режима

VerifyCsrfToken:

protected $except = [
        //
        '/payment-success',
    ];
Войти в полноэкранный режим Выход из полноэкранного режима

Оцените статью
devanswers.ru
Добавить комментарий