如何将ThinkPHP6与微信H5支付无缝对接?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1471个文字,预计阅读时间需要6分钟。
微信H5支付是移动端电商平台不可或缺的功能,今天我们带领大家实现ThinkPHP6对接微信H5支付。一、准备工作做微信支付同样需要企业资质,需要拥有一个已认证的微信服务号。
微信H5支付是移动端电商网页必不可少的功能,今天我们就带领大家来实现ThinkPHP6对接实现微信H5支付。一、准备工作
做微信支付同样需要企业资质,需要拥有一个已经认证的微信服务号,当然这个是需要缴纳300元给微信的。
具体申请的资质后,我们打开微信支付平台,在导航上点击“产品中心”-》点击‘H5支付’,在打开的页面中,填写并配置相关域名信息,填写好之后就可以等待微信官方审核通过了。如果申请不通过,微信会告知原因,直到H5支付通过开通成功。
二、对接微信H5支付
我们首先打开微信H5支付的官方文档,很遗憾,微信H5支付并没有像Native扫码支付那样给我们准备官方SDK&DEMO,没有官方SDK&DEMO,我们就需要自己集成了。
微信H5支付并不难,我们完全阅读统一下单章节。
1、准备参数。
微信官方已经给我们详细的列举了参数,这些参数获取并不难,我们需要注意两个参数:一个是签名sign,一个是终端IPspbill_create_ip。
签名sign官方已经给出了详细的说明,我们按key1=value1&key2=value2形式根据ASCII码从小到大排序。排序后得到StringA,然后再用得到的StringA和key拼接,最后都转成大写。
我们来看详细代码:
public function index(){ $url = "api.mch.weixin.qq.com/pay/unifiedorder";//微信传参地址 //1.获取调用统一下单接口所需必备参数 $appid = 'wxff5b6b241a4fb11';//微信公众号appid $mch_id = '152223331';//微信支付商户号 $key = 'b304911d6a9f7728d264dfd695ebae1';//自己设置的微信商家key $out_trade_no = time();//平台内部订单号 $nonce_str=MD5(time());//随机字符串 $body = '商品购买';//付款内容 $total_fee = 1;//订单总金额,单位为分 $spbill_create_ip = $this -> get_client_ip(); //获得用户设备IP $attach = 'weixinh5';//附加数据(自定义,在支付通知中原样返回) $notify_url = "www.xxx.cn/mobile/WechatPay/notify";//通知地址 $trade_type = 'MWEB';//交易类型,微信H5支付时固定为MWEB //2.将参数按照key=value的格式,并按照参数名ASCII字典序排序生成字符串 $signA ="appid=$appid&attach=$attach&body=$body&mch_id=$mch_id&nonce_str=$nonce_str¬ify_url=$notify_url&out_trade_no=$out_trade_no&spbill_create_ip=$spbill_create_ip&total_fee=$total_fee&trade_type=$trade_type"; //3.拼接字符串 $strSignTmp = $signA."&key=$key"; //4.MD5加密后转换成大写 $sign = strtoupper(MD5($strSignTmp)); //5.拼接成所需XML格式 $post_data = "<xml> <appid>$appid</appid> <attach>$attach</attach> <body>$body</body> <mch_id>$mch_id</mch_id> <nonce_str>$nonce_str</nonce_str> <notify_url>$notify_url</notify_url> <out_trade_no>$out_trade_no</out_trade_no> <spbill_create_ip>$spbill_create_ip</spbill_create_ip> <total_fee>$total_fee</total_fee> <trade_type>$trade_type</trade_type> <sign>$sign</sign> </xml>"; }
在这里用到一个$this -> get_client_ip()获取ip地址,我们看该方法的代码:
public function get_client_ip() { if(getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')) { $ip = getenv('HTTP_CLIENT_IP'); } elseif(getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')) { $ip = getenv('HTTP_X_FORWARDED_FOR'); } elseif(getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), 'unknown')) { $ip = getenv('REMOTE_ADDR'); } elseif(isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')) { $ip = $_SERVER['REMOTE_ADDR']; } return preg_match ( '/[\d\.]{7,15}/', $ip, $matches ) ? $matches [0] : ''; }
2、将参数post到官方地址。
官方的地址是URL地址:api.mch.weixin.qq.com/pay/unifiedorder,这个地址是不允许更改的。我们把准备好的xml参数post过去。
$dataxml = $this -> api.mch.weixin.qq.com/pay/unifiedorder";//微信传参地址 //1.获取调用统一下单接口所需必备参数 $appid = 'wxff5b68b241a4fb11';//微信公众号appid $mch_id = '1522223331';//微信支付商户号 $key = 'b304911d6a19f7728d264dfd695ebae1';//自己设置的微信商家key $out_trade_no = time();//平台内部订单号 $nonce_str=MD5(time());//随机字符串 $body = '商品购买';//付款内容 $total_fee = 1;//订单总金额,单位为分 $spbill_create_ip = $this -> get_client_ip(); //获得用户设备IP $attach = 'weixinh5';//附加数据(自定义,在支付通知中原样返回) $notify_url = "www.dongpaiweb.cn/mobile/WechatPay/notify";//通知地址 $trade_type = 'MWEB';//交易类型,微信H5支付时固定为MWEB //2.将参数按照key=value的格式,并按照参数名ASCII字典序排序生成字符串 $signA ="appid=$appid&attach=$attach&body=$body&mch_id=$mch_id&nonce_str=$nonce_str¬ify_url=$notify_url&out_trade_no=$out_trade_no&spbill_create_ip=$spbill_create_ip&total_fee=$total_fee&trade_type=$trade_type"; //3.拼接字符串 $strSignTmp = $signA."&key=$key"; //4.MD5加密后转换成大写 $sign = strtoupper(MD5($strSignTmp)); //5.拼接成所需XML格式 $post_data = "<xml> <appid>$appid</appid> <attach>$attach</attach> <body>$body</body> <mch_id>$mch_id</mch_id> <nonce_str>$nonce_str</nonce_str> <notify_url>$notify_url</notify_url> <out_trade_no>$out_trade_no</out_trade_no> <spbill_create_ip>$spbill_create_ip</spbill_create_ip> <total_fee>$total_fee</total_fee> <trade_type>$trade_type</trade_type> <sign>$sign</sign> </xml>"; //6.以POST方式向微信传参,并取得微信返回的支付参数 $dataxml = $this -> www.dongpaiweb.cn/mobile/WechatPay/return";//支付后跳转地址 $urls = $objectxml['mweb_url'] . '&redirect_url=' . urlencode($return_url); //访问这个url 但是在用下面的方法访问是 报错商家信息有误 所以我把url 放到视图中 跳转 // header("Location:$urls"); return view('mobile_pay',[ 'url'=>$urls ]); //mweb_url是微信返回的支付连接要把这个连接分配到前台 if($objectxml['result_code'] == 'FAIL'){ return $err_code_des = $objectxml['err_code_des']; } } }
需要注意,微信返回参数return_code和result_code,return_code仅代表通信成功,不能代表交易成功。只有当return_code和result_code都为SUCCESS的时候才为交易成功。
最后还要区分notify地址和return地址,notify地址是微信给商户的支付通知,和Native支付相同,以数据流形式发送过来。return地址是用户支付后的跳转页面,是给用户看的。
以上就是ThinkPHP6对接实现微信H5支付的相关介绍,大家加油!
以上就是ThinkPHP6对接实现微信H5支付的详细内容,更多请关注自由互联其它相关文章!
本文共计1471个文字,预计阅读时间需要6分钟。
微信H5支付是移动端电商平台不可或缺的功能,今天我们带领大家实现ThinkPHP6对接微信H5支付。一、准备工作做微信支付同样需要企业资质,需要拥有一个已认证的微信服务号。
微信H5支付是移动端电商网页必不可少的功能,今天我们就带领大家来实现ThinkPHP6对接实现微信H5支付。一、准备工作
做微信支付同样需要企业资质,需要拥有一个已经认证的微信服务号,当然这个是需要缴纳300元给微信的。
具体申请的资质后,我们打开微信支付平台,在导航上点击“产品中心”-》点击‘H5支付’,在打开的页面中,填写并配置相关域名信息,填写好之后就可以等待微信官方审核通过了。如果申请不通过,微信会告知原因,直到H5支付通过开通成功。
二、对接微信H5支付
我们首先打开微信H5支付的官方文档,很遗憾,微信H5支付并没有像Native扫码支付那样给我们准备官方SDK&DEMO,没有官方SDK&DEMO,我们就需要自己集成了。
微信H5支付并不难,我们完全阅读统一下单章节。
1、准备参数。
微信官方已经给我们详细的列举了参数,这些参数获取并不难,我们需要注意两个参数:一个是签名sign,一个是终端IPspbill_create_ip。
签名sign官方已经给出了详细的说明,我们按key1=value1&key2=value2形式根据ASCII码从小到大排序。排序后得到StringA,然后再用得到的StringA和key拼接,最后都转成大写。
我们来看详细代码:
public function index(){ $url = "api.mch.weixin.qq.com/pay/unifiedorder";//微信传参地址 //1.获取调用统一下单接口所需必备参数 $appid = 'wxff5b6b241a4fb11';//微信公众号appid $mch_id = '152223331';//微信支付商户号 $key = 'b304911d6a9f7728d264dfd695ebae1';//自己设置的微信商家key $out_trade_no = time();//平台内部订单号 $nonce_str=MD5(time());//随机字符串 $body = '商品购买';//付款内容 $total_fee = 1;//订单总金额,单位为分 $spbill_create_ip = $this -> get_client_ip(); //获得用户设备IP $attach = 'weixinh5';//附加数据(自定义,在支付通知中原样返回) $notify_url = "www.xxx.cn/mobile/WechatPay/notify";//通知地址 $trade_type = 'MWEB';//交易类型,微信H5支付时固定为MWEB //2.将参数按照key=value的格式,并按照参数名ASCII字典序排序生成字符串 $signA ="appid=$appid&attach=$attach&body=$body&mch_id=$mch_id&nonce_str=$nonce_str¬ify_url=$notify_url&out_trade_no=$out_trade_no&spbill_create_ip=$spbill_create_ip&total_fee=$total_fee&trade_type=$trade_type"; //3.拼接字符串 $strSignTmp = $signA."&key=$key"; //4.MD5加密后转换成大写 $sign = strtoupper(MD5($strSignTmp)); //5.拼接成所需XML格式 $post_data = "<xml> <appid>$appid</appid> <attach>$attach</attach> <body>$body</body> <mch_id>$mch_id</mch_id> <nonce_str>$nonce_str</nonce_str> <notify_url>$notify_url</notify_url> <out_trade_no>$out_trade_no</out_trade_no> <spbill_create_ip>$spbill_create_ip</spbill_create_ip> <total_fee>$total_fee</total_fee> <trade_type>$trade_type</trade_type> <sign>$sign</sign> </xml>"; }
在这里用到一个$this -> get_client_ip()获取ip地址,我们看该方法的代码:
public function get_client_ip() { if(getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')) { $ip = getenv('HTTP_CLIENT_IP'); } elseif(getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')) { $ip = getenv('HTTP_X_FORWARDED_FOR'); } elseif(getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), 'unknown')) { $ip = getenv('REMOTE_ADDR'); } elseif(isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')) { $ip = $_SERVER['REMOTE_ADDR']; } return preg_match ( '/[\d\.]{7,15}/', $ip, $matches ) ? $matches [0] : ''; }
2、将参数post到官方地址。
官方的地址是URL地址:api.mch.weixin.qq.com/pay/unifiedorder,这个地址是不允许更改的。我们把准备好的xml参数post过去。
$dataxml = $this -> api.mch.weixin.qq.com/pay/unifiedorder";//微信传参地址 //1.获取调用统一下单接口所需必备参数 $appid = 'wxff5b68b241a4fb11';//微信公众号appid $mch_id = '1522223331';//微信支付商户号 $key = 'b304911d6a19f7728d264dfd695ebae1';//自己设置的微信商家key $out_trade_no = time();//平台内部订单号 $nonce_str=MD5(time());//随机字符串 $body = '商品购买';//付款内容 $total_fee = 1;//订单总金额,单位为分 $spbill_create_ip = $this -> get_client_ip(); //获得用户设备IP $attach = 'weixinh5';//附加数据(自定义,在支付通知中原样返回) $notify_url = "www.dongpaiweb.cn/mobile/WechatPay/notify";//通知地址 $trade_type = 'MWEB';//交易类型,微信H5支付时固定为MWEB //2.将参数按照key=value的格式,并按照参数名ASCII字典序排序生成字符串 $signA ="appid=$appid&attach=$attach&body=$body&mch_id=$mch_id&nonce_str=$nonce_str¬ify_url=$notify_url&out_trade_no=$out_trade_no&spbill_create_ip=$spbill_create_ip&total_fee=$total_fee&trade_type=$trade_type"; //3.拼接字符串 $strSignTmp = $signA."&key=$key"; //4.MD5加密后转换成大写 $sign = strtoupper(MD5($strSignTmp)); //5.拼接成所需XML格式 $post_data = "<xml> <appid>$appid</appid> <attach>$attach</attach> <body>$body</body> <mch_id>$mch_id</mch_id> <nonce_str>$nonce_str</nonce_str> <notify_url>$notify_url</notify_url> <out_trade_no>$out_trade_no</out_trade_no> <spbill_create_ip>$spbill_create_ip</spbill_create_ip> <total_fee>$total_fee</total_fee> <trade_type>$trade_type</trade_type> <sign>$sign</sign> </xml>"; //6.以POST方式向微信传参,并取得微信返回的支付参数 $dataxml = $this -> www.dongpaiweb.cn/mobile/WechatPay/return";//支付后跳转地址 $urls = $objectxml['mweb_url'] . '&redirect_url=' . urlencode($return_url); //访问这个url 但是在用下面的方法访问是 报错商家信息有误 所以我把url 放到视图中 跳转 // header("Location:$urls"); return view('mobile_pay',[ 'url'=>$urls ]); //mweb_url是微信返回的支付连接要把这个连接分配到前台 if($objectxml['result_code'] == 'FAIL'){ return $err_code_des = $objectxml['err_code_des']; } } }
需要注意,微信返回参数return_code和result_code,return_code仅代表通信成功,不能代表交易成功。只有当return_code和result_code都为SUCCESS的时候才为交易成功。
最后还要区分notify地址和return地址,notify地址是微信给商户的支付通知,和Native支付相同,以数据流形式发送过来。return地址是用户支付后的跳转页面,是给用户看的。
以上就是ThinkPHP6对接实现微信H5支付的相关介绍,大家加油!
以上就是ThinkPHP6对接实现微信H5支付的详细内容,更多请关注自由互联其它相关文章!

