佣金发放php,微信企业付款PHP示例代码

在写微擎微信三级分销结算佣金时发现,如果会员提现都需要人工手动打款,财务的工作量和效率会大打折扣,因此想到了利用微信企业付款来解决,当管理员审核佣金时,确定发放佣金时,系统自动发放到申请人的微信钱包。

核心代码:

/*微信企业支付付款操作*/

$url = 'https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers';

$pars = array();

$pars['mch_appid'] = APPID;

$pars['mchid'] = 微信支付商户号;

$pars['nonce_str'] = random(32);

$pars['partner_trade_no'] = random(10) . date('Ymd') . random(3);

$pars['openid'] = 会员openid;

$pars['check_name'] = "NO_CHECK";

$pars['re_user_name'] = "用户姓名(可为空)";

$pars['amount'] = 打款金额(单位:分);

$pars['desc'] = '描述';

$pars['spbill_create_ip'] = '操作IP(即服务器IP)';

ksort($pars, SORT_STRING);

$string1 = '';

foreach ($pars as $k => $v) {

$string1.= "{$k}={$v}&";

}

$string1.= "key= 微信支付API密钥(md5加密的32位字符)";

$pars['sign'] = strtoupper(md5($string1));

//组成xml文件

$xml = '';

foreach ($pars as $k => $v) {

$xml.= "{$v}{$k}>";

}

$xml.= '';

//微信支付证书

$extras = array();

$extras['CURLOPT_CAINFO']  = dirname(dirname(dirname(__FILE__))) . '/cert/rootca_'.$weid.'.pem';

$extras['CURLOPT_SSLCERT'] = dirname(dirname(dirname(__FILE__))) . '/cert/apiclient_cert_'.$weid.'.pem';

$extras['CURLOPT_SSLKEY']  = dirname(dirname(dirname(__FILE__))) . '/cert/apiclient_key_'.$weid.'.pem';

$procResult = null;

$resp = $this->ihttp_request2($url, $xml, $extras);

if(is_error($resp)) {

$procResult = $resp;

} else {

$xml = '<?xml  version="1.0" encoding="utf-8"?>' . $resp['content'];

$dom = new DOMDocument();

if($dom->loadXML($xml)) {

$xpath = new DOMXPath($dom);

$code = $xpath->evaluate('string(//xml/return_code)');

$ret = $xpath->evaluate('string(//xml/result_code)');

if(strtolower($code) == 'success' && strtolower($ret) == 'success') {

$procResult = true;

} else {

$error = $xpath->evaluate('string(//xml/err_code_des)');

$procResult = error(-2, $error);

}

} else {

$procResult = error(-1, 'error response');

}

}

相关方法:

public function ihttp_request2($url, $post = '', $extra = array(), $timeout = 60) {

$urlset = parse_url($url);

if (empty($urlset['path'])) {

$urlset['path'] = '/';

}

if (!empty($urlset['query'])) {

$urlset['query'] = "?{$urlset['query']}";

}

if (empty($urlset['port'])) {

$urlset['port'] = $urlset['scheme'] == 'https' ? '443' : '80';

}

if (strexists($url, 'https://') && !extension_loaded('openssl')) {

if (!extension_loaded("openssl")) {

message('请开启您PHP环境的openssl');

}

}

if (function_exists('curl_init') && function_exists('curl_exec')) {

$ch = curl_init();

if (ver_compare(phpversion(), '5.6') >= 0) {

curl_setopt($ch, CURLOPT_SAFE_UPLOAD, false);

}

if (!empty($extra['ip'])) {

$extra['Host'] = $urlset['host'];

$urlset['host'] = $extra['ip'];

unset($extra['ip']);

}

curl_setopt($ch, CURLOPT_URL, $urlset['scheme'] . '://'

. $urlset['host'] . ($urlset['port'] == '80' ? '' : ':' . $urlset['port'])

. $urlset['path'] . $urlset['query']);

//换行,请把以上三行合成一行

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);

@curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);

curl_setopt($ch, CURLOPT_HEADER, 1);

curl_setopt($ch, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_0);

if ($post) {

if (is_array($post)) {

$filepost = false;

foreach ($post as $name => $value) {

if (substr($value, 0, 1) == '@' ||

(class_exists('CURLFile') && $value instanceof CURLFile)) {

//换行,请把以上两行合成一行

$filepost = true;

break;

}

}

if (!$filepost) {

$post = http_build_query($post);

}

}

curl_setopt($ch, CURLOPT_POST, 1);

curl_setopt($ch, CURLOPT_POSTFIELDS, $post);

}

if (!empty($GLOBALS['_W']['config']['setting']['proxy'])) {

$urls = parse_url($GLOBALS['_W']['config']['setting']['proxy']['host']);

curl_setopt($ch, CURLOPT_PROXY, "{$urls['host']}:{$urls['port']}");

$proxytype = 'CURLPROXY_' . strtoupper($urls['scheme']);

if (!empty($urls['scheme']) && defined($proxytype)) {

curl_setopt($ch, CURLOPT_PROXYTYPE, constant($proxytype));

} else {

curl_setopt($ch, CURLOPT_PROXYTYPE, CURLPROXY_HTTP);

curl_setopt($ch, CURLOPT_HTTPPROXYTUNNEL, 1);

}

if (!empty($GLOBALS['_W']['config']['setting']['proxy']['auth'])) {

curl_setopt($ch, CURLOPT_PROXYUSERPWD, $GLOBALS['_W']['config']['setting']['proxy']['auth']);

}

}

curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout);

curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);

curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);

curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);

curl_setopt($ch, CURLOPT_SSLVERSION, 1);

if (defined('CURL_SSLVERSION_TLSv1')) {

curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1);

}

curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.1;

WOW64; rv:9.0.1) Gecko/20100101 Firefox/9.0.1');

//换行,请把以上两行合成一行

if (!empty($extra) && is_array($extra)) {

$headers = array();

foreach ($extra as $opt => $value) {

if (strexists($opt, 'CURLOPT_')) {

curl_setopt($ch, constant($opt), $value);

} elseif (is_numeric($opt)) {

curl_setopt($ch, $opt, $value);

} else {

$headers[] = "{$opt}: {$value}";

}

}

if (!empty($headers)) {

curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);

}

}

$data = curl_exec($ch);

$status = curl_getinfo($ch);

$errno = curl_errno($ch);

$error = curl_error($ch);

curl_close($ch);

if ($errno || empty($data)) {

return error(1, $error);

} else {

return ihttp_response_parse($data);

}

}

$method = empty($post) ? 'GET' : 'POST';

$fdata = "{$method} {$urlset['path']}{$urlset['query']} HTTP/1.1\r\n";

$fdata .= "Host: {$urlset['host']}\r\n";

if (function_exists('gzdecode')) {

$fdata .= "Accept-Encoding: gzip, deflate\r\n";

}

$fdata .= "Connection: close\r\n";

if (!empty($extra) && is_array($extra)) {

foreach ($extra as $opt => $value) {

if (!strexists($opt, 'CURLOPT_')) {

$fdata .= "{$opt}: {$value}\r\n";

}

}

}

$body = '';

if ($post) {

if (is_array($post)) {

$body = http_build_query($post);

} else {

$body = urlencode($post);

}

$fdata .= 'Content-Length: ' . strlen($body) . "\r\n\r\n{$body}";

} else {

$fdata .= "\r\n";

}

if ($urlset['scheme'] == 'https') {

$fp = fsockopen('ssl://' . $urlset['host'], $urlset['port'], $errno, $error);

} else {

$fp = fsockopen($urlset['host'], $urlset['port'], $errno, $error);

}

stream_set_blocking($fp, true);

stream_set_timeout($fp, $timeout);

if (!$fp) {

return error(1, $error);

} else {

fwrite($fp, $fdata);

$content = '';

while (!feof($fp))

$content .= fgets($fp, 512);

fclose($fp);

return ihttp_response_parse($content, true);

}

}

public function ihttp_response_parse($data, $chunked = false) {

$rlt = array();

$headermeta = explode('HTTP/', $data);

if (count($headermeta) > 2) {

$data = 'HTTP/' . array_pop($headermeta);

}

$pos = strpos($data, "\r\n\r\n");

$split1[0] = substr($data, 0, $pos);

$split1[1] = substr($data, $pos + 4, strlen($data));

$split2 = explode("\r\n", $split1[0], 2);

preg_match('/^(\S+) (\S+) (\S+)$/', $split2[0], $matches);

$rlt['code'] = $matches[2];

$rlt['status'] = $matches[3];

$rlt['responseline'] = $split2[0];

$header = explode("\r\n", $split2[1]);

$isgzip = false;

$ischunk = false;

foreach ($header as $v) {

$pos = strpos($v, ':');

$key = substr($v, 0, $pos);

$value = trim(substr($v, $pos + 1));

if (is_array($rlt['headers'][$key])) {

$rlt['headers'][$key][] = $value;

} elseif (!empty($rlt['headers'][$key])) {

$temp = $rlt['headers'][$key];

unset($rlt['headers'][$key]);

$rlt['headers'][$key][] = $temp;

$rlt['headers'][$key][] = $value;

} else {

$rlt['headers'][$key] = $value;

}

if(!$isgzip && strtolower($key) == 'content-encoding' && strtolower($value) == 'gzip') {

$isgzip = true;

}

if(!$ischunk && strtolower($key) == 'transfer-encoding' && strtolower($value) == 'chunked') {

$ischunk = true;

}

}

if($chunked && $ischunk) {

$rlt['content'] = ihttp_response_parse_unchunk($split1[1]);

} else {

$rlt['content'] = $split1[1];

}

if($isgzip && function_exists('gzdecode')) {

$rlt['content'] = gzdecode($rlt['content']);

}

$rlt['meta'] = $data;

if($rlt['code'] == '100') {

return ihttp_response_parse($rlt['content']);

}

return $rlt;

}

public function ihttp_response_parse_unchunk($str = null) {

if(!is_string($str) or strlen($str) 

return false;

}

$eol = "\r\n";

$add = strlen($eol);

$tmp = $str;

$str = '';

do {

$tmp = ltrim($tmp);

$pos = strpos($tmp, $eol);

if($pos === false) {

return false;

}

$len = hexdec(substr($tmp, 0, $pos));

if(!is_numeric($len) or $len 

return false;

}

$str .= substr($tmp, ($pos + $add), $len);

$tmp  = substr($tmp, ($len + $pos + $add));

$check = trim($tmp);

} while(!empty($check));

unset($tmp);

return $str;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值