【微信支付】小程序之企业支付

之前,做过的是公众号发红包的操作,今天我要介绍的是微信支付的企业支付,小程序之内的企业支付。
如果对企业支付不了解的,可以点此链接去看下微信官方的企业支付介绍。

企业支付发送的主体,也是根据微信公众号一样获取的到的openID来发送,不同于红包的操作,这个操作就类似于转账了,不需要接收方在去点击领取。
【微信支付】小程序之企业支付_第1张图片


代码实现

    function unicode() {
        $str = uniqid(mt_rand(),1);
        $str=sha1($str);
        return md5($str);
    }

    function arraytoxml($data){
        $str='';
        foreach($data as $k=>$v) {
            $str.='<'.$k.'>'.$v.'.$k.'>';
        }
        $str.='';
        return $str;
    } 

    function xmltoarray($xml) {
        //禁止引用外部xml实体
        libxml_disable_entity_loader(true);
        $xmlstring = simplexml_load_string($xml, 'SimpleXMLElement', LIBXML_NOCDATA);
        $val = json_decode(json_encode($xmlstring),true);
        return $val;
    }  

    function curl($param="",$url) {
        $postUrl = $url;
        $curlPost = $param;
        $ch = curl_init();                   //初始化curl
        curl_setopt($ch, CURLOPT_URL,$postUrl);         //抓取指定网页
        curl_setopt($ch, CURLOPT_HEADER, 0);          //设置header
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);      //要求结果为字符串且输出到屏幕上
        curl_setopt($ch, CURLOPT_POST, 1);           //post提交方式
        curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost);      // 增加 HTTP Header(头)里的字段
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);    // 终止从服务端进行验证
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
        curl_setopt($ch,CURLOPT_SSLCERT,getcwd().'/cert/apiclient_cert.pem'); //这个是证书的位置
        curl_setopt($ch,CURLOPT_SSLKEY,getcwd().'/cert/apiclient_key.pem'); //这个也是证书的位置
        $data = curl_exec($ch);                 //运行curl
        curl_close($ch);
        return $data;
    }  

    public function sendPacket_f(){
        //http://localhost/duocai_bakc_new/api.php?c=wx_api_pay&f=sendPacket
        $time = time();
        $partner_trade_no = 'FA'.time().mt_rand(100,10000);
        $data['mch_appid'] = 'wx499********';//商户的应用appid
        $data['mchid'] = '123******2';//商户ID
        $data['nonce_str'] = $this->unicode();//unicode();//这个据说是唯一的字符串下面有方法
        $data['partner_trade_no'] = $partner_trade_no;//.time();//这个是订单号。
        $data['openid'] = 'osmxp1QUneYkB7OOiNiHtA*****';//这个是授权用户的openid。。这个必须得是用户授权才能用
        $data['check_name'] = 'NO_CHECK';//这个是设置是否检测用户真实姓名的
        //$data['re_user_name']='';//用户的真实名字
        $data['amount'] = 1*100;//提现金额
        $data['desc'] = '有奖采集任务奖励';//订单描述
        $data['spbill_create_ip'] = $_SERVER['SERVER_ADDR'];//这个最烦了,,还得获取服务器的ip
        $secrect_key = '630c84211dd832b6a01*********';///这个就是个API密码。32位的。。随便MD5一下就可以了
        $data = array_filter($data);
        ksort($data);
        $str = '';
        foreach ($data as $k => $v) {
            $str .= $k . '=' . $v . '&';
        }
        $str .= 'key=' . $secrect_key;
        $data['sign'] = md5($str);
        //print_r($data);
        $xml = $this->arraytoxml($data);
        $url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers';
        $res = $this->curl($xml, $url);
        $return = $this->xmltoarray($res)
        echo '
';
        var_dump($return);die;
    }

返回值

array(9) {
  ["return_code"]=>
  string(7) "SUCCESS"
  ["return_msg"]=>
  array(0) {
  }
  ["mch_appid"]=>
  string(18) "wx4990e7*******c"
  ["mchid"]=>
  string(10) "12*******"
  ["nonce_str"]=>
  string(32) "f0d6b760961*********4e5e"
  ["result_code"]=>
  string(7) "SUCCESS"
  ["partner_trade_no"]=>
  string(16) "FA15239330796943"
  ["payment_no"]=>
  string(28) "1000018301201804177004322523"
  ["payment_time"]=>
  string(19) "2018-04-17 10:44:40"
}

配置参数的获取

  • 商户id

【微信支付】小程序之企业支付_第2张图片

  • app_id 和 secrect_key
    【微信支付】小程序之企业支付_第3张图片

tip:微信红包最大额是200,企业支付最大额是200W

你可能感兴趣的:(【微信支付】小程序之企业支付)