音效素材网提供各类素材,打造精品素材网站!

站内导航 站长工具 投稿中心 手机访问

音效素材

PHP实现微信支付(jsapi支付)和退款(无需集成支付SDK)流程教程详解
日期:2021-09-06 20:05:24   来源:脚本之家

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

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)流程教程详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

    您感兴趣的教程

    在docker中安装mysql详解

    本篇文章主要介绍了在docker中安装mysql详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编...

    详解 安装 docker mysql

    win10中文输入法仅在桌面显示怎么办?

    win10中文输入法仅在桌面显示怎么办?

    win10系统使用搜狗,QQ输入法只有在显示桌面的时候才出来,在使用其他程序输入框里面却只能输入字母数字,win10中...

    win10 中文输入法

    一分钟掌握linux系统目录结构

    这篇文章主要介绍了linux系统目录结构,通过结构图和多张表格了解linux系统目录结构,感兴趣的小伙伴们可以参考一...

    结构 目录 系统 linux

    PHP程序员玩转Linux系列 Linux和Windows安装

    这篇文章主要为大家详细介绍了PHP程序员玩转Linux系列文章,Linux和Windows安装nginx教程,具有一定的参考价值,感兴趣...

    玩转 程序员 安装 系列 PHP

    win10怎么安装杜比音效Doby V4.1 win10安装杜

    第四代杜比®家庭影院®技术包含了一整套协同工作的技术,让PC 发出清晰的环绕声同时第四代杜比家庭影院技术...

    win10杜比音效

    纯CSS实现iOS风格打开关闭选择框功能

    这篇文章主要介绍了纯CSS实现iOS风格打开关闭选择框,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作...

    css ios c

    Win7如何给C盘扩容 Win7系统电脑C盘扩容的办法

    Win7如何给C盘扩容 Win7系统电脑C盘扩容的

    Win7给电脑C盘扩容的办法大家知道吗?当系统分区C盘空间不足时,就需要给它扩容了,如果不管,C盘没有足够的空间...

    Win7 C盘 扩容

    百度推广竞品词的投放策略

    SEM是基于关键词搜索的营销活动。作为推广人员,我们所做的工作,就是打理成千上万的关键词,关注它们的质量度...

    百度推广 竞品词

    Visual Studio Code(vscode) git的使用教程

    这篇文章主要介绍了详解Visual Studio Code(vscode) git的使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。...

    教程 Studio Visual Code git

    七牛云储存创始人分享七牛的创立故事与

    这篇文章主要介绍了七牛云储存创始人分享七牛的创立故事与对Go语言的应用,七牛选用Go语言这门新兴的编程语言进行...

    七牛 Go语言

    Win10预览版Mobile 10547即将发布 9月19日上午

    微软副总裁Gabriel Aul的Twitter透露了 Win10 Mobile预览版10536即将发布,他表示该版本已进入内部慢速版阶段,发布时间目...

    Win10 预览版

    HTML标签meta总结,HTML5 head meta 属性整理

    移动前端开发中添加一些webkit专属的HTML5头部标签,帮助浏览器更好解析HTML代码,更好地将移动web前端页面表现出来...

    移动端html5模拟长按事件的实现方法

    这篇文章主要介绍了移动端html5模拟长按事件的实现方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家...

    移动端 html5 长按

    HTML常用meta大全(推荐)

    这篇文章主要介绍了HTML常用meta大全(推荐),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参...

    cdr怎么把图片转换成位图? cdr图片转换为位图的教程

    cdr怎么把图片转换成位图? cdr图片转换为

    cdr怎么把图片转换成位图?cdr中插入的图片想要转换成位图,该怎么转换呢?下面我们就来看看cdr图片转换为位图的...

    cdr 图片 位图

    win10系统怎么录屏?win10系统自带录屏详细教程

    win10系统怎么录屏?win10系统自带录屏详细

    当我们是使用win10系统的时候,想要录制电脑上的画面,这时候有人会想到下个第三方软件,其实可以用电脑上的自带...

    win10 系统自带录屏 详细教程

    + 更多教程 +
    ASP编程JSP编程PHP编程.NET编程python编程