源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
查看: 435|回复: 23

[PHP编程] PHP实现微信支付(jsapi支付)和退款(无需集成支付SDK)流程教程详解

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2018-3-15 09:39:10 | 显示全部楼层 |阅读模式
本篇文章给大家介绍PHP实现微信支付(jsapi支付)和退款(无需集成支付SDK)流程教程详解,使用了微信官方给的php版本的sdk,但是在使用过程中有很多问题,今天给大家讲讲不集成支付SDK直接调用支付接口实现支付和退款,感兴趣的朋友一起看看吧

之前有写过几篇文章将微信支付和退款:

1.PHP实现微信支付(jsapi支付)流程
2.ThinkPHP中实现微信支付(jsapi支付)流程
3.PHP实现微信申请退款

这几篇都是使用了微信官方给的PHP版本的SDK,进行支付的时候写代码可以省不少事,步骤也挺简化,但是集成SDK有很多坑,很多人说引入的SDK老报错,或者说官方SDK本身有不少错误,改起来很麻烦,也确实挺麻烦的,对于新手搞支付很容易被绕进去,那么今天就来讲讲不集成支付SDK直接调用支付接口实现支付和退款。

前期准备:

1.当然了,还是要有一个微信认证服务号,并且开通了微信支付;

2.在微信商户后台配置好支付授权目录,同时准备好支付的Api证书(支付用不到,退款的时候使用)

3.调用接口支付的话,必须要先知道该用户的openid,所以要先知道怎么获取用户的openid,这个也很简单,我之前也有文章讲怎么获取用户的openid,详见文章微信公众号获取用户的openid。

好了,话不多说,直接贴上主要代码:

/** 
 * 微信支付请求接口(POST) 
 * @param string $openid openid 
 * @param string $body 商品简单描述 
 * @param string $order_sn 订单编号 
 * @param string $total_fee 金额 
 * @return json的数据 
 */ 
public function wxpay($openid,$total_fee,$body,$order_sn){ 
 $config = $this->config; 
 //统一下单参数构造 
 $unifiedorder = array( 
 'appid' => $config['appid'], 
 'mch_id' => $config['mch_id'], 
 'nonce_str' => self::getNonceStr(), 
 'body' => $body, 
 'out_trade_no' => $order_sn, 
 'total_fee' => $total_fee * 100, 
 'spbill_create_ip' => self::getip(), 
 'notify_url' => 'http://'.$_SERVER['HTTP_HOST'].'/notify.php', 
 'trade_type' => 'JSAPI', 
 'openid' => $openid 
 ); 
 $unifiedorder['sign'] = self::makeSign($unifiedorder); 
 //return $unifiedorder; 
 //请求数据,统一下单 
 $xmldata = self::array2xml($unifiedorder); 
 $url = 'https://api.mch.weixin.qq.com/pay/unifiedorder'; 
 $res = self::curl_post_ssl($url, $xmldata); 
 if(!$res){ 
 return array('status'=>0, 'msg'=>"Can't connect the server" ); 
 } 
 // 这句file_put_contents是用来查看服务器返回的结果 测试完可以删除了 
 //file_put_contents('./log.txt',$res,FILE_APPEND); 
 $content = self::xml2array($res); 
 if(strval($content['result_code']) == 'FAIL'){ 
 return array('status'=>0, 'msg'=>strval($content['err_code']).':'.strval($content['err_code_des'])); 
 } 
 if(strval($content['return_code']) == 'FAIL'){ 
 return array('status'=>0, 'msg'=>strval($content['return_msg'])); 
 } 
 $time = time(); 
 settype($time, "string"); //jsapi支付界面,时间戳必须为字符串格式 
 $resdata = array( 
 'appId' => strval($content['appid']), 
 'nonceStr' => strval($content['nonce_str']), 
 'package' => 'prepay_id='.strval($content['prepay_id']), 
 'signType' => 'MD5', 
 'timeStamp' => $time 
 ); 
 $resdata['paySign'] = self::makeSign($resdata); 
 return json_encode($resdata); 
} 
/** 
 * 微信退款(POST) 
 * @param string(28) $transaction_id 在微信支付的时候,微信服务器生成的订单流水号,在支付通知中有返回 
 * @param string $out_refund_no 商品简单描述 
 * @param string $total_fee 微信支付的时候支付的总金额(单位:分) 
 * @param string $refund_fee 此次要退款金额(单位:分) 
 * @return string  xml格式的数据 
 */ 
public function refund($transaction_id,$out_refund_no,$total_fee,$refund_fee){ 
 $config = $this->config; 
 //退款参数 
 $refundorder = array( 
 'appid' => $config['appid'], 
 'mch_id' => $config['mch_id'], 
 'nonce_str' => self::getNonceStr(), 
 'transaction_id'=> $transaction_id, 
 'out_refund_no' => $out_refund_no, 
 'total_fee' => $total_fee * 100, 
 'refund_fee' => $refund_fee * 100 
 ); 
 $refundorder['sign'] = self::makeSign($refundorder); 
 //请求数据,进行退款 
 $xmldata = self::array2xml($refundorder); 
 $url = 'https://api.mch.weixin.qq.com/secapi/pay/refund'; 
 $res = self::curl_post_ssl($url, $xmldata); 
 if(!$res){ 
 return array('status'=>0, 'msg'=>"Can't connect the server" ); 
 } 
 // 这句file_put_contents是用来查看服务器返回的结果 测试完可以删除了 
 //file_put_contents('./log3.txt',$res,FILE_APPEND); 
 $content = self::xml2array($res); 
 if(strval($content['result_code']) == 'FAIL'){ 
 return array('status'=>0, 'msg'=>strval($content['err_code']).':'.strval($content['err_code_des'])); 
 } 
 if(strval($content['return_code']) == 'FAIL'){ 
 return array('status'=>0, 'msg'=>strval($content['return_msg'])); 
 } 
 return $content; 
} 

这是封装好的类,使用起来也超级简单:

<?php 
require_once "wxpay.class.php"; 
$config = array( 
 'wxappid' => 'wx123456789876', 
 'mch_id' => '123456789', 
 'pay_apikey' => '123456789876123456789876123456789876' 
); 
$wxpay = new WxPay($config); 
$result = $wxpay->paytest(); 
?> 
<html> 
<head> 
 <meta http-equiv="content-type" content="text/html;charset=utf-8"/> 
 <meta name="viewport" content="width=device-width, initial-scale=1"/> 
 <title>江南极客支付</title> 
 <script type="text/javascript"> 
 //调用微信JS api 支付 
 function jsApiCall() 
 { 
 WeixinJSBridge.invoke( 
 'getBrandWCPayRequest',<?php echo $result; ?>, 
 function(res){ 
 WeixinJSBridge.log(res.err_msg); 
 //alert(res); 
 if(res.err_msg == "get_brand_wcpay_request:ok"){ 
  alert("支付成功!"); 
 }else if(res.err_msg == "get_brand_wcpay_request:cancel"){ 
  alert("用户取消支付!"); 
 }else{ 
  alert("支付失败!"); 
 } 
 } 
 ); 
 } 
 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> 
</head> 
<body> 
 <br/> 
 <font color="#9ACD32"><b>该笔订单支付金额为<span style="color:#f00;font-size:50px">1分</span>钱</b></font><br/><br/> 
 <font color="#9ACD32"><b><span style="color:#f00;font-size:50px;margin-left:40%;">1分</span>钱也是爱</b></font><br/><br/> 
 <div align="center"> 
 <button style="width:210px; height:50px; border-radius: 15px;background-color:#FE6714; border:0px #FE6714 solid; cursor: pointer; color:white; font-size:16px;" type="button" onclick="callpay()" >果断买买买^_^</button> 
 </div> 
</body> 
</html> 

至于支付回调验证,这里就不过多讲了,不明白的可以看ThinkPHP中实现微信支付(jsapi支付)流程,这里详细讲了如何处理回调。

类文件以及使用实例代码源码下载:http://xiazai.jb51.net/201803/yuanma/php_jsapi_jb51.rar

总结

以上所述是小编给大家介绍的PHP实现微信支付(jsapi支付)和退款(无需集成支付SDK)流程教程详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

回复

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2022-8-8 20:50:54 | 显示全部楼层
8888888888888888
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2022-8-17 19:04:02 | 显示全部楼层
2222222222222222
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

99

积分

注册会员

Rank: 2

积分
99
发表于 2023-2-23 12:33:17 | 显示全部楼层
很不错的源码论坛
回复 支持 反对

使用道具 举报

1

主题

2万

回帖

55

积分

注册会员

Rank: 2

积分
55
发表于 2023-4-10 23:45:57 | 显示全部楼层
人都不在了啊 啊
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-10-27 07:48:03 | 显示全部楼层
呵呵呵呵呵呵
回复 支持 反对

使用道具 举报

4

主题

2万

回帖

58

积分

注册会员

Rank: 2

积分
58
发表于 2023-11-16 21:07:12 | 显示全部楼层
来看看怎么样
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-12-2 13:30:34 | 显示全部楼层
数据库了多久撒快乐的健身卡啦
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

69

积分

注册会员

Rank: 2

积分
69
发表于 2024-3-14 02:16:19 | 显示全部楼层
下载来瞧瞧
回复 支持 反对

使用道具 举报

2

主题

2万

回帖

73

积分

注册会员

Rank: 2

积分
73
发表于 2024-4-30 07:10:56 | 显示全部楼层
不错的源码论坛
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2024-11-28 04:27 , Processed in 0.095720 second(s), 26 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表