ThinkPHP 开发微信支付接口

最近有个微商城做了微信支付的接口,现在整理一下发上来。

首先是需要有已开通微信支付接口的公众号,这个相信大家都知道,开通之后微信会发一封邮件到你的邮箱,邮件的内容就是开发需要用到的一些接口信息了(包含账号密码之类的东西)。

开发步骤

一、进入公众号平台,先设置几个参数,包括绑定域名、设置回调地址等等。

1、在设置 -> 公众号设置 -> 功能设置 -> 设置JS接口安全域名

ThinkPHP 开发微信支付接口_第1张图片

2、在微信支付 -> 开发配置 -> 配置你的js支付接口,回调地址等等,正式目录和测试目录都可以写上,测试目录需要把个人微信号先添加到白名单才能使用(提醒:用TP框架的小伙伴们在填写支付授权目录时可以这样填写:域名/index.php/控制器/,经测试是可以通过的,微信一样能检测到,之前看到网上有人说这样不行,可能是现在升级了吧,呵呵,还有一个就是域名一定要是已经备过案的才行,如果是在本地进行测试的小伙伴们可以使用花生壳,我不是在打广告,个人觉得还是挺好用的)

ThinkPHP 开发微信支付接口_第2张图片

3、在开发者中心把“网页授权获取用户基本信息”的域名写上自己的域名,微信登陆时需要用到的;

ThinkPHP 开发微信支付接口_第3张图片

二、到上面一大步设置完成后就可以开始我们的开发工作了;

1、用TP的小伙伴们可以用下面的包放到tp的扩展里,也可以自行到官网下载sdk包,具体目录:ThinkPHP\Library\Vendor\,其它就可以不用管啦;

2、打开包里的WxPayPubConfig.php文件,填写上你的微信支付的接口信息就好啦;

三、上面二大步都是配置,这一步就是写支付类了,其实也没什么的,复制粘贴就好了;

1、新建Wxpay控制器,当然你也可以自己命名,访问的名称要跟你在微信上配置的授权目录一样就好了;点击这里下载Wxpay

2、代码的地方就不多说了,下面直接上代码;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
namespace  Home\Controller;
use  Think\Controller;
//微信支付类
class  WxpayController  extends  Controller {
     //获取access_token过程中的跳转uri,通过跳转将code传入jsapi支付页面
     public  function  js_api_call() {
         $order_sn  = I( 'get.order_sn' '' );
         if  ( empty ( $order_sn )) {
             header( 'location:' .__ROOT__. '/' );
         }
         vendor( 'Weixinpay.WxPayPubHelper' );
         //使用jsapi接口
         $jsApi  new  \JsApi_pub();
         //=========步骤1:网页授权获取用户openid============
         //通过code获得openid
         if  (!isset( $_GET [ 'code' ])){
             //触发微信返回code码
             $url  $jsApi ->createOauthUrlForCode( '域名/Wxpay/js_api_call?order_sn=' . $order_sn );
             //$url = $jsApi->createOauthUrlForCode(\WxPayConf_pub::JS_API_CALL_URL);
             Header( "Location: $url" ); 
         } else {
             //获取code码,以获取openid
             $code  $_GET [ 'code' ];
             $jsApi ->setCode( $code );
             $openid  $jsApi ->getOpenId();
         }
         $res  array (
             'order_sn'  =>  '20150109113322' ,
             'order_amount'  => 255
         );
         //=========步骤2:使用统一支付接口,获取prepay_id============
         //使用统一支付接口
         $unifiedOrder  new  \UnifiedOrder_pub();
         //设置统一支付接口参数
         //设置必填参数
         //appid已填,商户无需重复填写
         //mch_id已填,商户无需重复填写
         //noncestr已填,商户无需重复填写
         //spbill_create_ip已填,商户无需重复填写
         //sign已填,商户无需重复填写
         $total_fee  $res [ 'order_amount' ]*100;
         //$total_fee = 1;
         $body  "订单支付{$res['order_sn']}" ;
         $unifiedOrder ->setParameter( "openid" "$openid" ); //用户标识
         $unifiedOrder ->setParameter( "body" $body ); //商品描述
         //自定义订单号,此处仅作举例
         $out_trade_no  $res [ 'order_sn' ];
         $unifiedOrder ->setParameter( "out_trade_no" $out_trade_no ); //商户订单号 
         $unifiedOrder ->setParameter( "total_fee" $total_fee ); //总金额
         //$unifiedOrder->setParameter("attach", "order_sn={$res['order_sn']}");//附加数据 
         $unifiedOrder ->setParameter( "notify_url" , \WxPayConf_pub::NOTIFY_URL); //通知地址 
         $unifiedOrder ->setParameter( "trade_type" "JSAPI" ); //交易类型
         //非必填参数,商户可根据实际情况选填
         //$unifiedOrder->setParameter("sub_mch_id","XXXX");//子商户号  
         //$unifiedOrder->setParameter("device_info","XXXX");//设备号 
         //$unifiedOrder->setParameter("attach","XXXX");//附加数据 
         //$unifiedOrder->setParameter("time_start","XXXX");//交易起始时间
         //$unifiedOrder->setParameter("time_expire","XXXX");//交易结束时间 
         //$unifiedOrder->setParameter("goods_tag","XXXX");//商品标记 
         //$unifiedOrder->setParameter("openid","XXXX");//用户标识
         //$unifiedOrder->setParameter("product_id","XXXX");//商品ID
         $prepay_id  $unifiedOrder ->getPrepayId();
         //=========步骤3:使用jsapi调起支付============
         $jsApi ->setPrepayId( $prepay_id );
         $jsApiParameters  $jsApi ->getParameters();
         $wxconf  = json_decode( $jsApiParameters , true);
         if  ( $wxconf [ 'package' ] ==  'prepay_id=' ) {
             $this ->error( '当前订单存在异常,不能使用支付' );
         }
         $this ->assign( 'res' $res );
         $this ->assign( 'jsApiParameters' $jsApiParameters );
         $this ->display( 'jsapi' );
     }
     //异步通知url,商户根据实际开发过程设定
     public  function  notify_url() {
         vendor( 'Weixinpay.WxPayPubHelper' );
         //使用通用通知接口
         $notify  new  \Notify_pub();
         //存储微信的回调
         $xml  $GLOBALS [ 'HTTP_RAW_POST_DATA' ];    
         $notify ->saveData( $xml );
         //验证签名,并回应微信。
         //对后台通知交互时,如果微信收到商户的应答不是成功或超时,微信认为通知失败,
         //微信会通过一定的策略(如30分钟共8次)定期重新发起通知,
         //尽可能提高通知的成功率,但微信不保证通知最终能成功。
         if ( $notify ->checkSign() == FALSE){
             $notify ->setReturnParameter( "return_code" "FAIL" ); //返回状态码
             $notify ->setReturnParameter( "return_msg" "签名失败" ); //返回信息
         } else {
             $notify ->setReturnParameter( "return_code" "SUCCESS" ); //设置返回码
         }
         $returnXml  $notify ->returnXml();
         //==商户根据实际情况设置相应的处理流程,此处仅作举例=======
         //以log文件形式记录回调信息
         //$log_name = "notify_url.log";//log文件路径
         //$this->log_result($log_name, "【接收到的notify通知】:\n".$xml."\n");
         $parameter  $notify ->xmlToArray( $xml );
         //$this->log_result($log_name, "【接收到的notify通知】:\n".$parameter."\n");
         if ( $notify ->checkSign() == TRUE){
             if  ( $notify ->data[ "return_code" ] ==  "FAIL" ) {
                 //此处应该更新一下订单状态,商户自行增删操作
                 //$this->log_result($log_name, "【通信出错】:\n".$xml."\n");
                 //更新订单数据【通信出错】设为无效订单
                 echo  'error' ;
             }
             else  if ( $notify ->data[ "result_code" ] ==  "FAIL" ){
                 //此处应该更新一下订单状态,商户自行增删操作
                 //$this->log_result($log_name, "【业务出错】:\n".$xml."\n");
                 //更新订单数据【通信出错】设为无效订单
                 echo  'error' ;
             }
             else {
                 //$this->log_result($log_name, "【支付成功】:\n".$xml."\n");
                 //我这里用到一个process方法,成功返回数据后处理,返回地数据具体可以参考微信的文档
                 if  ( $this ->process( $parameter )) {
                     //处理成功后输出success,微信就不会再下发请求了
                     echo  'success' ;
                 } else  {
                     //没有处理成功,微信会间隔的发送请求
                     echo  'error' ;
                 }
             }
         }
     }
     //订单处理
     private  function  process( $parameter ) {
         //此处应该更新一下订单状态,商户自行增删操作
         /*
         * 返回的数据最少有以下几个
         * $parameter = array(
             'out_trade_no' => xxx,//商户订单号
             'total_fee' => XXXX,//支付金额
             'openid' => XXxxx,//付款的用户ID
         );
         */
         return  true;
     }
}
?>

四、以上就是微信支付的整个流程了,扫码支付的应该都差不多,我没去弄了,用过的朋友也可以分享下,^_^;来上几张支付的截图

ThinkPHP 开发微信支付接口_第4张图片

你可能感兴趣的:(php支付)