微信小程序企業付款到個人


<?php

/**
 * 小程序之企業付款到個人!
 */
class WxPayModel extends Model
{



    public function sendMoneyToPerson($trade_no,$openid,$amount){
        header('Content-type:text/html;charset=utf8');

        setlog([$trade_no,$openid,$amount],[],'','p_000.log');

        $partner_trade_no = $trade_no;

        if (100000 < $amount){
            $return_data = [
                'num'       =>      '14488',
                'desc'      =>      '參數錯誤'
            ];

            return $return_data;
        }



        $data['mch_appid'] = C('APPID');                  //商戶的應用appid
        $data['mchid'] = C('MCHID');                      //商戶ID
        $data['nonce_str'] = $this->unicode();            //unicode();//這個據說是唯一的字符串下面有方法
        $data['partner_trade_no'] = $partner_trade_no;      //這個是訂單號。
        $data['openid'] = $openid;                          //這個是授權用戶的openid。。這個必須得是用戶授權才能用---?????
        $data['check_name'] = 'NO_CHECK';                           //這個是設置是否檢測用戶真實姓名的
        //$data['re_user_name'] = '';//用戶的真實名字

        $data['amount'] = $amount;                                  //提現金額(單位:分)
        $data['desc'] = 'xxxxx感謝您的支持';                        //訂單描述
        $data['spbill_create_ip'] = $_SERVER['SERVER_ADDR'];        //這個最煩了,,還得獲取服務器的ip
        $secrect_key = C('PAY_KEY');          //這個就是個API密碼。32位的。。隨便MD5一下就可以了

        $data = array_filter($data);
        ksort($data);

        $str = '';
        foreach ($data as $k => $v) {
            $str .= $k . '=' . $v . '&';
        }

        $str .= 'key=' . $secrect_key;

        setlog([],[$str],'','p_1999.log');

        $data['sign'] = strtoupper(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);

        if ($return['result_code'] == 'FAIL'){
            setlog($data,$return,'','p_1.log');

            $return_data = [
                'num'       =>      '10025',
                'desc'      =>      $return['err_code_des']
            ];

            return $return_data;
        }

        setlog($return,$_POST,'','p_2.log');

        $return_data = [
            'num'       =>     '0',
            'desc'      =>     '到賬成功',
            'data'      =>      $return
        ];

        return $return_data;
    }



    /***
     * array(9) {
            ["return_code"] => string(7) "SUCCESS"
            ["return_msg"] => array(0) {}
            ["mch_appid"] => string(18) "xxxxxxxx"
            ["mchid"] => string(10) "xxxxxxxxx"
            ["nonce_str"] => string(32) "fbb9d90268134e280cc6fe2b9781b143"
            ["result_code"] => string(7) "SUCCESS"
            ["partner_trade_no"] => string(12) "zhubin123456"
            ["payment_no"] => string(28) "1494771532201905183784872155"
            ["payment_time"] => string(19) "2019-05-18 17:21:59"
        }
     *
     * array(9) {
     *  [return_code] => SUCCESS
        [return_msg] => 支付失敗
        [mch_appid] => wx6457c25c4c537cf4
        [mchid] => 1494771532
        [result_code] => FAIL
        [err_code] => RECV_ACCOUNT_NOT_ALLOWED
        [err_code_des] => 收款賬戶不在收款賬戶列表,請查看產品中心企業付款配置
     * }

     */






    private function decode_name($key,$name){
        $nameLen = strlen( $name );
        $keyLen = strlen( $key );
        if ( $keyLen < $nameLen ){
            $key = str_repeat( $key, ceil( $nameLen / $keyLen ));
        }

        $CMSName = base64_decode( $name ) ^ $key;
        return $CMSName;
    }



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



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

        $str .= '</xml>';
        return $str;
    }



    private 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;
    }


    private 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;
    }







}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM