服务器微信支付接口笔记(与app端对接)
yuyutoo 2024-10-31 16:42 2 浏览 0 评论
最近几天在做app的微信支付和支付宝支付,主要负责服务器接口。记录一下服务器这边的工作。
参考微信的官方文档链接:(有用的几个)
1 - 首先,如果想让app可以使用微信支付,必须先申请一个开放平台的账号
微信开放平台地址:微信开放平台地址 (点击打开)
同时,在开放平台页面顶部,有一个 资源中心,里面有各种文档(登录,授权等api在这个文档里面,通俗易懂,这点微信还是很不错的。)
2 -如果你完成了开放平台app的申请,就可以在app详情里面进行支付,登录(默认允许)等接口的申请,支付的话,要填一些资料,和汇款给对公账户的验证,如果你都完成了,微信就会发送一封邮件到你的邮箱,上面会记录着,商户号,商户id 等等信息,可以在微信商户平台登录,修改密钥获取证书等操作,链接甩上 : 点击打开链接 (支付等api在这个文档里面)
(ps:移动应用申请微信APP支付权限仅接受公司主体)
到这里,准备工作就算完成了。
支付流程步骤详解:
步骤1:用户在商户APP中选择商品,提交订单,选择微信支付。
这一步,app将相关订单信息提交给商户
步骤2:商户后台收到用户支付单,调用微信支付统一下单接口。参见【统一下单API】。
商户系统先调用该接口在微信支付服务后台生成预支付交易单,返回正确的预支付交易回话标识后再在APP里面调起支付。
步骤3:统一下单接口返回正常的prepay_id,再按签名规范重新生成签名后,将数据传输给APP。参与签名的字段名为appId,partnerId,prepayId,nonceStr,timeStamp,package。注意:package的值格式为Sign=WXPay
步骤4:商户APP调起微信支付。api参见本章节【app端开发步骤说明】(与服务器接口无关)
步骤5:商户后台接收支付通知。api参见【支付结果通知API】
步骤6:商户后台查询支付结果。,api参见【查询订单API】
遇到的问题:
1 商户用于接收微信的支付通知,链接是通过【统一下单API】中提交的参数notify_url设置,如果链接无法访问,商户将无法接收到微信通知,不能带参数,微信返回类型为post,xml格式
2 接收到支付通知首先要做签名验证,防止数据泄漏导致出现“假通知”,造成资金损失,就是收到的参数,除了sign字段之外的字段做签名之后,与收到的sign比较。
3 处理重复问题,微信可能会多次返回信息,要处理重复订单的问题,主要是解决【统一下单API】的订单号
4 另外,5里面要对6进行验证,验证无误,才可以在商户端对订单支付状态进行修改,防止假通知,或误操作。
上代码:(步骤5,6的)
- <?php
- /**
- * 通用通知接口demo
- * ====================================================
- * 支付完成后,微信会把相关支付和用户信息发送到商户设定的通知URL,
- * 商户接收回调信息后,根据需要设定相应的处理流程。
- *
- * 这里举例使用log文件形式记录回调信息。
- */
- require_once dirname(__FILE__).'/log_.php';
- // include_once("./log_.php");
- require_once '/xxxxxx.php';
- // include_once("../xxxxxx.php");
- //使用通用通知接口
- $notify = new Notify_pub();
- //存储微信的回调
- $xml = $GLOBALS['HTTP_RAW_POST_DATA'];
- $notify->saveData($xml);//将微信的请求xml转换成关联数组,以方便数据处理
- if (empty($data))
- return false;
- //验证签名,并回应微信。
- //对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败,
- //微信会通过一定的策略(如30分钟共8次)定期重新发起通知,
- //尽可能提高通知的成功率,但微信不保证通知最终能成功。
- if($notify->checkSign() == FALSE){
- //设置两个数组的字段值
- $notify->setReturnParameter("return_code","FAIL");//返回状态码
- $notify->setReturnParameter("return_msg","签名失败");//返回信息
- }else{
- $notify->setReturnParameter("return_code","SUCCESS");//设置返回码
- }
- $returnXml = $notify->returnXml();
- echo $returnXml;
- //==商户根据实际情况设置相应的处理流程,此处仅作举例=======
- //以log文件形式记录回调信息
- $log_ = new Log_();
- $log_name=dirname(__FILE__)"/notify_url.log";//log文件路径
- $log_->log_result($log_name,"【接收到的notify通知】:\n".$xml."\n");
- if($notify->checkSign() == TRUE)
- {
- if ($notify->data["return_code"] == "FAIL"||empty($notify->data["return_code"])) {
- //此处应该更新一下订单状态,商户自行增删操作
- $log_->log_result($log_name,"【通信出错】:\n".$xml."\n");
- }
- elseif($notify->data["result_code"] == "FAIL"||empty($notify->data["result_code"])){
- //此处应该更新一下订单状态,商户自行增删操作
- $log_->log_result($log_name,"【业务出错】:\n".$xml."\n");
- }
- else{
- $check = new OrderQuery_pub();
- if(!$check->createXml()){
- $msg = '订单查询失败';
- $log_->log_result($log_name,"订单查询失败:\n".time()."\n");
- return false;
- }
- // if (empty($data['out_trade_no'])){
- // // file_put_contents('/xxxxx/aaa.txt', '3');
- // return false;
- // }
- ksort($data);
- reset($data);
- $payment = D('Payment')->getPayment('weixin');
- /* 检查支付的金额是否相符 */
- //商户逻辑
- }
- //签名验证
- $sign = array();
- foreach ($data as $key => $val) {
- if ($key != 'sign') {
- $sign[] = $key . '=' . $val;
- }
- }
- $sign[] = 'key=' . $payment['appkey'];
- //用&将sign元素拼接成字串
- $signstr = strtoupper(md5(join('&', $sign)));
- if ($signstr != $data['sign']){
- $log_->log_result($log_name,"【签名失败】:\n""用于组件sign的数组为:=".$sign."\n");
- return false;
- }
- //商户,对订单操作
- echo "SUCCESS";
- $log_->log_result($log_name,"【支付成功】:\n".$xml.time()."\n");
- die();
- }
- //商户自行增加处理流程,
- //例如:更新订单状态
- //例如:数据库操作
- //例如:推送支付完成信息
- }
- ?>
如果你觉得有用的话,顶一下吧 ! ^o^
相关推荐
- MySQL5.5+配置主从同步并结合ThinkPHP5设置分布式数据库
-
前言:本文章是在同处局域网内的两台windows电脑,且MySQL是5.5以上版本下进行的一主多从同步配置,并且使用的是集成环境工具PHPStudy为例。最后就是ThinkPHP5的分布式的连接,读写...
- thinkphp5多语言怎么切换(thinkphp5.1视频教程)
-
thinkphp5多语言进行切换的步骤:第一步,在配置文件中开启多语言配置。第二步,创建多语言目录。相关推荐:《ThinkPHP教程》第三步,编写语言包。视图代码:控制器代码:效果如下:以上就是thi...
- 基于 ThinkPHP5 + Bootstrap 的后台开发框架 FastAdmin
-
FastAdmin是一款基于ThinkPHP5+Bootstrap的极速后台开发框架。主要特性基于Auth验证的权限管理系统支持无限级父子级权限继承,父级的管理员可任意增删改子级管理员及权限设置支持单...
- Thinkphp5.0 框架实现控制器向视图view赋值及视图view取值操作示
-
本文实例讲述了Thinkphp5.0框架实现控制器向视图view赋值及视图view取值操作。分享给大家供大家参考,具体如下:Thinkphp5.0控制器向视图view的赋值方式一(使用fetch()方...
- thinkphp5实现简单评论回复功能(php评论回复功能源码下载)
-
由于之前写评论回复都是使用第三方插件:畅言所以也就没什么动手,现在证号在开发一个小的项目,所以就自己动手写评论回复,没写过还真不知道评论回复功能听着简单,但仔细研究起来却无法自拔,由于用户量少,所以...
- ThinkPHP框架——实现定时任务,定时更新、清理数据
-
大家好,我是小蜗牛,今天给大家分享一下,如何用ThinkPHP5.1.*版本实现定时任务,例如凌晨12点更新数据、每隔10秒检测过期会员、每隔几分钟发送请求保证ip的活性等本次分享,主要用到一个名为E...
- BeyongCms系统基于ThinkPHP5.1框架的轻量级内容管理系统
-
BeyongCms内容管理系统(简称BeyongCms)BeyongCms系统基于ThinkPHP5.1框架的轻量级内容管理系统,适用于企业Cms,个人站长等,针对移动App、小程序优化;提供完善简...
- YimaoAdminv3企业建站系统,使用 thinkphp5.1.27 + mysql 开发
-
介绍YimaoAdminv3.0.0企业建站系统,使用thinkphp5.1.27+mysql开发。php要求5.6以上版本,推荐使用5.6,7.0,7.1,扩展(curl,...
- ThinkAdmin-V5开发笔记(thinkpad做开发)
-
前言为了快速开发一款小程序管理后台,在众多的php开源后台中,最终选择了基于thinkphp5的,轻量级的thinkadmin系统,进行二次开发。该系统支持php7。文档地址ThinkAdmin-V5...
- thinkphp5.0.9预处理导致的sql注入复现与详细分析
-
复现先搭建thinkphp5.0.9环境...
- thinkphp5出现500错误怎么办(thinkphp页面错误)
-
thinkphp5出现500错误,如下图所示:相关推荐:《ThinkPHP教程》require():open_basedirrestrictionineffect.File(/home/ww...
- Thinkphp5.0极速搭建restful风格接口层
-
下面是基于ThinkPHPV5.0RC4框架,以restful风格完成的新闻查询(get)、新闻增加(post)、新闻修改(put)、新闻删除(delete)等server接口层。1、下载Thin...
- 基于ThinkPHP5.1.34 LTS开发的快速开发框架DolphinPHP
-
DophinPHP(海豚PHP)是一个基于ThinkPHP5.1.34LTS开发的一套开源PHP快速开发框架,DophinPHP秉承极简、极速、极致的开发理念,为开发集成了基于数据-角色的权限管理机...
- ThinkPHP5.*远程代码执行高危漏洞手工与升级修复解决方法
-
漏洞描述由于ThinkPHP5框架对控制器名没有进行足够的安全检测,导致在没有开启强制路由的情况下,黑客构造特定的请求,可直接GetWebShell。漏洞评级严重影响版本ThinkPHP5.0系列...
- Thinkphp5代码执行学习(thinkphp 教程)
-
Thinkphp5代码执行学习缓存类RCE版本5.0.0<=ThinkPHP5<=5.0.10Tp框架搭建环境搭建测试payload...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- MySQL5.5+配置主从同步并结合ThinkPHP5设置分布式数据库
- thinkphp5多语言怎么切换(thinkphp5.1视频教程)
- 基于 ThinkPHP5 + Bootstrap 的后台开发框架 FastAdmin
- Thinkphp5.0 框架实现控制器向视图view赋值及视图view取值操作示
- thinkphp5实现简单评论回复功能(php评论回复功能源码下载)
- ThinkPHP框架——实现定时任务,定时更新、清理数据
- BeyongCms系统基于ThinkPHP5.1框架的轻量级内容管理系统
- YimaoAdminv3企业建站系统,使用 thinkphp5.1.27 + mysql 开发
- ThinkAdmin-V5开发笔记(thinkpad做开发)
- thinkphp5.0.9预处理导致的sql注入复现与详细分析
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)