使用Laravel创建和支付Razorpay订单流程步骤
Laravel  /  管理员 发布于 2年前   554
工作流程:
按下立即购买按钮后,所有数据都将提交到数据库,然后在 Razorpay 表中创建订单并重定向到使用 Razorpay 支付页面。
单击使用 Razorpay 付款按钮时,使用 try catch 验证 Razorpay 付款,并且订单表付款状态从未付款更改为已付款和 razorpay_payment_id,通过检查 razorpay_order_id 和会话订单 ID 在 Razorpay 表中更新 razorpay_signature删除。
最后,它使用具有订单 ID 的数据变量前往 Success 视图。
注意:
当这个 "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 支付 Blade:
@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
验证CsrfToken:
protected $except = [
//
'/payment-success',
];
转:
https://dev.to/debo2696/razorpay-order-creation-and-payment-using-laravel-1oi1
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号