Paypals Website Payments Pro Hosted Solutionを使用して、ユーザーがサイトを離れているように感じたり、PCI に準拠する必要なく、paypal を介して支払いを受け付けることができるようにしたいと考えています。
これを次の形式で機能させたいと考えています。
- ユーザーがアイテムの購入ページにアクセスし、数量を選択して [今すぐ購入] ボタンを押す
- AJAXリクエストがサーバーに送信され、数量の検証/合計の計算などが行われます
- AJAX リクエストが iframe の URL を返す
- iframe にページが取り込まれ、読み込みが完了すると iframe が表示されます
- ユーザーがクレジット カードの詳細を入力すると、PayPal がトランザクションを完了します
- Paypal が iframe をリダイレクトして親ページの JavaScript を呼び出し、別の URL にリダイレクトする成功ページ。
したがって、数量選択ページがあり
、データをサーバーに送信して数量を検証し、合計を計算する方法を知っています
どうすればよいかわからないのは、この時点からペイパルにリクエストを送信して、iframe の URL を取得することです。
私がやろうとしたことは(非常に基本的なスタンドアロンの例として)次のとおりです。
<?php
class paypal {
private $APIuser;
private $APIpass;
private $APIsign;
private $APIvers = '74.0';
private $APIaddr = 'https://api-3t.sandbox.paypal.com/nvp';
private $post_params = array();
function __construct($APIuser, $APIpass, $APIsign){
$this->APIuser = $APIuser;
$this->APIpass = $APIpass;
$this->APIsign = $APIsign;
}
function param($name, $value = null){
$this->post_params[$name] = $value;
return $this;
}
function getUrl(){
$post = $this->post_params;
$post['pwd'] = $this->APIpass;
$post['user'] = $this->APIuser;
$post['method'] = 'BMCreateButton';
$post['version'] = $this->APIvers;
$post['signature'] = $this->APIsign;
$post['buttoncode'] = 'CLEARTEXT';
$post['buttontype'] = 'PAYMENT';
$post_string = '?';
foreach($post as $k => $v)
$post_string .= $k.'='.urlencode($v).'&';
$post_string = substr($post_string, 0, -1);
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $this->APIaddr.$post_string);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
$out = curl_exec($ch);
curl_close($ch);
$out = explode('&', $out);
$final = array();
foreach($out as $k => &$v){
$v = explode('=', $v);
$final[$v[0]] = urldecode($v[1]);
}
return $final;
}
}
//mock variables
$price = 10.00;
$APIu = 'xxxxxxxxxx';
$APIp = 'xxxxxxxxxx';
$APIs = 'xxxxxxxxxx';
$paypal = new paypal($APIu, $APIp, $APIs);
$paypal->param('L_BUTTONVAR0=subtotal', $price*$_GET['quantity']);
$paypal->param('L_BUTTONVAR1=template', 'templateD');
$resp = $paypal->getUrl();
?>
<iframe width="100%" height=100%" src="<?php echo $resp['EMAILLINK']; ?>"></iframe>
テストバイヤーのクレジットカードの詳細を入力してヒットするまで、これは最初はうまくいくようです
お支払いページに戻り、住所を修正してください。
私は何を間違っていますか/これを機能させるには何が必要ですか?