RefillPhone.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <?php
  2. namespace refill\zhenqi;
  3. require_once(BASE_HELPER_RAPI_PATH . '/zhenqi/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. private function req_params(int $phone, int $card_type, int $amount, string $order_sn)
  13. {
  14. $params['type'] = 1;
  15. $params['account_type'] = 1;
  16. $params['mobile'] = $phone;
  17. $params['out_trade_no'] = $order_sn;
  18. $params['product_id'] = config::product_code[$amount];
  19. $params['time_stamp'] = time();
  20. return $params;
  21. }
  22. public function add($card_no, $card_type, $amount, $params,&$net_errno = 0)
  23. {
  24. $params = $this->req_params($card_no, $card_type, $amount, $params['order_sn']);
  25. if(empty($params['product_id'])) {
  26. return [false, '商品编号获取失败', false];
  27. }
  28. $sign = $this->sign($params);
  29. $params['sign'] = $sign;
  30. $params = json_encode($params);
  31. $params = $this->encrypt($params);
  32. $resp = http_post_data(config::ORDER_URL, $params , config::ExtHeaders, $net_errno);
  33. if (empty($resp)) {
  34. return [false, '系统错误', true];
  35. }
  36. else
  37. {
  38. Log::record($resp, Log::DEBUG);
  39. $resp = json_decode($resp, true);
  40. if (empty($resp)) {
  41. return [false, '系统错误', true];
  42. } else {
  43. $status = intval($resp['status']);
  44. if($status === 1) {
  45. $data = $this->decrypt($resp['data']['json_data']);
  46. Log::record("zhenqi add status 0 data:{$data}", Log::DEBUG);
  47. $data = json_decode($data,true);
  48. return [true, $data['out_trade_no'], false];
  49. } else {
  50. $sub_code = $resp['sub_code'];
  51. if(($sub_code >= 100 && $sub_code <= 200) || $sub_code == 102) {
  52. $data = $this->decrypt($resp['data']['json_data']);
  53. Log::record("zhenqi add status 1 sub_code:{$sub_code}, data:{$data}", Log::DEBUG);
  54. $data = json_decode($data,true);
  55. return [true, $data['out_trade_no'], false];
  56. }else {
  57. return [false, $resp['info'], false];
  58. }
  59. }
  60. }
  61. }
  62. }
  63. public function query($refill_info)
  64. {
  65. $params['out_trade_no'] = $refill_info['order_sn'];
  66. $params['time_stamp'] = time();
  67. $params['sign'] = $this->sign($params);
  68. $params = json_encode($params);
  69. $params = $this->encrypt($params);
  70. $resp = http_post_data(config::QUERY_URL, $params , config::ExtHeaders);
  71. if (empty($resp)) {
  72. return [false, '系统错误'];
  73. }
  74. else
  75. {
  76. Log::record($resp, Log::DEBUG);
  77. $resp = json_decode($resp, true);
  78. if (empty($resp)) {
  79. return [false, '系统错误'];
  80. }
  81. elseif($resp['status'] == 1)
  82. {
  83. $data = $this->decrypt($resp['data']['json_data']);
  84. Log::record("zhenqi order query status 1 data:{$data}", Log::DEBUG);
  85. $data = json_decode($data,true);
  86. $status = intval($data['status']);
  87. if ($status === 1) {
  88. $updata['official_sn'] = $data['sp_order_no'];
  89. Model('refill_order')->edit($refill_info['order_id'], $updata);
  90. $order_state = ORDER_STATE_SUCCESS;
  91. } elseif ($status === 2) {
  92. $order_state = ORDER_STATE_CANCEL;
  93. } elseif ($status === 3) {
  94. $order_state = ORDER_STATE_SEND;
  95. } else {
  96. return [false, $status];
  97. }
  98. return [true, $order_state];
  99. }
  100. elseif ($resp['sub_code'] == 1210)
  101. {
  102. return [true, ORDER_STATE_NOEXIST];
  103. }
  104. else
  105. {
  106. return [false, $resp['info']];
  107. }
  108. }
  109. }
  110. private function sign($params)
  111. {
  112. ksort($params);
  113. $body = "";
  114. foreach ($params as $k => $v) {
  115. $body .= "{$k}={$v}&";
  116. }
  117. $body .= "app_secret=".config::APP_SECRET;
  118. return strtoupper(md5($body));
  119. }
  120. //加密
  121. private function encrypt($encrypt)
  122. {
  123. $key = substr(openssl_digest(openssl_digest(config::TOKEN, 'sha1', true), 'sha1', true), 0, 16);
  124. $data = openssl_encrypt($encrypt, 'AES-128-ECB', $key, OPENSSL_RAW_DATA);
  125. return base64_encode($data);
  126. }
  127. //解密
  128. private function decrypt($decrypt)
  129. {
  130. $key = substr(openssl_digest(openssl_digest(config::TOKEN, 'sha1', true), 'sha1', true), 0, 16);
  131. return openssl_decrypt($decrypt, 'AES-128-ECB', $key);
  132. }
  133. }