|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
《PHP+MYSQL WEB开发(第三版)》号称圣经级,(也许是个不错的选择(声明:作者没给我啥好处费,我也不是书托,隔着大老远,我连他老兄的面都没见过的说-_-) 具体参考:
https://cms.paypal.com/us/cgi-bin/?cmd=_render-content&content_ID=developer/e_howto_html_Appx_websitestandard_htmlvariables
界说常量paypalurl
const PAYPAL_URL = 'https://www.sandbox.paypal.com/';
将要传送的数据纪录为一个数组
$paypalData = array(
'add' => 1,
'cmd' => '_ext-enter',
'redirect_cmd' => '_xclick',
'business' => $paypalAccount, --------liangliangfeng211@gmail.com这个是收款人的paypal账号
'item_name' => '51customimprint shopping cart',
'item_number' => $order->id,
'first_name' => $address->first_name,
'last_name' => $address->last_name,
'address1' => $address->address1,
'city' => $address->city,
'state' => $address->state_or_province,
'zip' => $address->zip_code,
'amount' => $order->subtotal,
'shipping' => $order->shipping_fee,
'no_note' => 1,
'currency_code' => 'USD',
'lc' => 'US'
);
将这个数组转化为一个url地址
$paypalArguments = array();
foreach($paypalData as $k => $v){
array_push($paypalArguments, $k . '=' . urlencode($v));
}
$paypalUrl = self::PAYPAL_URL . '?' . implode('&', $paypalArguments);
$this->_redirect($paypalUrl);
接上去,咱们测试的时分,应当将Paypal接口的地址设置为:
https://www.sandbox.paypal.com/cgi-bin/webscr
根基的流程
当客户向您付款时,PayPal将向位于指定 URL (type=”hidden” name=”notify_url” value=” “)的办事器发送一个告诉。此告诉中将包含您的客户的一切付款信息(例如,客户称号、金额),和一段加密代码。当办事器收到告诉时,它随后会将该信息(包含加密代码)发送回平安的PayPal URL。PayPal将经由过程反省加密字符串对买卖停止身份验证。这类将 IPN 数据传回PayPal的操作避免了“棍骗”,因而您可以确保 IPN 来自PayPal。在停止验证时,PayPal会将其正当性切实其实认信息发送回您的办事器。
提醒:要启用即时付款告诉,您将需求输出一个 URL,经由过程它您可以吸收到来自您的用户信息的告诉。
启用了即时付款告诉后,每次当您吸收付款时您的办事器城市收到一个告诉,此告诉将以埋没的“FORM POST”的体例发送到指定的 URL,并将包含一切付款信息。此页面的底部列出了告诉的 FORM 变量。
每次收到来自PayPal的 IPN 时,您必需在实行定单之前完成以下所述的告诉确认进程。确认列出的信息将可确保买卖正当。
告诉确认IPN
为了确保付款已进入您的PayPal账户,您必需验证用作“receiver_email”的电子邮件地址是不是已在您的PayPal账户中注册并失掉确认。
办事器收到即时付款告诉后,您将需求经由过程构建一个发送到PayPal的 HTTP POST 对其停止确认。您的 POST 应发送到 https://www.paypal.com/cgi-bin/webscr
您必需完整依照收到表单变量时的原样发送一切收到的表单变量。您还需求将一个值为“_notify-validate”的名为“cmd”变量(例如,cmd=_notify-validate)附加到 POST 字符串。
PayPal将答复该 POST,并在答复的注释中包括一个单词“VERIFIED”或“INVALID”。当您收到 VERIFIED 答复时,您需求在实行定单之前履行若干反省:
确认“payment_status”为“Completed”,由于体系也会为其他了局(如“Pending”或“Failed”)发送 IPN。
反省“txn_id”是不是未反复,以避免讹诈者反复利用旧的已完成的买卖。
验证“receiver_email”是已在您的PayPal账户中注册的电子邮件地址,以避免将付款发送到讹诈者的账户 。
反省其他买卖概况(如物品号和价钱),以确认价钱未改动完成了以上反省后,您可使用 IPN 数据更新您的数据库,并处置购物。
假如收到“有效”告诉,则应将其视为可疑告诉,并应对其停止查询拜访。
php manual(PHP手册)肯定是要从网上下载一个的,它很权威,也很全面,我自己认为它是一本很好的参考书,但是不适合新手当教材使用。 |
|