RefillPhone.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace refill\yichangt_hf;
  3. require_once(BASE_HELPER_RAPI_PATH . '/yichangt_hf/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 $card_no, string $order_sn, int $amount)
  13. {
  14. $params['appid'] = config::APP_ID;
  15. $params['api_product'] = 'dhcz';
  16. $params['mobile'] = $card_no;
  17. $params['order'] = $order_sn;
  18. $params['cash'] = $amount;
  19. $params['nonce'] = rand(100000,999999);
  20. $params['time'] = time();
  21. $params['notify'] = config::NOTIFY_URL;
  22. return $params;
  23. }
  24. public function add($card_no, $card_type, $amount, $params,&$net_errno = 0)
  25. {
  26. $params = $this->req_params($card_no, $params['order_sn'], $amount);
  27. $sign = $this->sign($params);
  28. $params['signature'] = $sign;
  29. $resp = http_request(config::ORDER_URL, $params, 'POST', false, [], $net_errno);
  30. if (empty($resp)) {
  31. return [false, '系统错误', true];
  32. }
  33. else
  34. {
  35. Log::record($resp, Log::DEBUG);
  36. $resp = json_decode($resp ,true);
  37. if (empty($resp)) {
  38. return [false, '系统错误', true];
  39. } elseif ($resp['code'] === 1) {
  40. return [true, $resp['data']['order'], false];
  41. } else {
  42. return [false, $resp['info'], false];
  43. }
  44. }
  45. }
  46. public function query($refill_info)
  47. {
  48. $params['appid'] = config::APP_ID;
  49. $params['api_product'] = 'query';
  50. $params['merchant_order_id'] = $refill_info['order_sn'];
  51. $params['nonce'] = rand(100000,999999);
  52. $params['time'] = time();
  53. $sign = $this->sign($params);
  54. $params['signature'] = $sign;
  55. $resp = http_request(config::QUERY_URL, $params, 'POST');
  56. if (empty($resp)) {
  57. return [false, '系统错误'];
  58. }
  59. else
  60. {
  61. Log::record($resp, Log::DEBUG);
  62. $resp = json_decode($resp, true);
  63. if (empty($resp))
  64. {
  65. return [false, '系统错误'];
  66. }
  67. elseif ($resp['code'] === 1)
  68. {
  69. $data = $resp['data'];
  70. $status = $data['status'];
  71. if ($status === 2) {
  72. $order_state = ORDER_STATE_SUCCESS;
  73. } elseif ($status === 3) {
  74. $order_state = ORDER_STATE_CANCEL;
  75. } elseif (in_array($status, [1, 4], true)) {
  76. $order_state = ORDER_STATE_SEND;
  77. } else {
  78. return [false, $resp['info']];
  79. }
  80. return [true, $order_state];
  81. }
  82. elseif ($resp['code'] === -101)
  83. {
  84. return [true, ORDER_STATE_NOEXIST];
  85. }
  86. else
  87. {
  88. return [false, $resp['info']];
  89. }
  90. }
  91. }
  92. public function balance()
  93. {
  94. $params['appid'] = config::APP_ID;
  95. $params['api_product'] = 'query';
  96. $params['nonce'] = rand(100000,999999);
  97. $params['time'] = time();
  98. $sign = $this->sign($params);
  99. $params['signature'] = $sign;
  100. $resp = http_request(config::BALANCE_URL, $params, 'POST');
  101. if (empty($resp)) {
  102. return [false, '系统错误'];
  103. } else {
  104. Log::record($resp, Log::DEBUG);
  105. $resp = json_decode($resp ,true);
  106. if (empty($resp)) {
  107. return [false, '系统错误', true];
  108. } elseif ($resp['code'] === 1) {
  109. return [true, $resp['data']['account'], false];
  110. } else {
  111. return [false, $resp['info'], false];
  112. }
  113. }
  114. }
  115. private function sign($params)
  116. {
  117. $params['token'] = sha1(config::APP_ID . '|' . config::APP_SECRET);
  118. ksort($params);
  119. $signature_string = '';
  120. foreach ($params as $k => $v) {
  121. if (strlen($v)) {
  122. if($k == 'notify') {
  123. $v = urlencode($v);
  124. }
  125. $signature_string .= "{$k}={$v}&";
  126. }
  127. }
  128. $signature_string = substr($signature_string, 0, -1);
  129. return sha1($signature_string);
  130. }
  131. }