我希望在我的项目中实现在线支付。我使用来自波兰的Przelewy24网关。
对于Laravel 8,我选择了适用于此处的插件: https://github.com/mnastalski/przelewy24-php 我遇到的问题是网关反馈有关转账是否已收到或已预订的信息。
我联系了Przelewy24技术支持,并从他们那里收到了以下日志信息:
[responseBody] => 重定向到“/登录” 重定向到“/登录”。 [httpResponseCode] => 302
我尝试了很多方法,但不幸的是没有任何结果。 下面的代码已经被修改了很多次。
后端
我认为Laravel可能存在不允许外部脚本的问题,或者它试图强制脚本登录(即重定向到登录页面),但是在我的看法中,“order_status”无需用户登录。
目前还没有对数据库进行读写操作。这是我接下来要跟进的步骤,因为上述代码终于开始正常工作了。我已经苦苦挣扎了两个星期……所以,请帮帮我!
对于Laravel 8,我选择了适用于此处的插件: https://github.com/mnastalski/przelewy24-php 我遇到的问题是网关反馈有关转账是否已收到或已预订的信息。
我联系了Przelewy24技术支持,并从他们那里收到了以下日志信息:
[responseBody] => 重定向到“/登录” 重定向到“/登录”。 [httpResponseCode] => 302
我尝试了很多方法,但不幸的是没有任何结果。 下面的代码已经被修改了很多次。
后端
-- web.php --
Route::post('/order_status', 'Payment_Controller@order_status')->name('order_status');
Auth::routes([ 'verify' => true ]);
...
...
Route::get('/orderPaymentMethods/', 'Payment_Controller@paymentMethods')->name('orderPayments_paymentMethods');
Route::get('/order-success', 'Payment_Controller@order_success')->name('order_success');
-- Payment_Controller.php
private function create_instance()
{
return new Przelewy24([
'merchant_id' => $this->partnerId,
'crc' => $this->crc,
'pos_id' => $this->posId,
'live' => false, // `true` for production/live mode
]);
}
public function create_transaction()
{
$this->currency = $this->settings->first()->currency;
if (!$this->sessionId) {
$this->sessionId = $this->set_sessionId();
}
$this->checkCart(); // this function is checking if cart is empty or not
$this->get_totalPrice_from_cart(); // this function is geting total price of cart
$this->user_email = \Auth::user()->email;
try {
$this->transaction = $this->create_instance()->transaction([
'session_id' => $this->sessionId,
'url_return' => route('order_success'),
'url_status' => route('order_status'),
'amount' => $this->price,
'description' => $this->description,
'email' => $this->user_email,
'currency' => $this->currency,
]);
if ($this->transaction->token()) {
/** TRANSACTION STARTED */
return $this->transaction;
}
return 'Create transaction failed';
} catch (ApiResponseException $e) {
return 'Error(transaction): (' . $e->getCode() . ') - ' . $e->getMessage();
}
}
public function set_sessionId()
{
// for testing purpose 1h session ID
$this->sessionId = md5($this->posId . '|' . $this->partnerId . '|' . $this->price . '|' . $this->currency . '|' . $this->crc . '|' . date('Ymd-H'));
return $this->sessionId;
}
public function order_success()
{
// this is returning page from przelewy24
return view('order_success');
}
public function order_status()
{
// this is returning status and it doesn't work.
// $webhook is always empty because as i mention before - support from przelewy24 getting Error 302 -redirecting to '/login'
$this->checkCart();
$instance = $this->create_instance();
$webhook = $instance->handleWebhook();
try {
$verify = $instance->verify([
'session_id' => $webhook->sessionId(),
'order_id' => $webhook->orderId(),
'amount' => $webhook->amount(),
]);
} catch (ApiResponseException $e) {
return $e->getMessage();
}
return response()->json($verify);
}
前端
-- cartPage_paymentMethod.blade.php --
<html>
...
...
@php
/** PAYMENT */
$transaction = new App\Http\Controllers\Payment_Controller();
$sessionId = $transaction->set_sessionId();
$create_trans = $transaction->create_transaction();
$transaction_url = '';
if(is_string($create_trans))
echo $create_trans;
else
$transaction_url = $create_trans->redirectUrl();
@endphp
<form method="post" action="{{$transaction_url}}">
@csrf
<button class="btn btn-primary">{{__('labels.toPayment')}}</button>
</form>
-- order_success.blade.php -- //
@section('content')
<div id="message">Waiting for payment...</div>
<div id="response">-</div>
@push('custom-js')
<script type="text/javascript">
$(document).ready(function() {
setTimeout(function() {
$.ajaxSetup({
headers: {
"Content-Type" : "application/json",
"Accept" : "application/json",
"cache-control": "no-cache",
"X-Requested-With": "XMLHttpRequest",
'X-CSRF-TOKEN' : $('meta[name="csrf-token"]').attr('content')
},
});
$.ajax({
type : "POST",
url : '{{route('order_status')}}',
dataType : "JSON",
headers : {
},
processData: false,
success : function(resp) {
console.log(resp);
$('#response').html(resp);
},
error : function(xhr) {
console.log(xhr);
}
})
}, 1000)
})
</script>
@endpush
@endsection
我认为Laravel可能存在不允许外部脚本的问题,或者它试图强制脚本登录(即重定向到登录页面),但是在我的看法中,“order_status”无需用户登录。
目前还没有对数据库进行读写操作。这是我接下来要跟进的步骤,因为上述代码终于开始正常工作了。我已经苦苦挣扎了两个星期……所以,请帮帮我!
csrf
阻止了来自支付网关的响应。谢谢! - Kafus