导语:分销商,微商提现怎么提?直接用微信支付。
实现如下:
微信支付配置 /*微信支付*/ 'pay_weixin' => array( 'appid' => 'xxx', 'appsecret' => 'xxxxx', 'mchid' => '1283301801', //商户号 'key' => 'zhudianbaodiandodozhudianbao0527', //商户支付秘钥 'apiclient_cert' => 'conf/cert/apiclient_cert.pem', //商户证书apiclient_cert.pem 'apiclient_key' => 'conf/cert/apiclient_key.pem', //商户证书apiclient_key.pem )
arraytoxml
/** * array转xml */ function arraytoxml($arr) { $xml = ; foreach ($arr as $key=>$val) { if (is_numeric($val)) { $xml.=.$val.; } else $xml.=; } $xml.=; return $xml; }
使用证书,以post方式提交xml到对应的接口url
/** * 作用:使用证书,以post方式提交xml到对应的接口url */ function postxmlsslcurl($xml, $url, $second, $cert, $key) { $ch = curl_init(); //超时时间 curl_setopt($ch,curlopt_timeout,$second ? $second : $this->timeout); //这里设置代理,如果有的话 //curl_setopt($ch,curlopt_proxy, '8.8.8.8'); //curl_setopt($ch,curlopt_proxyport, 8080); curl_setopt($ch,curlopt_url, $url); curl_setopt($ch,curlopt_ssl_verifypeer,false); curl_setopt($ch,curlopt_ssl_verifyhost,false); //设置header curl_setopt($ch,curlopt_header,false); //要求结果为字符串且输出到屏幕上 curl_setopt($ch,curlopt_returntransfer,true); //设置证书 //使用证书:cert 与 key 分别属于两个.pem文件 //默认格式为pem,可以注释 curl_setopt($ch,curlopt_sslcerttype,'pem'); curl_setopt($ch,curlopt_sslcert,$cert); //默认格式为pem,可以注释 curl_setopt($ch,curlopt_sslkeytype,'pem'); curl_setopt($ch,curlopt_sslkey, $key); //post提交方式 curl_setopt($ch,curlopt_post, true); curl_setopt($ch,curlopt_postfields,$xml); $data = curl_exec($ch); //返回结果 if($data){ curl_close($ch); return $this->xmltoarray($data); } else { $error = curl_errno($ch); echo curl出错,错误码:$error.
; curl_close($ch); return false; } }
企业向个人付款 //企业向个人付款 public function paytouser($params, $key, $apicent_cert, $apiclient_key) { $url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers'; //检测必填参数 if($params[partner_trade_no] == null) { // exit(退款申请接口中,缺少必填参数partner_trade_no!.
); }elseif($params[openid] == null){ exit(退款申请接口中,缺少必填参数openid!.
); }elseif($params[check_name] == null){ //no_check:不校验真实姓名 force_check:强校验真实姓名(未实名认证的用户会校验失败,无法转账)option_check:针对已实名认证的用户才校验真实姓名(未实名认证用户不校验,可以转账成功) exit(退款申请接口中,缺少必填参数check_name!.
); }elseif(($params[check_name] == 'force_check' or $params[check_name] == 'option_check') && ($params[re_user_name] == null)){ //收款用户真实姓名。 exit(退款申请接口中,缺少必填参数re_user_name!.
); }elseif($params[amount] == null){ exit(退款申请接口中,缺少必填参数amount!.
); }elseif($params[desc] == null){ exit(退款申请接口中,缺少必填参数desc!.
); } $params[mch_appid] = $this->appid;//公众账号id $params[mchid] = $this->mchid;//商户号 $params[nonce_str] = $this->createnoncestr();//随机字符串 $params['spbill_create_ip'] = $_server['remote_addr'] == '::1' ? '192.127.1.1' : $_server['remote_addr'];//获取ip $params[sign] = $this->getsign($params, $key);//签名 $xml = $this->arraytoxml($params); return $this->postxmlsslcurl($xml, $url, false, $apicent_cert, $apiclient_key); }
企业付款 private function _enterprisepay($number, $member_id, $amount, $desc) { // 获取openid $wxuser_id = m('member')->where(array('id' => $member_id))->getfield('wxuser_id'); $openid = m('wxuser')->where(array('id' => $wxuser_id))->getfield('openid'); $pay = c('pay_weixin'); import('@.action.wxdevelop'); $enterprise = new wxenterprise($pay['appid'], $pay['appsecret'], $pay['mchid']); $params = array( 'partner_trade_no' => $number, 'openid' => $openid, 'check_name' => 'no_check', 'amount' => $amount, // 总计 'desc' => $desc, ); $result = $enterprise->paytouser($params, $pay['key'], $pay['apiclient_cert'], $pay['apiclient_key']); return $result; }
处理分销商提现 private function _handle($truename, $price) { // 处理分销商提现 $withdrawid = date(ymdhis) . strval(rand(1000, 9999)); $data = array('withdrawid' => $withdrawid, 'store_id' => $this->store_id, 'member_id' => $this->member_id, 'truename' => $truename, 'price' => $price, 'addtime' => time()); //免审核 if ($price >= c('withdraw_uncheck_value')) { $data['need_check'] = 0; $data['status'] = 1; if ($this->withdrawmodel->add($data)) { $result = $this->_enterprisepay($withdrawid, $this->member_id, $price * 100, '分销商(' . $truename . ')提现'); //遇到支付信息出错,转为需审核提现 if ($result['return_code'] != 'success') { $this->withdrawmodel->where(array('withdrawid' => $withdrawid))->save(array('need_check' => 1, 'status' => 0)); $this->assign('success', 2); } else { //设置微信交易号 $this->withdrawmodel->where(array('withdrawid' => $withdrawid))->save(array('payment_no' => $result['payment_no'])); //增加佣金流水,待修复 $data = array('store_id' => $this->store_id, 'user_type' => 2, 'user_id' => $this->shop_id, 'trade_type' => 2, 'trade_no' => $withdrawid, 'price' => -$price, 'status'=> 1, 'message' => $truename.'提现', 'addtime' => time()); m('twitter_log')->add($data); //减少相应可提佣金 m('member')->where(array('id' => $this->member_id))->setinc('money', -$price); $this->assign('success', 1); //发送佣金变动消息 import('@.action.tmplmsg'); $tmplmsg = new tmplmsg(); $tmplmsg->send(tmplmsg::price_change, $this->member_id, array('token' => $this->token, 'intro' => '分销佣金提现转出', 'price' => $price, 'business' => business)); } } else { $this->error('提现信息错误!'); } } //需要审核 else { $this->withdrawmodel->add($data); $this->assign('success' , 2); } }
提供企业向用户付款的功能,支持企业通过api接口付款,或通过微信支付商户平台网页功能操作付款。
温馨提示:◆ 给同一个实名用户付款,单笔单日限额2w/2w◆ 给同一个非实名用户付款,单笔单日限额2000/2000◆ 一个商户同一日付款总额限额100w◆ 仅支持商户号已绑定的appid;◆ 针对付款的目标用户,已微信支付实名认证的用户可提供校验真实姓名的功能,未实名认证的用户无法校验,企业可根据自身业务的安全级别选择验证类型;◆ 付款金额必须小于或等于商户当前可用余额的金额;◆ 已付款的记录,企业可通过企业付款查询查看相应数据。
到账 付款资金将进入目标用户的零钱(微信-我-钱包-零钱)。微信支付将做零钱入账消息通知,零钱收支明细会展示相应记录。
温馨提示:针对无零钱账户的历史客户端版本,资金将进入用户的红包账户,微信支付无消息通知用户,企业可选择自行触达用户。
接口链接:https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers
是否需要证书请求需要双向证书。
数据示例:
wxe062425f740c30d8100000983pg2j4iltkch16cq2502si8znmtm67vs100000982014120919616oho4gt7wvpxit1a9gjfamymizy1soption_check张三100节日快乐!10.2.3.10c97bdbacf37622775366f38b629f45e3
成功示例:
错误示例:
参考资料:https://pay.weixin.qq.com/wiki/doc/api/mch_pay.php?chapter=14_2