RefillPhone.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. <?php
  2. namespace refill\legou;
  3. require_once(BASE_HELPER_RAPI_PATH . '/legou/config.php');
  4. use mtopcard\cards_helper;
  5. use refill;
  6. use Log;
  7. class RefillPhone extends refill\IRefillPhone
  8. {
  9. public function __construct($cfgs)
  10. {
  11. parent::__construct($cfgs);
  12. }
  13. private function req_params(int $phone,$card_type, int $amount, string $order_sn)
  14. {
  15. $params['username'] = config::USERNAME;
  16. $params['orderNumber'] = $order_sn;
  17. $params['cardNumber'] = $phone;
  18. $params['cardExt'] = $amount;
  19. $params['productNo'] = config::ProductIDS[$card_type];
  20. $params['timestamp'] = $this->getMillisecond();
  21. $params['notifyUrl'] = config::NOTIFY_URL;
  22. return $params;
  23. }
  24. public function add($card_no, $card_type, $amount, $params)
  25. {
  26. $params = $this->req_params($card_no,$card_type, $amount, $params['order_sn']);
  27. [$success,$card] = cards_helper::reserve($card_type,$amount,$params['buyer_id'],$card_no,$card_type,$params['order_id'],config::StoreIDS);
  28. if(!$success) {
  29. return [false, '没有可用卡密', false];
  30. }
  31. $rcard_no = $card->card_no();
  32. $rcard_key = $card->card_key();
  33. $params['rechargeNum'] = $rcard_no;
  34. $params['rechargePwd'] = $rcard_key;
  35. $sign = $this->sign($params);
  36. $params['sign'] = $sign;
  37. $params['rechargeNum'] = $this->encryptWithOpenssl($rcard_no);
  38. $params['rechargePwd'] = $this->encryptWithOpenssl($rcard_key);
  39. $resp = http_request(config::ORDER_URL, $params , 'POST' , false , config::ExtHeaders);
  40. $card_id = $card->card_id();
  41. if ($resp === false) {
  42. cards_helper::reuse($card_id);
  43. return [false, '网络错误', true];
  44. }
  45. else
  46. {
  47. Log::record($resp, Log::DEBUG);
  48. $resp = json_decode($resp ,true);
  49. if($resp == false) {
  50. cards_helper::reuse($card_id);
  51. return [false, '网络错误', true];
  52. }
  53. $status = intval($resp['code']['status']);
  54. if($status == 100000) {
  55. return [true, $resp['obj'], false];
  56. }else{
  57. cards_helper::reuse($card_id);
  58. return [false , $resp['code']['desc'], false];
  59. }
  60. }
  61. }
  62. public function query($refill_info)
  63. {
  64. $params['orderNumber'] = $refill_info['order_sn'];
  65. $params['username'] = config::USERNAME;
  66. $content = $params['username'] . $params['orderNumber'] . config::KEY;
  67. $params['sign'] = md5($content);
  68. $resp = http_request(config::QUERY_URL, $params , 'POST' , false , config::ExtHeaders);
  69. if ($resp === false) {
  70. return [false, '网络错误'];
  71. } else {
  72. Log::record($resp, Log::DEBUG);
  73. $resp = json_decode($resp, true);
  74. if($resp == false) {
  75. return [false, '网络错误'];
  76. }
  77. $status = intval($resp['code']['status']);
  78. if ($status == 100000) {
  79. $order_state = -1;
  80. $obj = $resp['obj'];
  81. if ($obj['resultCode'] == 2) {
  82. $order_state = ORDER_STATE_SUCCESS;
  83. } elseif ($obj['resultCode'] == 3) {
  84. $order_state = ORDER_STATE_CANCEL;
  85. } else {
  86. $order_state = ORDER_STATE_SEND;
  87. }
  88. if ($order_state == -1) {
  89. return [false, $resp['code']['desc']];
  90. }
  91. return [true, $order_state];
  92. } else {
  93. return [false, $resp['code']['desc']];
  94. }
  95. }
  96. }
  97. private function sign($params)
  98. {
  99. $key = config::KEY;
  100. $content = $params['username'] . $params['orderNumber'] . $params['cardNumber'] . $params['cardExt'] . $params['rechargeNum'] . $params['rechargePwd'] . $params['productNo'];
  101. $content .= $params['timestamp'] . $key;
  102. return md5($content);
  103. }
  104. /**
  105. * 获取毫秒级别的时间戳
  106. */
  107. private static function getMillisecond()
  108. {
  109. //获取毫秒的时间戳
  110. $time = explode ( " ", microtime () );
  111. $time = $time[1] . ($time[0] * 1000);
  112. $time2 = explode( ".", $time );
  113. $time = $time2[0];
  114. return $time;
  115. }
  116. private function encryptWithOpenssl($data = '')
  117. {
  118. $key = substr(config::KEY , 0 ,16);
  119. $iv = substr(config::KEY , -16);
  120. return base64_encode(openssl_encrypt($data, "AES-128-CBC", $key, OPENSSL_RAW_DATA, $iv));
  121. }
  122. }