RefillPhone.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. <?php
  2. namespace refill\app;
  3. require_once(BASE_HELPER_RAPI_PATH . '/app/config.php');
  4. use refill;
  5. use Log;
  6. class RefillPhone extends refill\IRefillPhone
  7. {
  8. public function __construct($cfgs)
  9. {
  10. parent::__construct($cfgs);
  11. }
  12. public function goods($quality,int $amount,int $card_type)
  13. {
  14. $maps = $this->mAmountTypes[$quality] ?? [];
  15. $key = "{$amount}-{$card_type}";
  16. if(array_key_exists($key,$maps)) {
  17. $params = $maps[$key];
  18. return [$params['goods_id'], round($params['price'],2)];
  19. }
  20. else {
  21. return [];
  22. }
  23. }
  24. private function req_params(string $order_sn, string $product_code)
  25. {
  26. $params['AppKey'] = config::APP_KEY;
  27. $params['TimesTamp'] = time();
  28. $params['ProductCode'] = 'PLM100024'; //产品编码需传入
  29. $params['BuyCount'] = 1;
  30. $params['MOrderID'] = $order_sn;
  31. $params['CustomerIP'] = config::API_IP;
  32. $params['IsCallback'] = 1;
  33. $params['CallBackUrl'] = config::NOTIFY_URL;
  34. $params['Version'] = '1.0';
  35. return $params;
  36. }
  37. //直充提单
  38. public function add($card_no, $card_type, $amount, $params)
  39. {
  40. $order_sn = $params['order_sn'];
  41. $product_code = $params['product_code'];
  42. $params = $this->req_params($order_sn,$product_code);
  43. $params['ChargeAccount'] = $card_no;
  44. $params['ChargeAccountType'] = 1;//账号类型1 手机号,2 QQ号,3 微信号
  45. $sign = $this->sign($params);
  46. $params['Sign'] = $sign;
  47. $resp = http_request(config::ORDER_URL, $params);
  48. if (empty($resp)) {
  49. return [false, '网络错误', true];
  50. }
  51. else
  52. {
  53. Log::record($resp, Log::DEBUG);
  54. $resp = json_decode($resp, true);
  55. if (empty($resp)) {
  56. return [false, '网络错误', true];
  57. } elseif ($resp['Code'] == 999) {
  58. return [true, $resp['OrderModel']['OrderId'], false];
  59. } else {
  60. return [false, $resp['Msg'], false];
  61. }
  62. }
  63. }
  64. public function CardOrderAdd($card_no, $card_type, $amount, $params)
  65. {
  66. $order_sn = $params['order_sn'];
  67. $product_code = $params['product_code'];
  68. $params = $this->req_params($order_sn,$product_code);
  69. $params['PublicKey'] = $this->CT_RSA($params['order_id']);
  70. $sign = $this->sign($params);
  71. $params['Sign'] = $sign;
  72. $resp = http_request(config::CARD_ORDER_URL, $params);
  73. if (empty($resp)) {
  74. return [false, '网络错误', true];
  75. }
  76. else
  77. {
  78. Log::record($resp, Log::DEBUG);
  79. $resp = json_decode($resp, true);
  80. if (empty($resp)) {
  81. return [false, '网络错误', true];
  82. } elseif ($resp['Code'] == 999) {
  83. return [true, $resp['OrderModel']['OrderId'], false];
  84. } else {
  85. return [false, $resp['Msg'], false];
  86. }
  87. }
  88. }
  89. private function CT_RSA($order_id)
  90. {
  91. //创建公私钥
  92. $res = openssl_pkey_new();
  93. //获取私钥
  94. openssl_pkey_export($res, $private_key);
  95. //获取公钥
  96. $public_key = openssl_pkey_get_details($res)['key'];
  97. $rsa = [
  98. 'public_key' => $public_key,
  99. 'private_key' => $private_key,
  100. ];
  101. $rsa_json = json_encode($rsa);
  102. Log::record("rsa info : {$rsa_json}");
  103. //公钥私钥与订单绑定,加rsa字段
  104. $updata['public_key'] = $public_key;
  105. $updata['private_key'] = $private_key;
  106. Model('refill_order')->edit($order_id, $updata);
  107. return $public_key;
  108. }
  109. public function query($refill_info)
  110. {
  111. $params['AppKey'] = config::APP_KEY;
  112. $params['TimesTamp'] = time();
  113. $params['MOrderID'] = $refill_info['order_sn'];
  114. $params['Version'] = '1.0';
  115. $content = config::APP_KEY . $params['TimesTamp'] . $params['Version'] . $params['MOrderID'] . config::App_Secret;
  116. $params['Sign'] = strtoupper(md5($content));
  117. $resp = http_request(config::QUERY_URL, $params);
  118. if (empty($resp)) {
  119. return [false, '网络错误', []];
  120. }
  121. else
  122. {
  123. Log::record($resp, Log::DEBUG);
  124. $resp = json_decode($resp, true);
  125. if (empty($resp)) {
  126. return [false, '网络错误', []];
  127. }
  128. elseif ($resp['Code'] == 999)
  129. {
  130. $status = intval($resp['Data']['OrderState']);
  131. $card_data = [];
  132. if ($status === 2) {
  133. if(!empty($resp['Data']['CardData'])) {
  134. $private_key = $refill_info['private_key'];
  135. $cards = $this->rsa_decode($resp['Data']['CardData'],$private_key);
  136. $card_data = [];
  137. foreach ($cards as $card) {
  138. $card_data[] = json_decode($card, true);
  139. }
  140. //需返回卡密信息
  141. }
  142. $order_state = ORDER_STATE_SUCCESS;
  143. } elseif ($status === 3) {
  144. $order_state = ORDER_STATE_CANCEL;
  145. } elseif (in_array($status, [1,4])) {
  146. $order_state = ORDER_STATE_SEND;
  147. } else {
  148. return [false, $resp['Message'], $card_data];
  149. }
  150. return [true, $order_state, $card_data];
  151. }
  152. else
  153. {
  154. return [false, $resp['Message'], []];
  155. }
  156. }
  157. }
  158. private function rsa_decode($card_data,$private_key)
  159. {
  160. $res = openssl_pkey_get_private($private_key);
  161. //使用私钥解密数据
  162. openssl_private_decrypt($card_data, $decrypted, $res);
  163. return $decrypted;
  164. }
  165. private function sign($params)
  166. {
  167. $content = config::APP_KEY . $params['BuyCount'] . $params['CallBackUrl'] . $params['ChargeAccount'] . $params['CustomerIP'] . $params['MOrderID'];
  168. $content .= $params['ProductCode'] . $params['TimesTamp'] . $params['Version'] . config::App_Secret;
  169. return strtoupper(md5($content));
  170. }
  171. }