PHP教程之php购物网站付出paypal利用办法
《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手册)肯定是要从网上下载一个的,它很权威,也很全面,我自己认为它是一本很好的参考书,但是不适合新手当教材使用。 要进行开发,搭建环境是首先需要做的事,windows下面我习惯把环境那个安装在C盘下面,因为我配的环境经常出现诡异事件,什么事都没做环境有的时候就不能用啦。 如果你已经到这种程度了,那么你已经可以做我的老师了。其实php也分很多的区域, 刚开始安装php的时候,我图了个省事,把php的扩展全都打开啦(就是把php.ini 那一片 extension 前面的冒号全去掉啦),这样自然有好处,以后不用再需要什么功能再来打开。 说点我烦的低级错误吧,曾经有次插入mysql的时间 弄了300年结果老报错,其实mysql的时间是有限制的,大概是到203X年具体的记不清啦,囧。 建议加几个专业的phper的群,当然啦需要说话的人多,一处一点问题能有人回答你的,当然啦要让人回答你的问题,平时就得躲在里面聊天,大家混熟啦,愿意回答你问题的人自然就多啦。 没接触过框架的人,也不用害怕,其实框架就是一种命名规范及插件,学会一个框架其余的框架都很好上手的。 我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。 写的比较杂,因为我也是个新手,不当至于大家多多指正。 php里的数组为空的时候是不能拿来遍历的;(这个有点低级啊,不过我刚被这个边界问题墨迹了好长一会) 微软最近出的新字体“微软雅黑”,虽然是挺漂亮的,不过firefox支持的不是很好,所以能少用还是少用的好。 至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。 为了以后维护的方便最好是代码上都加上注释,“予人方便,自己方便”。此外开发文档什么的最好都弄齐全。我觉得这是程序员必备的素质。虽然会消耗点很多的时间。但是确实是非常有必要的。 对于初学者来说不推荐去拿钱买的。当然如果一个网站你经常去用,而且里面的资料也比较有用,最好还是买个会员比较好,毕竟那些也是别人的工作成果。 作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。 真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎, 开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。 不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。 这些中手常用的知识,当你把我说的这些关键字都可以熟练运用的时候,你可以选择自己
页:
[1]