PHP实现微信支付(jsapi支付)流程步骤详解
最近接触到一个项目,涉及到微信支付,搞微信开发这么久以来,还没搞过支付,之前也就搞过公众号发红包,感谢前辈们的探索,我看了他们的博文,让我少走了很多弯路。
前期准备:
1.微信认证服务号,并且开通了微信支付
2.微信支付sdk,下载地址:
3.登录微信支付平台下载支付证书
方法步骤:
1.demo文件处理
(1)将官方的demo下载下来,文件名为wxpayapi_php_v3,把这文件重命名为wxpay,为了后边书写目录方便;
(2)打开lib文件夹下的wxpay.api.php文件,在537行有一段curl网络请求配置代码:
curl_setopt($ch,curlopt_ssl_verifypeer,true); curl_setopt($ch,curlopt_ssl_verifyhost,2);//严格校验
替换成:
curl_setopt($ch,curlopt_ssl_verifypeer,false); curl_setopt($ch,curlopt_ssl_verifyhost,2);//严格校验
为了禁止 curl 验证对等证书(peer's certificate)。
(3)打开lib文件夹下的wxpay.config.php文件,第25行开始,根据自己的账号完成基本信息设置;
const appid = '公众账号appid'; const mchid = '商户号'; const key = '商户支付密钥'; const appsecret = '公众帐号secert';
(4)打开lib文件夹下的wxpay.notify.php文件,第79行的代码:
if($needsign == true && $this->getreturn_code($return_code) == "success") { $this->setsign(); }
改成:
if($needsign == true && $this->getreturn_code() == "success") { $this->setsign(); }
(5)打开cert证书目录,将里边的两个证书换成自己的支付证书。
2.公众号后台设置
(1)配置网页授权域名,我的域名是(xy.chuyin.ren);
(1)配置支付授权目录,域名是(xy.chuyin.ren),我将demo放到此域名指向的目录的weixinopen/文件夹下,demo中jsapi.php文件位于example/目录下,所以支付授权目录为:xy.chuyin.ren/weixinopen/wxpay/example/
3.支付流程
打开example目录下的jsapi.php文件,支付发起和处理,都是在这里完成。
(1)获取用户openid
之前配置好了自己的appid和appsecert,所以这里不用处理。
//①、获取用户openid $tools = new jsapipay(); $openid = $tools->getopenid();
这里首先初始化的一个jsapipay()类得到一个对象,文件对应example/目录下的wxpay.jsapipay.php,调用getopenid()方法,会自动获取自己的openid。
(2)统一下单
//②、统一下单 $input = new wxpayunifiedorder(); $input->setbody("test"); $input->setattach("test"); $input->setout_trade_no(wxpayconfig::mchid.date("ymdhis")); $input->settotal_fee("1"); $input->settime_start(date("ymdhis")); $input->settime_expire(date("ymdhis", time() + 600)); $input->setgoods_tag("test"); $input->setnotify_url("http://paysdk.weixin.qq.com/example/notify.php"); $input->settrade_type("jsapi"); $input->setopenid($openid); $order = wxpayapi::unifiedorder($input); echo '<font color="#f00"><b>统一下单支付单信息</b></font><br/>'; printf_info($order); $jsapiparameters = $tools->getjsapiparameters($order);
对应wxpay.api.php的第24行的unifiedorder()方法,配置订单信息和支付回调函数,这里需要修改几个参数:
a. 商品名称:
$input->setbody("test");
b. 订单号
$input->setout_trade_no(wxpayconfig::mchid.date("ymdhis"));
c. 支付金额
$input->settotal_fee("1");
d. 支付验证链接
设置为你的notify.php文件所在的位置,所以我这里设置为:
也可以写其他地址,当然要在支付授权域名之下,支付成功之后就会自动回调到该链接指定的方法里边,可以在里边进行判断和数据库操作.
$input->setnotify_url(http://paysdk.weixin.qq.com/example/notify.php);
e. 附加参数
$input->setattach("test");
附加参数,可填可不填,填写的话,里边字符串最好不要出现空格。
这时候,点击支付应该就可以成功支付了。
(3)发起支付
<script type="text/javascript"> //调用微信js api 支付 function jsapicall() { weixinjsbridge.invoke( 'getbrandwcpayrequest', <?php echo $jsapiparameters; ?>, function(res){ weixinjsbridge.log(res.err_msg); alert(res.err_code+res.err_desc+res.err_msg); } ); } function callpay() { if (typeof weixinjsbridge == "undefined"){ if( document.addeventlistener ){ document.addeventlistener('weixinjsbridgeready', jsapicall, false); }else if (document.attachevent){ document.attachevent('weixinjsbridgeready', jsapicall); document.attachevent('onweixinjsbridgeready', jsapicall); } }else{ jsapicall(); } } </script>
点击立即支付按钮调用的就是 callpay() 函数,他有会调用jsapicall() 函数打开支付程序。
jsapicall() 函数会监听每一步动作:
res.err_msg 为get_brand_wcpay_request:cancel
表明前端判断的取消支付,es.err_msg 为get_brand_wcpay_request:ok 表明前端判断的支付成功,我们可以根据这个将支付跳转到成功页面。
(4)支持成功回调
通过前端jsapicall()函数可以监听支付结果,但是这个并不可信。确认是否支付成功还是应当通过notify.php 处理业务逻辑。前边配置好了支付验证链接setnotify_url(),支付完成后,微信服务器会根据链接自动请求你的notify.php文件,打开这个文件,其实这个文件最主要的代码就两行:
$notify = new paynotifycallback(); $notify->handle(false);
由此跟踪到wxpay.notify.php类文件的handle()函数:
/** * * 回调入口 * @param bool $needsign 是否需要签名输出 */ final public function handle($needsign = true) { $msg = "ok"; //当返回false的时候,表示notify中调用notifycallback回调失败获取签名校验失败,此时直接回复失败 $result = wxpayapi::notify(array($this, 'notifycallback'), $msg); if($result == false){ $this->setreturn_code("fail"); $this->setreturn_msg($msg); $this->replynotify(false); return; } else { //该分支在成功回调到notifycallback方法,处理完成之后流程 $this->setreturn_code("success"); $this->setreturn_msg("ok"); } $this->replynotify($needsign); }
主要代码:
$result = wxpayapi::notify(array($this, 'notifycallback'), $msg);
然后来到wxpay.api.php文件的第411行,notify()函数:
/** * * 支付结果通用通知 * @param function $callback * 直接回调函数使用方法: notify(you_function); * 回调类成员函数方法:notify(array($this, you_function)); * $callback 原型为:function function_name($data){} */ public static function notify($callback, &$msg) { //获取通知的数据 $xml = $globals['http_raw_post_data']; //file_put_contents('log.txt',$xml,file_append); //如果返回成功则验证签名 try { $result = wxpayresults::init($xml); } catch (wxpayexception $e){ $msg = $e->errormessage(); return false; } return call_user_func($callback, $result); }
这里面的$xml=$globals['http_raw_post_data'],就是支付成功后用户返回给你的一个结果,他是一个xml格式的字符串。
我们可以将这里返回的xml数据记录下来,然后打开看看$out_trade_no就是在支付之前我自己设置的订单号码,$attach就是设置的附加参数。
得到了这个订单号,然后我就直接在下面写支付成功后的逻辑了,比如改变数据库中的数据等等。
这样 微信支付的 jsapi支付就大致分析完成了。
这是集成了官方的sdk实现的,如果不使用sdk,可以使用更简单的方法,见:php实现微信支付(jsapi支付)和退款(无需集成支付sdk)
总结
以上所述是小编给大家介绍的php实现微信支付(jsapi支付)流程步骤详解,希望对大家有所帮助