支付宝的H5支付体验真不错(支付宝叫他手机网站支付)。
反观微信支付干嘛要把H5支付藏起来?而且体验还那么差。
Payment 3.0 支付宝的配置设置文档请 点击这里
项目GitHub地址:https://github.com/helei112g/payment
从本篇开始,将用支付宝的沙箱方式进行演示,在项目的 payment/examples 中我已经提供了我的沙箱帐号。
新版接口已经同时支持 RSA 与 RSA2 。更换签名方式时,注意公钥的变化,在demo中我进行了注释。
另外支付宝为了提升支付体验,可以将 手机网站支付转Native支付 ,对于混合应用是非常好的体验。这部分服务器端的业务逻辑无须变动,只需要客户端更新到最新的 详情地址
还是先讲手机网站支付需要设置哪些参数,后面用代码演示。代码部分大家会发现跟 即时到账 支付的使用完全一致。他们的不同之处仅仅是下单参数的区别。
参数类型是否必须说明bodyboolean是商品描述subjectstring是商品名称,该参数最长为128个汉字order_nostring是商户网站唯一订单号timeout_expressstring是设置未付款交易的超时时间,一旦超时,该笔交易就会自动被关闭。amountfloat是该笔订单的资金总额,单位为RMB-Yuanreturn_paramstring是公用回传参数goods_typestring否商品主类型:0—虚拟类商品,1—实物类商品 默认为1store_idstring否商户门店编号body 主要是对商品的描述,根据自己的业务写就好,不过不要用一些非常特殊的字符,支付宝可能会进行一些处理,导致你的结果与预期不一样
subject 可以写一下商品名称信息,主要是方便支付宝后台对账时查看
order_no 自己生成的订单号,每次下单的单号必须唯一。也就是说:同一个 order_no 他的其他下单数据不能发生变化,价格、名称等等。如果有变化,需要重新生成一个订单号。
timeout_express 订单过期时间,很简单,你希望在那一刻过期,就写那个点的时间戳。只会精确到分钟
amount 订单的金额,就是用户实际需要支付的金额。
return_param 希望支付宝异步通知时,原样返回给你的数据,同样注意避免一些特殊字符
goods_type 用来区分购买的是实际商品还是虚拟商品,虚拟商品不需要物流发货,并且 虚拟类商品不支持使用花呗渠道
store_id 门店编号,这部分数据主要是支付宝为了将业务深化到线下而提供的,如果用不到,不设置就好。
代码调用。
use Payment\Common\PayException; use Payment\Client\Charge; $config = require_once('./aliconfig.php');// 支付宝的配置信息 $channel = 'ali_wap'; $payData = [ 'body' => '一个苹果', 'subject' => '牛逼公司--付款吧', 'order_no' => 'NB12312355', 'timeout_express' => '1489241888', 'amount' => '100', 'return_param' => 'buy some', 'goods_type' => 1, 'store_id' => '',// 没有就不设置 ]; try { $payUrl = Charge::run($channel, $config, $payData); } catch (PayException $e) { // 异常处理 exit; } echo htmlspecialchars($payUrl);大家在这里可以回到即时到账的部分对比一下,调用代码完全一致。唯一的差别就是 payData 中的些微差别。 多了一个 store_id 参数。少了另外两个参数: qr_mod paymethod
后面的几种支付在调用上也是如此没有差别,变化主要时围绕 payData 进行的。
当然这里最重要的变化是:$channel 。Payment 知道使用那种支付方式,完全是根据这个参数来设置的。因此一定要设置正确。再把对应的信息贴出来。方便大家查看。
名称含义ali_web即时到账ali_appapp支付(移动支付)ali_wapH5支付(手机网站支付、wap支付)ali_qr当面付中的扫码支付ali_bar当面付中的条码支付另外这里返回的依然是一个url。大家根据自己的业务进行合理的处理。htmlspecialchars() 函数的目的还是为了转义,正式使用时,请注意。
关于异步通知部分,会有专门的文章讲解,这里暂时略过。请关注后面的文章。
如果你有不清楚的或者愿意交流的地方,请联系我:
邮箱:dayugog@gmail.com
如果你觉得这个项目有帮助到你,请打赏我,让我有动力持续下去 左边微信,右边支付宝:
ps: 一般性的问题请大家可以先查资料,如果实在无法解决找我吧(不免费服务)。
对于支付宝的沙箱功能,我得再啰嗦几句。先把我配置的沙箱帐号贡献出来。方便大家测试
商家信息
商家账号 naacvg9185@sandbox.com商户UID 2088102169252684appId 2016073100130857买家信息
买家账号 aaqlmq0729@sandbox.com登录密码 111111支付密码 111111当前沙箱的买家帐号,只能使用 android 版本进行登陆。
沙箱钱包只支持扫一扫、付款码、门店详情页功能,其余功能不提供
所以大家,不要在使用我提供的沙箱帐号时,用你们真实的支付宝帐号去支付,那样子是不会成功的。沙箱的所有功能,都只能使用上面的沙箱帐号去完成。