- 商户转账到零钱,设置请求头还报错Http头缺少Accept或User-Agent?
public function transfer($batch_name, $out_trade_no, $money, $openid) { $url = 'https://api.mch.weixin.qq.com/v3/transfer/batches'; $pars = []; $pars['appid'] = '*****';//直连商户的appid $pars['out_batch_no'] = $out_trade_no;//商户系统内部的商家批次单号,要求此参数只能由数字、大小写字母组成,在商户系统内部唯一 $pars['batch_name'] = $batch_name;//该笔批量转账的名称 $pars['batch_remark'] = $batch_name;//转账说明,UTF8编码,最多允许32个字符 $pars['total_amount'] = intval($money * 100);//转账总金额 单位为“分” $pars['total_num'] = 1;//转账总笔数 $pars['transfer_detail_list'][0] = [ 'out_detail_no' => 'transfer' . $out_trade_no, 'transfer_amount' => $pars['total_amount'], 'transfer_remark' => $batch_name, 'openid' => $openid ];//转账明细列表 $token = $this->getToken($pars);//获取token $res = $this->https_request($url, json_encode($pars), $token);//发送请求 $data = json_decode($res, true); return $data; } 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/certificates'; $url = 'https://api.mch.weixin.qq.com/v3/transfer/batches'; $http_method = 'POST';//请求方法(GET,POST,PUT) $timestamp = time();//请求时间戳 $url_parts = parse_url($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 = $certPem['certPem']; $apiclient_key_path = $certPem['keyPem']; $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 = '******'; $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);//签名 $schema = 'WECHATPAY2-SHA256-RSA2048'; $token = sprintf('mchid="%s",nonce_str="%s",timestamp="%d",serial_no="%s",signature="%s"', $merchant_id, $nonce, $timestamp, $serial_no, $sign);//微信返回token } catch (\Exception $e) { // throw new BaseException(['msg' => $e->getMessage()]); return json(['code'=>1,'msg'=>$e->getMessage()]); } return $token; } /** * 获取cert证书文件 * @return array * @throws BaseException */ private function getCertPem() { // cert目录 $filePath = dirname(__DIR__) . '/public/cert/wechat/'; return [ 'certPem' => $filePath . 'apiclient_cert.pem', 'keyPem' => $filePath . 'apiclient_key.pem' ]; } //在别的方法里调用,报错{code: "INVALID_REQUEST", message: "Http头缺少Accept或User-Agent"} $res = $this->transfer('结算手工费', $out_trade_no, $craft_fee, $openid); return json($res);
01-22 - 小程序虚拟支付,请求query_user_balance,报错支付签名(pay_sig)校验失败?
按照文档实例 [图片] 签名结果为: [图片] 文档签名实例 [图片] c37809f27c6d7fd1837ad2500a04512b66b34fd793a39a385fade56dca89a4b5 c37809f27c6d7fd1837ad2500a04512b66b34fd793a39a385fade56dca89a4b5 签名结果是一致的,签名没有错,但是请求接口一直报签名错误。 [图片] 是哪里有问题吗?下面是虚拟支付查询余额接口 public function getBalanceV2() { $accessToken = $this->getAccessToken(); $openid = $this->auth->wxxopenid; $user_ip = request()->ip(); $uri = '/xpay/query_user_balance'; $evn = 1; $postBody = json_encode(["openid"=>$openid,"env"=>$evn,"user_ip"=>$user_ip]); $appKey = "*************"; $paySig = $this->calcPaySig($uri,$postBody,$appKey);; // 0 米大师正式环境 1 米大师沙箱环境 $url = "https://api.weixin.qq.com/xpay/query_user_balance?access_token={$accessToken}&pay_sig={$paySig}"; // return $url; $result = json_decode(Http::post($url),true); return json($result); } 2024-12-14
2024-12-14 - 小程序虚拟支付,请求query_user_balance,报错支付签名(pay_sig)校验失败?
按照文档实例 [图片] 签名结果为: [图片] 文档签名实例 [图片] c37809f27c6d7fd1837ad2500a04512b66b34fd793a39a385fade56dca89a4b5 c37809f27c6d7fd1837ad2500a04512b66b34fd793a39a385fade56dca89a4b5 签名结果是一致的,签名没有错,但是请求接口一直报签名错误。 [图片] 是哪里有问题吗?下面是虚拟支付查询余额接口 public function getBalanceV2() { $accessToken = $this->getAccessToken(); $openid = $this->auth->wxxopenid; $user_ip = request()->ip(); $uri = '/xpay/query_user_balance'; $evn = 1; $postBody = json_encode(["openid"=>$openid,"env"=>$evn,"user_ip"=>$user_ip]); $appKey = "*************"; $paySig = $this->calcPaySig($uri,$postBody,$appKey);; // 0 米大师正式环境 1 米大师沙箱环境 $url = "https://api.weixin.qq.com/xpay/query_user_balance?access_token={$accessToken}&pay_sig={$paySig}"; // return $url; $result = json_decode(Http::post($url),true); return json($result); }
2024-12-12 - 微信App 支付支付成功,异步回调地址收不到通知,是怎么回事?
客户端支付订单号: 20221201070749001023102129 这是回调地址:http://app.hanxinliao.com/addons/epay/api/notifyx/type/wechat 请帮忙看一下,是什么原因? 回调地址我对几遍了地址没有问题,外网可以直接访问回调地址 是回调发过来我代码写错了吗
2022-12-01