OriginBank.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <?php
  2. namespace App\Libs\Pay\Merchants;
  3. use GuzzleHttp\Client;
  4. use Log;
  5. class OriginBank
  6. {
  7. function __construct($config)
  8. {
  9. $this->open_id = $config['open_id'];
  10. $this->open_key = $config['open_key'];
  11. $this->sub_appid = $config['sub_appid'];
  12. $this->PayClient = new client(['base_uri'=>'https://api.orangebank.com.cn/','timeout'=>3]);
  13. }
  14. //生成订单
  15. function send($data)
  16. {
  17. $time = time();
  18. $base_data = [
  19. 'open_id'=>$this->open_id,
  20. 'timestamp'=>$time,
  21. ];
  22. $data = [
  23. 'out_no'=>$data['trade_no'],
  24. 'pmt_tag'=>'WeixinOL',
  25. 'ord_name'=>'小说充值',
  26. 'original_amount'=>$data['price'],
  27. 'trade_amount'=>$data['price'],
  28. //'notify_url'=>env('ORIGINBANK_NOFITY_URL'),
  29. 'sub_appid'=>$this->sub_appid,
  30. 'sub_openid'=>$data['openid'],
  31. 'JSAPI'=>1
  32. ];
  33. dump($data);
  34. $base_data['data'] = $this->encrypt(json_encode($data),$this->open_key);
  35. dump($data);
  36. dump($this->decrypt($base_data['data'],$this->open_key));
  37. $base_data['sign'] = $this->signs($base_data);
  38. dump('base_data');dump($base_data);
  39. $response = $this->PayClient->request('POST','/mct1/payorder',['form_params'=>$base_data])->getBody()->getContents();
  40. dump($this->decrypt(json_decode($response,1)['data'],$this->open_key));
  41. dd($this->getPayInfo($response));
  42. return $this->getPayInfo($response);
  43. }
  44. function getPayInfo($response)
  45. {
  46. try{
  47. $return_info = json_decode($response,1);
  48. dump($return_info);
  49. if($return_info['errcode'] == 0)
  50. {
  51. $data = json_decode($this->decrypt($return_info['data'],$this->open_key,true),true);
  52. dump($data);
  53. $trade_result = json_decode($data['trade_result'],true);
  54. $wc_pay_data = json_decode($trade_result['wc_pay_data'],true);
  55. dump($trade_result);
  56. $pay_info = [
  57. 'appId'=>$wc_pay_data['appId'],
  58. 'timeStamp'=>$wc_pay_data['timeStamp'],
  59. 'nonceStr'=>$wc_pay_data['nonce_str'],
  60. 'signType'=>$wc_pay_data['signType'],
  61. 'package'=>'prepay_id=' . $wc_pay_data['prepay_id'],
  62. 'paySign'=>$wc_pay_data['paySign']
  63. ];
  64. return $pay_info;
  65. }
  66. }catch (\Exception $e)
  67. {
  68. echo $e->getMessage();
  69. return null;
  70. }
  71. }
  72. //签名
  73. public function signs($array){
  74. $signature = array();
  75. foreach($array as $key=>$value){
  76. $signature[$key]=$key.'='.$value;
  77. }
  78. $signature['open_key']='open_key'.'='.$this->open_key;
  79. ksort($signature);
  80. #先sha1加密 在md5加密
  81. $sign_str = md5(sha1(implode('&', $signature)));
  82. return $sign_str;
  83. }
  84. #@todo AES加解密
  85. #加密
  86. private function encrypt($input, $key) {
  87. $size = @mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
  88. dump('size');dump($size);
  89. $input = $this->pkcs5_pad($input, $size);
  90. $td = @mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');
  91. $iv = @mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
  92. @mcrypt_generic_init($td, $key, $iv);
  93. $data = @mcrypt_generic($td, $input);
  94. @mcrypt_generic_deinit($td);
  95. @mcrypt_module_close($td);
  96. $data = strtoupper(bin2hex($data));
  97. return $data;
  98. }
  99. public function encrypt3($key, $iv, $data)
  100. {
  101. /**
  102. * 打开加密
  103. */
  104. $td = @mcrypt_module_open(MCRYPT_RIJNDAEL_128, "", MCRYPT_MODE_CBC, "");
  105. /**
  106. * 初始化加密
  107. */
  108. @mcrypt_generic_init($td, $key, $iv);
  109. /**
  110. * 加密
  111. */
  112. $encrypted = @mcrypt_generic($td, $data);
  113. /**
  114. * 清理加密
  115. */
  116. @mcrypt_generic_deinit($td);
  117. /**
  118. * 关闭
  119. */
  120. @mcrypt_module_close($td);
  121. return base64_encode($encrypted);
  122. }
  123. public function encrypt2($input, $key)
  124. {
  125. $data = openssl_encrypt($input, 'AES-128-ECB', $key, OPENSSL_RAW_DATA);
  126. $data = base64_encode($data);
  127. return $data;
  128. }
  129. public function decrypt2($sStr, $sKey)
  130. {
  131. $decrypted = openssl_decrypt(base64_decode($sStr), 'AES-128-ECB', $sKey, OPENSSL_RAW_DATA);
  132. return $decrypted;
  133. }
  134. private function pkcs5_pad ($text, $blocksize) {
  135. $pad = $blocksize - (strlen($text) % $blocksize);
  136. return $text . str_repeat(chr($pad), $pad);
  137. }
  138. public function decrypt($sStr, $sKey) {
  139. $sStr=hex2bin($sStr);
  140. $decrypted= @mcrypt_decrypt(
  141. MCRYPT_RIJNDAEL_128,
  142. $sKey,
  143. $sStr,
  144. MCRYPT_MODE_ECB
  145. );
  146. $dec_s = strlen($decrypted);
  147. $padding = ord($decrypted[$dec_s-1]);
  148. $decrypted = substr($decrypted, 0, -$padding);
  149. return $decrypted;
  150. }
  151. }