代码一个字没动复制到公共方法里在调用就不报错了。
商户转账到零钱,设置请求头还报错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); } 我看部分帖子说 postBody 的参数位置很重要,三个参数位置我来回换也不行,这个接口时不能直接请求吗?需要前端做什么处理?还是后端能直接请求?还是小程序有什么配置没有设置导致的签名错误????
有奖调研 l 微信开发者平台已上线,有啥需求来和我们说说?[图片] 随着微信生态的发展,大部分微信开发者需要同时管理众多的微信生态的业务和服务,记录各种账号信息、控制台管理地址以及理清业务之间的绑定关系。 为了清晰地为开发者展示微信生态的所有产品和服务,同时还为各种开发提供一站式管理与指南,微信团队现已推出👉微信开发者平台👈 [图片][图片][图片][图片] 当前已支持接入管理小程序、小游戏、多端应用、微信网关,更多的微信生态业务的开发管理在推进中。 为了更好更多的满足开发者需求,我们发起了关于微信开发者平台的有奖调研话题,非常欢迎开发者分享自己的想法,比如: 希望哪个业务可尽快支持在微信开发者平台中进行管理? 对站内信和平台通知的统一接收和管理功能有什么建议? 希望开放什么场景下的自助定位开发问题工具? 等等................ 欢迎各位开发者朋友们可以畅所欲言,反馈最真实需求,官方团队将认真评估,及时支持,以使得开发者们可以有更好的开发体验和更好的开发效率。 即日起至2024年12月22日,在下方评论区分享自己对「微信开发者平台」的使用体验与建议,精选评论的开发者将获得官方精美礼品一份。[图片]
2024-12-14