PHP支付接口教程,详解微信支付(一)

  1. 云栖社区>
  2. 博客>
  3. 正文

PHP支付接口教程,详解微信支付(一)

fourn 2017-06-28 21:42:00 浏览617
展开阅读全文

微信支付

三大支付方式里面,最复杂也是坑最多的非微信支付莫属,我们从微信开始讲。
常见的微信支付种类有下列四种:

  1. 微信JS支付,也称公众号内支付,使用场景就是微信里面的H5商城,在微信以外的地方无法使用
  2. 微信PC支付,也称扫码支付,使用场景是PC端,注意这里并不是“原生扫码支付”
  3. 微信APP支付,使用场景是原生或者混合APP
  4. 微信WEB支付,场景是微信外的触屏网站,这个接口一直都有,只是最近才开放出来可以让普通公司申请,这个如果有机会的话也会讲一讲

从接口申请阶段开始,四种方式就各有各的坑,这里不得不感谢一下腾讯,替我们增加了很多工作量。

微信JS支付

第一阶段:接口申请

因为是面向开发人员的教程,所以具体的申请条件、如何申请等内容并不会讲的太详细,只需要注意下面几点即可:

  1. 请领导把你的微信号设置为公众号的临时管理员
  2. 把公众号和商户平台的账号密码拿到手
  3. 微信平台需要自己去重查看APPSECRET,这个过程需要公众号管理员授权
  4. 商户平台需要自己去配置KEY,这个过程会有两条验证短信发到领导手机上

总之第一阶段最后需要把这四个数据准确的拿到手:

  1. APPID——登录公众平台查看
  2. APPSECRET——登录公众平台申请重置之后查看
  3. MCHID——商户平台的ID
  4. KEY——商户平台自己设置的KEY
30492-d494f089e70b4880
查看APPID

30492-fa54dd0dafa37f5f
查看APPSECRET

30492-dd44e85272d59d33
查看MCHID

30492-63fa35aecdc6e48c
设置KEY

第二阶段:配置

这里指的配置是配置公众平台,配置有必要详细的说一下,现在各种现成的项目和集成支付代码比比皆是,可是你就是用不起来,这个时候千万不要花时间去审查代码,是你的配置出了问题。让我们从原理上来理解一下:
业务域名、 JS接口安全域名、网页授权域名

30492-5f5040f297861d4d
PHP支付接口教程,详解微信支付、支付宝支付、银联支付(一)

这三个参数在同一个页面进行配置,配置方法也相同,直接填写域名即可。如果你遇到的问题是REDIRECT_URI错误,那多半就是这里出现了问题。
支付授权目录
30492-547c145c268cabb9
PHP支付接口教程,详解微信支付、支付宝支付、银联支付(一)

这里一定要填写实际发起支付的页面的URL,并且以斜杠结尾。那么就有三个问题:

1. 我完全没搞懂实际发起支付的是哪个URL
2. 我并不清楚什么叫斜杠结尾
3. 我配置对了为什么没用
  1. 在获取OPENID的过程中会有一次重定向,一般是重定向回本页面,但也有部分项目不会这么做,比如ecshop,就被重定向到了别的页面,所以实际发起页面也就变成了别的页面。
  2. 斜杠结尾就是把你的URL从右边开始数,碰到第一个斜杠,把你数过的部分删掉,剩下的就是正确的配置内容。当然还有广大ThinkPHP3.2用户,你们的参数用斜杠来传,就意味着你们在支付页面只能带一个参数,否则怎么配置都不会对的。
  3. 有可能你压根没配置对,请参考前两条。如果你确定配置对了,请去喝一杯咖啡,这个配置有时候不会马上生效。

第三阶段:调试

倒一杯咖啡,打开你心爱的代码编辑器,按照这6个步骤来,不要浮躁,你将会再次感谢腾讯……
把你在第一阶段准备的参数放到项目中(运气好的话此时你已经完成了开发)

  1. 测试CODE有没有获取到
  2. 测试OPENID有没有获取到
  3. 测试预支付订单是否正常
  4. 测试JS是否正常
  5. 测试回调数据是否正常

把踩过的坑或者套路与大家分享一下:

在官方DEMO中,JsApiPay类下面GetOpenid方法中第4行,
$_SERVER['PHP_SELF']
和
$_SERVER['QUERY_STRING']
之间少了一个问号。导致的问题就是有一些用GET传参的同学,OPENID死活获取不到。
订单名称里面不能含有&,暂时只发现这个符号会使得支付发起失败
签名错误,一般是再去检查参数,特别是一些看不到的字符可能混在参数中,最好不要怀疑签名方法有问题。
流程中有4个左右的地方会签名,或者验证签名,一定要确保所使用的KEY都是正确的。
在调试JS的时候用
alert(res.err_code+res.err_desc+res.err_msg)
把错误弹出来
测试回调的时候用
$GLOBALS['HTTP_RAW_POST_DATA']
来接收微信的通知,做好是接收到就存到数据库里,先确保接收到了,再去调签名和业务逻辑。

写在最后

操作类的内容和理论类的内容是分开的,例如本文就是操作类的,今后将会有探讨JS支付原理或者公私钥原理的文章,但不是现在,因为不想开留太多坑。
在文章节奏的把控上略显得有些不足,不过我会尽量不出现大篇幅代码,多分享经验干货,多以初学者的角度行文。如果有问题欢迎留言讨论,希望能对大家有帮助!


30492-354d5a951a7f9265

以上内容属于作者原创,特此声明,如需转载,请取得同意

网友评论

登录后评论
0/500
评论
fourn
+ 关注