Codeigniter 使用Cardsave 3D secure签出
是否有人使用CI Merchant和3D Secure成功集成了Cardsave 我现在已经设法让3D安全对我的网站做出响应(对于任何其他有问题的人,您似乎需要将“return_url”作为参数添加到参数中),但使用真实卡或授权成功的测试3D安全卡,交易总是失败 不幸的是,CI Merchant网站上没有关于Cardsave驱动程序的任何文档,只有Paypal的一个示例 失败的交易没有显示在我的Cardsave帐户中的任何位置,因此我甚至不确定CI Merchant当时是否正在与Cardsave通信 下面是我用于测试的代码示例:Codeigniter 使用Cardsave 3D secure签出,codeigniter,ci-merchant,Codeigniter,Ci Merchant,是否有人使用CI Merchant和3D Secure成功集成了Cardsave 我现在已经设法让3D安全对我的网站做出响应(对于任何其他有问题的人,您似乎需要将“return_url”作为参数添加到参数中),但使用真实卡或授权成功的测试3D安全卡,交易总是失败 不幸的是,CI Merchant网站上没有关于Cardsave驱动程序的任何文档,只有Paypal的一个示例 失败的交易没有显示在我的Cardsave帐户中的任何位置,因此我甚至不确定CI Merchant当时是否正在与Cardsave
public function test_live_payment()
{
$this->load->library('merchant');
$creditcard = $this->input->post('creditcard');
$creditcardtype = $this->input->post('creditcardtype');
$cardmonth = $this->input->post('cardmonth');
$cardyear = $this->input->post('cardyear');
$cardsecurecode = $this->input->post('cardsecurecode');
$cardnameon = $this->input->post('cardnameon');
$address1 = $this->input->post('address1');
$address2 = $this->input->post('address2');
$city = $this->input->post('city');
$postcode = $this->input->post('postcode');
$data['status'] = '';
$data['message'] = '';
$test = TRUE;
if ($test) :
$settings = array (
'merchant_id' => 'TEST ACCOUNT',
'password' => 'XXXX'
);
else :
$settings = array (
'merchant_id' => 'LIVE ACCOUNT',
'password' => 'XXXX'
);
endif;
if ($_POST) :
$this->merchant->load('cardsave');
$this->merchant->initialize($settings);
$data['transaction_id'] = '999' . rand(1, 999);
$params = array(
'amount' => '1.00',
'currency' => 'GBP',
'card_no' => $creditcard,
'name' => $cardnameon,
'exp_month' => $cardmonth,
'exp_year' => 20 . $cardyear,
'csc' => $cardsecurecode,
'transaction_id' => $data['transaction_id'],
'description' => 'Test payment',
'address1' => $address1,
'address2' => $address2,
'city' => $city,
'postcode' => $postcode,
'return_url' => site_url('/test-payment')
);
$response = $this->merchant->purchase($params);
if ($response->success()) :
$gateway_reference = $response->reference();
$data['status'] = 'Success';
$data['message'] = 'The transaction was successfully processed';
else :
$message = $response->message();
$data['status'] = 'Failed';
if ( ! empty($message)) :
$data['message'] = $message;
else :
$data['message'] = 'Transaction failed. No further details received.';
endif;
endif;
endif;
$this->load->view('test_payment_form', $data);
}
似乎已经解决了我自己的问题。确保我传递了一个返回URL,然后2。将返回URL发送到包含purchase_return()函数的新函数。以下是我的完整(测试)代码:
public function test_live_payment()
{
$this->load->library('merchant');
$creditcard = $this->input->post('creditcard');
$creditcardtype = $this->input->post('creditcardtype');
$cardmonth = $this->input->post('cardmonth');
$cardyear = $this->input->post('cardyear');
$cardsecurecode = $this->input->post('cardsecurecode');
$cardnameon = $this->input->post('cardnameon');
$address1 = $this->input->post('address1');
$address2 = $this->input->post('address2');
$city = $this->input->post('city');
$postcode = $this->input->post('postcode');
$data['status'] = '';
$data['message'] = '';
$test = TRUE;
if ($test) :
$settings = array (
'merchant_id' => 'TEST ACCOUNT',
'password' => 'XXXX'
);
else :
$settings = array (
'merchant_id' => 'LIVE ACCOUNT',
'password' => 'XXXX'
);
endif;
if ($_POST) :
$this->merchant->load('cardsave');
$this->merchant->initialize($settings);
$data['transaction_id'] = '999' . rand(1, 999);
$data['transaction_id'] = '999' . rand(1, 999);
$newdata = array(
'transaction_id' => $data['transaction_id']
);
$this->session->set_userdata($newdata);
$params = array(
'amount' => '1.00',
'currency' => 'GBP',
'card_no' => $creditcard,
'name' => $cardnameon,
'exp_month' => $cardmonth,
'exp_year' => 20 . $cardyear,
'csc' => $cardsecurecode,
'transaction_id' => $data['transaction_id'],
'description' => 'Test payment',
'address1' => $address1,
'address2' => $address2,
'city' => $city,
'postcode' => $postcode,
'return_url' => site_url('/test-payment-response')
);
$response = $this->merchant->purchase($params);
if ($response->success()) :
$gateway_reference = $response->reference();
$data['status'] = 'Success';
$data['message'] = 'The transaction was successfully processed';
else :
$message = $response->message();
$data['status'] = 'Failed';
if ( ! empty($message)) :
$data['message'] = $message;
else :
$data['message'] = 'Transaction failed. No further details received.';
endif;
endif;
endif;
$this->load->view('test_payment_form', $data);
}
public function test_response()
{
$settings = array (
'merchant_id' => 'TEST ACCOUNT',
'password' => 'XXXX'
);
$this->load->library('merchant');
$this->merchant->load('cardsave');
$this->merchant->initialize($settings);
$data['transaction_id'] = $this->session->userdata('transaction_id');
$params = array(
'amount' => '1.00',
'currency' => 'GBP',
'transaction_id' => $data['transaction_id']
);
$response = $this->merchant->purchase_return($params);
if ($response->success()) :
$gateway_reference = $response->reference();
$data['status'] = 'Success';
$data['message'] = 'The transaction was successfully processed';
else :
$message = $response->message();
$data['status'] = 'Failed';
if ( ! empty($message)) :
$data['message'] = $message;
else :
$data['message'] = 'Transaction failed. No further details received.';
endif;
endif;
$this->load->view('test_payment_form', $data);
}