//微信商户关联appid
protected $app_id ='';
//微信商户号
protected $mchid ='';
//微信api证书路径(三选一)
protected $cert_pem =getcwd().'/uploads/other/cert/2022062617324832e483199.pem';
protected $key_pem =getcwd().'/uploads/other/cert/202206261733042d98b3586.pem';
//微信api证书路径(三选一)
protected $cert_pem =ROOT_PATH.'/uploads/other/cert/2022062617324832e483199.pem';
protected $key_pem =ROOT_PATH.'/uploads/other/cert/202206261733042d98b3586.pem';
//微信api证书路径(三选一)
$request = \think\Request::instance();
protected $cert_pem =$request->root(true).'/uploads/other/cert/2022062617324832e483199.pem';
protected $key_pem =$request->root(true).'/uploads/other/cert/202206261733042d98b3586.pem';
/**
* 调用方法
*/
public function fx(){
$fx_price = 1;
$user_id = 102;
self::send_money($fx_price,$user_id,'活动推荐购买返佣金');
}
/**
* 商家转账到零钱
* @param $fx_price //转账金额
* @param $user_id //用户id
* @param $batch_name //转账描述
*/
public function send_money($fx_price,$user_id,$batch_name){
$openid = Db::name("user")->where(['id'=>$user_id])->value('openid');
$out_trade_no = time();
self::transfer($batch_name,$out_trade_no,$fx_price,$openid);
}
/**
* 商家转账到零钱
* @param $batch_name
* @param $out_trade_no
* @param $money
* @param $openid
* @throws BaseException
*/
public function transfer($batch_name, $out_trade_no, $money, $openid){
$url = 'https://api.mch.weixin.qq.com/v3/transfer/batches';
$pars = [];
//直连商户的appid
$pars['appid'] = $this->app_id;
//商户系统内部的商家批次单号,要求此参数只能由数字、大小写字母组成,在商户系统内部唯一
$pars['out_batch_no'] = 'order' . $out_trade_no;
//该笔批量转账的名称
$pars['batch_name'] = $batch_name;
//转账说明,UTF8编码,最多允许32个字符
$pars['batch_remark'] = $batch_name;
//转账总金额 单位为“分”
$pars['total_amount'] = intval($money * 100);
//转账总笔数
$pars['total_num'] = 1;
//转账明细列表
$pars['transfer_detail_list'][0] = [
'out_detail_no' => 'user' . $out_trade_no,
'transfer_amount' => $pars['total_amount'],
'transfer_remark' => $batch_name,
'openid' => $openid
];
//获取请求头token
$token = $this->getToken($pars);
//发送请求
$res = $this->https_request($url, json_encode($pars), $token);
//返回数据转换成数组
$data = json_decode($res, true);
//可以用这个来打印请求接口得报错信息
//var_dump($data);die;
if (isset($data['batch_id']) && $data['batch_id']) {
return $data;
}
return [];
}
public function https_request($url, $data = null, $token){
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, (string)$url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
if (!empty($data)) {
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
}
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$headers = [
'Authorization:WECHATPAY2-SHA256-RSA2048 ' . $token,
'Accept: application/json',
'Content-Type: application/json; charset=utf-8',
'User-Agent:Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36',
];
if (!empty($headers)) {
curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
}
$output = curl_exec($curl);
curl_close($curl);
return $output;
}
public function getToken($pars){
$url = 'https://api.mch.weixin.qq.com/v3/transfer/batches';
//请求方法(GET,POST,PUT)
$http_method = 'POST';
//请求时间戳
$timestamp = time();
//获取请求的绝对URL
$url_parts = parse_url($url);
//请求随机串
$nonce = $timestamp . rand('10000', '99999');
//请求报文主体
$body = json_encode((object)$pars);
$stream_opts = [
"ssl" => [
"verify_peer" => false,
"verify_peer_name" => false,
]
];
try {
$certPem = $this->getCertPem();
$apiclient_cert_path = $this->cert_pem;
$apiclient_key_path = $this->key_pem;
$apiclient_cert_arr = openssl_x509_parse(file_get_contents($apiclient_cert_path, false, stream_context_create($stream_opts)));
//证书序列号
$serial_no = $apiclient_cert_arr['serialNumberHex'];
//密钥
$mch_private_key = file_get_contents($apiclient_key_path, false, stream_context_create($stream_opts));
$merchant_id = $this->mchid;
$canonical_url = ($url_parts['path'] . (!empty($url_parts['query']) ? "?${url_parts['query']}" : ""));
$message = $http_method . "\n" .
$canonical_url . "\n" .
$timestamp . "\n" .
$nonce . "\n" .
$body . "\n";
openssl_sign($message, $raw_sign, $mch_private_key, 'sha256WithRSAEncryption');
//签名
$sign = base64_encode($raw_sign);
//请求头token返回
$token = sprintf('mchid="%s",nonce_str="%s",timestamp="%d",serial_no="%s",signature="%s"',$merchant_id, $nonce, $timestamp, $serial_no, $sign);
} catch (\Exception $e) {
throw new BaseException(['msg' => $e->getMessage()]);
}
return $token;
}
微信商家转账到零钱
于 2022-12-01 22:17:26 首次发布