文件管理 · 2022年8月9日

微信支付php开发教程|如何用PHP实现微信支付求教新手!说明详细点

A. 微信支付的二维码怎么生成php

开通线下扫码支付即可实现。解决方案:1、首先服务号必须先完成认证。2、然后在申请开通微信支付。3、启动设计和开发,支付接口已可以在开发环境下调用调试。场景介绍:用户扫描商户展示在各种场景的二维码进行支付。步骤1:商户根据微信支付的规则,为不同商品生成不同的二维码,展示在各种场景,用于用户扫描购买。

B. php初学者如何学习实现微信支付和支付宝支付的相关

淘宝号绑定支付宝。 1、登陆淘宝官网,点击注册。 2、淘宝提供了两种注册方式:一般的会员注册和手机注册。 3、如果是已经注册成功的淘宝号,点击“我的淘宝”。 4这时,在新出现的页面中选择:设置——支付宝绑定设置。

C. 你好 !! PHP如何实现微信支付 求指教 新手!说清楚一点

通知机制的实现,官方只有文档没有demo代码,对没搞过的人来说,需要花大量时间来做测试。从文档上说的来看,微信每次通知过来的数据,结构比较复杂,是一个多段数据,除了要取出POST数据外,还要取其它的数据。这里首先涉及到一个关于php://input与$_POST取值的问题,简单列几点如下:1,Content- Type取值为application/x-www-form-urlencoded时,php会将http请求body相应数据会填入到数组$_POST,填入到$_POST数组中的数据是进行urldecode()解析的结果。(其实,除了该Content-Type,还有 multipart/form-data表示数据是表单数据,稍后我们介绍)2,php://input数据,只要Content-Type不为 multipart/form-data(该条件限制稍后会介绍)。那么php://input数据与http entity body部分数据是一致的。该部分相一致的数据的长度由Content-Length指定。3,仅当Content-Type为application/x-www-form-urlencoded且提交方法是POST方法时,$_POST数据与php://input数据才是”一致”(打上引号,表示它们格式不一致,内容一致)的。其它情况,它们都不一致。4,php://input读取不到$_GET数据。是因为$_GET数据作为query_path写在http请求头部(header)的PATH字段,而不是写在http请求的body部分。帮助我们了解了为什么xml_rpc服务端读取数据都是通过file_get_contents(‘php://input', ‘r')。而不是从$_POST中读取,正是因为xml_rpc数据规格是xml,它的Content-Type是text/xml。5. php://input碰到了multipart/form-data,请查阅RFC1867对它的描述。multipart/form-data也表示以POST方法提交表单数据,它还伴随了文件上传,所以会跟application/x- www-form-urlencoded数据格式不一样。它会以一更种更合理的,更高效的数据格式传递给服务端。当Content-Type为multipart/form-data的时候,即便http请求body中存在数据,php://input也为空,PHP此时,不会把数据填入php://input流。所以,可以确定: php://input不能用于读取enctype=multipart/form-data数据。6. 当Content-Type为application/x- www-form-urlencoded时,php://input和$_POST数据是“一致”的,为其它Content-Type的时候,php: //input和$_POST数据数据是不一致的。因为只有在Content-Type为application/x-www-form- urlencoded或者为multipart/form-data的时候,PHP才会将http请求数据包中的body相应部分数据填入$_POST全局变量中,其它情况PHP都忽略。而php://input除了在数据类型为multipart/form-data之外为空外,其它情况都可能不为空以上转述这么多文字的意思,就是说,得用到这两种方式来读取微信传过来的数据。 ..

D. 如何用PHP实现微信支付

以PHP语言为例,对抄微信支付的开发流程进行一下说明:

1.获取订单信息。

2.根据订单信息和支付相关的账号生成sign,并且生成支付参数。

3.将支付参数信息POST到微信服务器,获取返回信息。

4.根据返回信息生成相应的支付代码(微信内部)或是支付二维码(非微信内),完成支付。

E. 如何利用PHP实现 APP端微信支付功能

一丶PHP后台后台生成预支付交易单,返回正确的预支付交易回话标识后再在APP里面调起支付!官方文档:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_1根据文档拼接微信需要的参数,这里需要几个方法,直接上代码!传输给微信的参数要组装成xml格式发送,传如参数数组!publicfunctionToXml($data=array()){if(!is_array($data)||count($data)<=0){return'数组异常';}$xml="";foreach($dataas$key=>$val){if(is_numeric($val)){$xml.="<".$key.">".$val."";}else{$xml.="<".$key.">";}}$xml.="";return$xml;}2.生成随机字符串,微信所需参数!这里方法很多,看自己爱好都行!functionrand_code(){$str='';//62个字符$str=str_shuffle($str);$str=substr($str,0,32);return$str;}3.这里是微信比较重要的一步了,这个方法会多次用到!生成签名privatefunctiongetSign($params){ksort($params);//将参数数组按照参数名ASCII码从小到大排序foreach($paramsas$key=>$item){if(!empty($item)){//剔除参数值为空的参数$newArr[]=$key.'='.$item;//整合新的参数数组}}$stringA=implode("&",$newArr);//使用&符号连接参数$stringSignTemp=$stringA."&key="."************************";//拼接key//key是在商户平台API安全里自己设置的$stringSignTemp=MD5($stringSignTemp);//将字符串进行MD5加密$sign=strtoupper($stringSignTemp);//将所有字符转换为大写return$sign;}4.传递参数给微信,生成预支付订单!接收微信返回的数据,在反给APP端,APP端调用支付接口,完成支付!APP端所需参数见微信文档:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_12&index=2publicfunctionwx_pay(){$nonce_str=$this->rand_code();//调用随机字符串生成方法获取随机字符串$data['appid']='wxdbc5dc*******';//appid$data['mch_id']='1493*****';//商户号$data['body']="APP支付测试";$data['spbill_create_ip']=$_SERVER['HTTP_HOST'];//ip地址$data['total_fee']=1;//金额$data['out_trade_no']=time().mt_rand(10000,99999);//商户订单号,不能重复$data['nonce_str']=$nonce_str;//随机字符串$data['notify_url']='https://www.5wx.org/';接收支付后的通知,必须为能直接访问的网址,不能跟参数$data['trade_type']='APP';//支付方式//将参与签名的数据保存到数组注意:以上几个参数是追加到$data中的,$data中应该同时包含开发文档中要求必填的剔除sign以外的所有数据$data['sign']=$this->getSign($data);//获取签名$xml=$this->ToXml($data);//数组转xml//curl传递给微信方$url="https://api.mch.weixin.qq.com/pay/unifiedorder";//header("Content-type:text/xml");$ch=curl_init();curl_setopt($ch,CURLOPT_URL,$url);if(stripos($url,"https://")!==FALSE){curl_setopt($ch,CURLOPT_SSLVERSION,CURL_SSLVERSION_TLSv1);curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE);curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,FALSE);}else{curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,TRUE);curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验}//设置headercurl_setopt($ch,CURLOPT_SSLVERSION,CURL_SSLVERSION_TLSv1);curl_setopt($ch,CURLOPT_HEADER,FALSE);//要求结果为字符串且输出到屏幕上curl_setopt($ch,CURLOPT_RETURNTRANSFER,TRUE);//设置超时curl_setopt($ch,CURLOPT_TIMEOUT,30);curl_setopt($ch,CURLOPT_POST,TRUE);//传输文件curl_setopt($ch,CURLOPT_POSTFIELDS,$xml);//运行curl$data=curl_exec($ch);//返回结果if($data){curl_close($ch);//返回成功,将xml数据转换为数组.$re=$this->FromXml($data);if($re['return_code']!='SUCCESS'){json("201",'签名失败');}else{//接收微信返回的数据,传给APP!$arr=array('prepayid'=>$re['prepay_id'],'appid'=>'wxdbc5dc*****','partnerid'=>'14937****','package'=>'Sign=WXPay','noncestr'=>$nonce_str,'timestamp'=>time(),);//第二次生成签名$sign=$this->getSign($arr);$arr['sign']=$sign;json('200','签名成功',$arr);}}else{$error=curl_errno($ch);curl_close($ch);json('201',"curl出错,错误码:$error");}}5.将xml数据转换为数组,接收微信返回数据时用到.publicfunctionFromXml($xml){if(!$xml){echo"xml数据异常!";}//将XML转为array//禁止引用外部xml实体libxml_disable_entity_loader(true);$data=json_decode(json_encode(simplexml_load_string($xml,'SimpleXMLElement',LIBXML_NOCDATA)),true);return$data;}二.APP支付成功后,会调用你填写的回调地址.返回参数详见微信文档:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_7&index=3//微信支付回调functionwx_notify(){//接收微信返回的数据数据,返回的xml格式$xmlData=file_get_contents('php://input');//将xml格式转换为数组$data=$this->FromXml($xmlData);//用日志记录检查数据是否接受成功,验证成功一次之后,可删除。$file=fopen('./log.txt','a+');fwrite($file,var_export($data,true));//为了防止假数据,验证签名是否和返回的一样。//记录一下,返回回来的签名,生成签名的时候,必须剔除sign字段。$sign=$data['sign'];unset($data['sign']);if($sign==$this->getSign($data)){//签名验证成功后,判断返回微信返回的if($data['result_code']=='SUCCESS'){//根据返回的订单号做业务逻辑$arr=array('pay_status'=>1,);$re=M('order')->where(['order_sn'=>$data['out_trade_no']])->save($arr);//处理完成之后,告诉微信成功结果!if($re){echo'';exit();}}//支付失败,输出错误信息else{$file=fopen('./log.txt','a+');fwrite($file,"错误信息:".$data['return_msg'].date("Y-m-dH:i:s"),time()."
");}}else{$file=fopen('./log.txt','a+');fwrite($file,"错误信息:签名验证失败".date("Y-m-dH:i:s"),time()."
");}}在这里,微信APP支付流程就成功走完了!谢谢支持!———————

F. 微信支付lavel是什么

Laravel 微信开发组件-WeChat 微信支付一、介绍本教程是LAMP开发环境下基于larvel5.1LTS版进行的开发实例。 由于现在国内有很多优秀且具备开源精神的php开发者,因此出于节约时间成本和维护成本的考虑,微信开发采用组件化开发,我们没必要重复造轮子。本教程采用 overtrue 团队的 easywechat 组件进行微信的支付功能开发和实现。由于这个组件功能过多 本篇博客主要介绍“扫码支付”的主要流程和思路。二、composer安装默认大家已经在自己的开发环境上已经安装了composer,并会一些简单的操作,安装命令: composer require "overtrue/laravel-wechat:~3.0"* 如果你用了 laravel-debugbar,请禁用或者关掉,否则这模块别想正常使用!!! * (但是composer提示是否可以关闭x-debug,会影响安装之类的提示,可以不去管它)三、在laravel中进行配置1.注册 ServiceProvider (找到 config/app.php 配置文件中,key为 providers 的数组,在数组中添加服务提供者): Overtrue\LaravelWechat\ServiceProvider::class,2.(可选)添加 * 外观 * 在app/config/app.php 的 aliases 数组里,添加 * 别名 * : 'wechat' =>Overtrue\LaravelWechat\ServiceProvider::class,3.创建配置文件(在项目根目录中运行 artisan 命令,发布配置文件到你的项目中): php artisan vendor:publish此时在/config目录下会生成配置文件wechat.php,在里面输入你的微信商家信息,这里请注意保护隐私。四、 微信支付飞起1.配置微信商家信息,laravel根目录下的.ENV文件支持以下配置: WECHAT_APPID WECHAT_SECRET WECHAT_TOKEN WECHAT_AES_KEY WECHAT_LOG_LEVEL WECHAT_LOG_FILE WECHAT_OAUTH_SCOPES WECHAT_OAUTH_CALLBACK WECHAT_PAYMENT_MERCHANT_ID WECHAT_PAYMENT_KEY WECHAT_PAYMENT_CERT_PATH WECHAT_PAYMENT_KEY_PATH WECHAT_PAYMENT_DEVICE_INFO WECHAT_PAYMENT_SUB_APP_ID WECHAT_PAYMENT_SUB_MERCHANT_ID WECHAT_ENABLE_MOCK你可以在/config/wechat.php中进行相关参数配置,也可以写在.ENV文件中,然后,wechat.php具体读取方法: 'notify_url' => env('NOTIFY_URL', 'http://www.XXXXX.com/notify_url'), // 回调地址env()默认读取.env文件中常量的值,如果.env中没有定义该常量,则返回env()的第二个参数的值。2.wechat.php文件中需要注意的地方(1).'log'数组内是日志配置。 (2).'payment'数组是主要配置的数组,主要配置商户的信息和证书。3.(重点)创建订单(1).引入命名空间 use EasyWeChat\Foundation\Application; use EasyWeChat\Payment\Order;(2).填写订单信息 $attributes = [ 'trade_type' => 'JSAPI', // JSAPI,NATIVE,APP… 'body' => 'iPad mini 16G 白色', 'detail' => 'iPad mini 16G 白色', 'out_trade_no' => '1217752501201407033233368018', 'total_fee' => 5388, 'notify_url' => 'http://xxx.com/order-notify', // 支付结果通知网址,如果不设置则会使用配置里的默认地址,我就没有在这里配,因为在.env内已经配置了。 // … ]; // 创建订单 $order = new Order($attributes); $result = $payment->prepare($order); if ($result->return_code == 'SUCCESS' && $result->result_code == 'SUCCESS') { //生产那个订单后的逻辑 \Log::info('生成订单号..'.$data->order_guid); //这一块是以ajax形式返回到页面上。 //用户的体验就是点击【确认支付】,验证码以弹层页面出来了(没错,还需要一个好用的弹层js)。 $ajax_data=[ 'html' => json_encode(\QrCode::size(250)->generate($result['code_url'])), 'out_trade_no' => $data->order_guid, 'price' => $data->price ]; return $ajax_data; }else{ return back()->withErrors('生成订单错误!'); }五、渲染页面这里创建了订单,需要生成二维码图片,可以参考一下这个二维码图片组件。Composer 设置首先,添加 QrCode 包添加到你的 composer.json 文件的 require 里:composer require "simplesoftwareio/simple-qrcode"添加 Service Provider注册 SimpleSoftwareIO\QrCode\QrCodeServiceProvider::class 至 config/app.php 的 providers 数组里.添加 Aliases最后,注册 'QrCode' => SimpleSoftwareIO\QrCode\Facades\QrCode::class 至 config/app.php 的 aliases 数组里.pay.blade.php内容<script type="text/javascript" src="{{ asset('vendor/jquery.js') }}"></script><script type="text/javascript" src="{{ asset('layer/layer.js') }}"></script><input class="wechat_btn" type="button" value="确认支付"/> {!– 这个页面需要有一些js代码,才能使支付功能更加美观可用无bug,比如ajax轮询,点击支付后的btn失效,放弃支付时关闭弹层等等 –}js内容$('.wechat_btn').click(function() { $('.my_order_guid').val(''); $('#code').val(''); //ajax生成二维码 data={ '_token':$(".token").val(),//令牌 'money':$(".money").val(),//商品价格 } sendAjax(data, "/order", function (data) { //发送二维码过来(此处使用优美的layer弹层库) layer.open({ type: 1, title:'微信支付', skin: 'layui-layer-rim', //加上边框 area: ['270px', '340px'], //宽高 content: "<p style='color:red;text-align: center;'>支付金额:"+data['price'] +"元</p> <input type='hidden' class='my_order_guid' value='"+data['out_trade_no'] +"'/><div id='code' style='text-align: center;'>"+JSON.parse(data['html'])+ "</div><p style='text-align: center;'>请使用微信扫码支付</p><script> $('.layui-layer-close').click(function() { layer.msg('您已放弃本次支付');setTimeout('window.location.reload()',3000); });</script>" //这里我把弹层库有关的一点点js写到content里面去了。 }); getInfo(); //这里写一个轮询,可以异步查询订单是否支付完成的信息,从而进行逻辑处理(比如轮询支付状态,成功了跳转页面),仅仅提点一下我的想法,轮询的代码不用找,没有贴。});});六、回调函数先放上主要代码再说:public function notifyUrl(Request $request) { $app = new Application(config('wechat')); $response = $app->payment->handleNotify(function($notify, $successful){ if ($successful) { $order_arr=json_decode($notify,true); $order_guid=$order_arr['out_trade_no'];//订单号 //回调成功的逻辑 } }); }注意(1).wechat发送回调是通过post方式,在路由处定义了之后,还需要在laravel项目中排除token验证,我建议在中间件中VerifyCsrfToken.php进行排除路由。protected $except = [//'/pay_success_notify','/To_rule_out_route'];(2). * 重点!重点!重点! * 回调这里的处理可以说是重中之重,这里出岔子,可能会造成 用户支付成功后,微信的 * 回调没有进来 * ,后台回调的逻辑就没有执行,导致用户钱花了,东西没买上(即你的服务器上没有执行给付费用户修改支付状态等数据库操作)。另一种后果,如果没有正确返回微信参数,微信会多次发送回调信息来提醒你支付成功了,导致你的服务器 * 接受回调函数多遍 * 。而此时你也马马虎虎,没有在支付成功的逻辑上对用户的支付状态进行判断,导致逻辑用户充一次钱,在数据库却重复执行了好几次相关数据库操作。前者坑了付费用户,后者坑了你的公司,这里如果不注意的话,后果只会很严重,涉及到钱的地方要倍加小心。 (2).在回调路由指向的方法内,如果你的支付成功的逻辑成功运行了,需要return true;如果没有成功进行数据库操作,需要返回false;或不返回,微信会再一次发送回调信息(post方式)。七、一些easywechat官方的建议:这里需要注意的有几个点:1.handleNotify 只接收一个 callable 参数,通常用一个匿名函数即可。2.该匿名函数接收两个参数,这两个参数分别为: $notify 为封装了通知信息的 EasyWeChat\Support\Collection 对象,前面已经讲过这里就不赘述了,你可以以对象或者数组形式来读取通知内容,比如:$notify->totalfee 或者 $notify['totalfee']。 $successful 这个参数其实就是判断 用户是否付款成功了(result_code == ‘SUCCESS’)3.该函数返回值就是告诉微信 “我是否处理完成”,如果你返回一个 false 或者一个具体的错误消息,那么微信会在稍后再次继续通知你,直到你明确的告诉它:“我已经处理完成了”,在函数里 return true; 代表处理完成。4.handleNotify 返回值 $response 是一个 Response 对象,如果你要直接输出,使用 $response->send(), 在一些框架里不是输出而是返回:return $response。5.注意:请把 “支付成功与否” 与 “是否处理完成” 分开,它俩没有必然关系。 比如:微信通知你用户支付完成,但是支付失败了(result_code 为 ‘FAIL’),你应该更新你的订单为支付失败,但是要告诉微信处理完成。后记1.在微信开发中,大量用到了laravel自带的Log查错的方法,当var_mp(),echo(),dd()等方法不能查看错误信息是,使用日志查错就可以解决了。怎样使用laravel的log服务,这个以后会讲。 2.本项目开发可以说是组件化开发,有开发速度快,代码质量高,维护成本低等优点,本例的微信开发是一个缩影。[原文地址](http://www.blog8090.com/)

G. PHP实现微信扫码支付怎么做,微信的demo报错咋搞

微信扫码首先你要确定几个步骤:1申请了微信支付,获得到微信支付所需要的appid和秘钥2有正确的回调地址,就是需要外网ip地址接收回调信息3如果以上都满足,剩下来的才是代码的问题,这个时候需要考虑比如版本问题,路径问题,配置信息问题,各个可能得问题,然后开启php的啊错误信息,对报错问题具体分析。

H. 如何用php开发微信支付接口

appid //公众号后台开发者中心获得(和邮件内的一样) mchid//邮件内获得 key//商户后台自己设置 appsecret //公众号开发者中心获得两个证书文件,邮件内获得 apiclient_cert.pem apiclient_key.pem注意事项:公众号后台微信支付-》开发配置-》新增测试目录和测试个人微信号。开发者中心-》网页授权获取用户基本信息-》修改成你的测试域名。否则会出现redirect_uri 参数

I. 如何用PHP实现微信支付,求教。新手!说明详细点

微信公众号JSAPI支付 一:配置参数 申请成功后,获取接口文件, 将所有文件放入项目根目录weixin下,在WxPay.ub.config.php中填入配置账户信息; 二:设置授权 开发者中心->网页服务->网页授权获取用户基本信息->修改; “授权回调页面域名修改成你的域名地址即可,须保证网页授权已获得,不然会报redirect_uri 参数错误; 三:网页授权获取用户openid js_api_call.php 请求文件中改动(所有传给微信的参数都在入口文件中接收) $out_trade_no = $_GET['out_trade_no']; //商户系统内部订单号 32个字符内 $total_fee = $_GET['total_fee']*100; //订单总金额 单位为分,不能带小数点,所以须把价格乘以100, 不然获取prepay_id时会报错误(设置金额字段时最好设为小数点后2位) $pay_status = get_pay_status($out_trade_no);//查看订单支付状态 $return_url = get_return_url($out_trade_no); //设置支付成功后跳转页面 //使用jsapi接口 $jsApi = new JsApi_pub(); //通过code获得openid if (!isset($_GET['code'])) { //触发微信返回code码 //设置redirect_uri参数,返回code码地址,其实就是重定向到当前页面,获取用户code码参数 $url = WxPayConf_pub::JS_API_CALL_URL."?showwxpaytitle=1&out_trade_no=$out_trade_no&total_fee=$total_fee"; $url = $jsApi->createOauthUrlForCode($url); Header("Location: $url"); }else{ //获取code码,以获取openid $code = $_GET['code']; $jsApi->setCode($code); $openid = $jsApi->getOpenId(); //用户标识 } 再就是WxPayHubHelper.php文件 JsApi_pub()类下createOauthUrlForCode($redirectUrl)方法, 第二个参数 改为 $urlObj["redirect_uri"] = urlencode($redirectUrl); //对$url变量进行url编码 不然header重定向时无法获取订单号和金额 四:设置统一支付接口参数,获取prepay_id (预支付ID 微信生成的预支付 ID,用于后续接口调用中使用) 微信支付->开发配置->支付测试->测试授权目录和测试白名单添加 (支付授权目录需要精确到最细一级的目录,且在使用时,目录名称后直接加文件名,如ccc.com/weixin/) 确保你 WxPayPubHelper.php文件里 UnifiedOrder_pub 这个类的getPrepayId这个方法能正常使用 这一步的调试在 getPrepayId()内 var_mp($this->result); 就能看到错误代码; posXml这个方法后调用了createXml这个方法 function postXml() { $xml = $this->createXml(); //**在此处查看xml文件是否正常生成 include_once("log_.php"); $log = new Log_(); $log->log_result("log.txt",$xml); //** 由于打印一些xml格式的文件只显示字符长度,不显示内容。于是用log的形式写在服务器上调试 $this->response = $this->postXmlCurl($xml,$this->url,$this->curl_timeout); return $this->response; } 保证xml这个变量格式如下; <xml><openid><![CDATA[UKqsyD_711nkk2c]]></openid> <body><![CDATA[pay]]</body> <out_trade_no>201504101658571802></out_trade_no> <total_fee>120</total_fee> <notify_url><![CDATA[http://www.hao123.com/weixin/notify_url.php]]></notify_url> <trade_type><![CDATA[JSAPI]]></trade_type> <appid><![CDATA[wxfd3c4asdf]]></appid> <mch_id>123334333102</mch_id> <spbill_create_ip><![CDATA[192.168.0.1]]></spbill_create_ip> <nonce_str><![CDATA[imsdasdcmlkhfa]]></nonce_str> <sign><![CDATA[CBE62F36806A3E1]]></sign></xml>参数正确,postXmlCurl才能正确提交,提交后就能得到正确的prepay_id,就能弹出支付框了五:使用jsapi调起支付 根据prepay_id生成jsapi支付参数 $jsApi->setPrepayId($prepay_id); $jsApiParameters = $jsApi->getParameters(); //调用微信JS api 支付 function jsApiCall() { WeixinJSBridge.invoke( 'getBrandWCPayRequest', <?php echo $jsApiParameters; ?>, function(res){ WeixinJSBridge.log(res.err_msg); if(res.err_msg == "get_brand_wcpay_request:ok") { //支付成功后 window.location.href="<?php echo $return_url;?>" //跳转地址及订单操作,在异步页面也须处理订单,防止同步时失败 }else{ alert("支付失败"+res.err_code+res.err_desc+res.err_msg); } } ); }(每次请求callpay方法时须判断订单状态,防止重复提交) 六:通用通知接口 异步处理微信返回结果 支付完成后,notify.php中获取微信的回调 $xml = $GLOBALS['HTTP_RAW_POST_DATA']; //须验证签名,并回应微信。 if($notify->checkSign() == TRUE) //签名验证通过并更新订单状态后 $notify->setReturnParameter("return_code","SUCCESS"); //设置返回码,保证支付状态改变后才返回成功 //对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败, //微信会通过一定的策略(如30分钟共8次)定期重新发起通知, $returnXml = $notify->returnXml(); echo $returnXml;(将xml数据返回微信 当return_code为SUCCESS时,不会再通知) //当收到通知进行处理时,首先检查对应业务数据的状态,判断该通知是否已经处理过,如果没有处理过再进行处理, 如果处理过直接返回结果成功。在对业务数据进行状态检查和处理之前,要采用数据锁进行并发控制, 以避免函数重入造成的数据混乱. //判断是否在微信浏览器打开 function isWeiXin(){ var ua = window.navigator.userAgent.toLowerCase(); if(ua.match(/MicroMessenger/i) == 'micromessenger'){ return true; }else{ return false; } } 步骤够详细了吧,我自己实现过,所以写了日志,结合php版本的demo 大致弄得出来了,如果对整个流程不太清楚,仔细的看完微信公众号支付接口文档,你申请微信公众号支付成功了就会有的,

J. php微信支付接口开发流程