Demo.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <?php
  2. namespace app\admin\controller;
  3. use think\Response;
  4. use think\Config;
  5. /**
  6. * 示例接口
  7. */
  8. class Demo
  9. {
  10. //如果$noNeedLogin为空表示所有接口都需要登录才能请求
  11. //如果$noNeedRight为空表示所有接口都需要验证权限才能请求
  12. //如果接口已经设置无需登录,那也就无需鉴权了
  13. //
  14. // 无需登录的接口,*表示全部
  15. protected $noNeedLogin = ['*'];
  16. // 无需鉴权的接口,*表示全部
  17. protected $noNeedRight = ['*'];
  18. /**
  19. * 测试方法
  20. *
  21. */
  22. public function test()
  23. {
  24. $batch_name = '余额提现';//转账的名称
  25. $out_trade_no = time().rand(1000,9999);//单号
  26. $money = 1;//金额
  27. $openid = 'o4a9g5cDIEVzS7zVzE-_VEK8y9Yg';//用户openid
  28. $this->tixian($batch_name,$out_trade_no,$money,$openid);
  29. }
  30. public function tixian($batch_name,$out_trade_no,$money,$openid){
  31. $url = 'https://api.mch.weixin.qq.com/v3/transfer/batches';
  32. $pars = [];
  33. $pars['appid'] = config('wxconfig.appId');//直连商户的appid
  34. $pars['out_batch_no'] = 'sjzz'.date('Ymd').mt_rand(1000, 9999);//商户系统内部的商家批次单号,要求此参数只能由数字、大小写字母组成,在商户系统内部唯一
  35. $pars['batch_name'] = $batch_name;//该笔批量转账的名称
  36. $pars['batch_remark'] = $batch_name;//转账说明,UTF8编码,最多允许32个字符
  37. $pars['total_amount'] = intval($money * 100);//转账总金额 单位为“分”
  38. $pars['total_num'] = 1;//转账总笔数
  39. $pars['transfer_detail_list'][0] = [
  40. 'out_detail_no'=>'Dh'.$out_trade_no,
  41. 'transfer_amount'=>$pars['total_amount'],
  42. 'transfer_remark'=>$batch_name,
  43. 'openid'=>$openid
  44. ];//转账明细列表
  45. $token = $this->getToken($pars);//获取token
  46. $res = $this->https_request($url,json_encode($pars),$token);//发送请求
  47. $resArr = json_decode($res,true);
  48. halt($resArr);
  49. //成功返回
  50. // array(3) {
  51. // ["batch_id"] => string(40) "1030001016101247194272022062900873000000"
  52. // ["create_time"] => string(25) "2022-06-29T10:21:30+08:00"
  53. // ["out_batch_no"] => string(16) "sjzz202206291647001"
  54. // }
  55. }
  56. function https_request($url,$data = null,$token){
  57. $curl = curl_init();
  58. curl_setopt($curl, CURLOPT_URL, (string)$url);
  59. curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
  60. curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
  61. if (!empty($data)){
  62. curl_setopt($curl, CURLOPT_POST, 1);
  63. curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
  64. }
  65. curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
  66. //添加请求头
  67. $headers = [
  68. 'Authorization:WECHATPAY2-SHA256-RSA2048 '.$token,
  69. 'Accept: application/json',
  70. 'Content-Type: application/json; charset=utf-8',
  71. 'User-Agent:Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36',
  72. ];
  73. if(!empty($headers)){
  74. curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
  75. }
  76. $output = curl_exec($curl);
  77. curl_close($curl);
  78. return $output;
  79. }
  80. public function getToken($pars)
  81. {
  82. // $url = 'https://api.mch.weixin.qq.com/v3/certificates';
  83. $url = 'https://api.mch.weixin.qq.com/v3/transfer/batches';
  84. $http_method = 'POST';//请求方法(GET,POST,PUT)
  85. $timestamp = time();//请求时间戳
  86. $url_parts = parse_url($url);//获取请求的绝对URL
  87. $nonce = $timestamp.rand('10000','99999');//请求随机串
  88. $body = json_encode((object)$pars);//请求报文主体
  89. $stream_opts = [
  90. "ssl" => [
  91. "verify_peer"=>false,
  92. "verify_peer_name"=>false,
  93. ]
  94. ];
  95. $apiclient_cert_path = 'https://'.$_SERVER['HTTP_HOST'].'/uploads/apiclient/apiclient_cert.pem';
  96. $apiclient_key_path = 'https://'.$_SERVER['HTTP_HOST'].'/uploads/apiclient/apiclient_key.pem';
  97. $apiclient_cert_arr = openssl_x509_parse(file_get_contents($apiclient_cert_path,false, stream_context_create($stream_opts)));
  98. $serial_no = $apiclient_cert_arr['serialNumberHex'];//证书序列号
  99. $mch_private_key = file_get_contents($apiclient_key_path,false, stream_context_create($stream_opts));//密钥
  100. $merchant_id = config('wxconfig.payMchId');//商户id
  101. $canonical_url = ($url_parts['path'] . (!empty($url_parts['query']) ? "?${url_parts['query']}" : ""));
  102. $message = $http_method."\n".
  103. $canonical_url."\n".
  104. $timestamp."\n".
  105. $nonce."\n".
  106. $body."\n";
  107. openssl_sign($message, $raw_sign, $mch_private_key, 'sha256WithRSAEncryption');
  108. $sign = base64_encode($raw_sign);//签名
  109. $schema = 'WECHATPAY2-SHA256-RSA2048';
  110. $token = sprintf('mchid="%s",nonce_str="%s",timestamp="%d",serial_no="%s",signature="%s"',
  111. $merchant_id, $nonce, $timestamp, $serial_no, $sign);//微信返回token
  112. return $token;
  113. }
  114. }