RefillPhone.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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. if ($resp === false) {
  41. return [false, '网络错误', true];
  42. }
  43. else
  44. {
  45. Log::record($resp, Log::DEBUG);
  46. $resp = json_decode($resp ,true);
  47. if($resp == false) {
  48. return [false, '网络错误', true];
  49. }
  50. $status = intval($resp['code']['status']);
  51. if($status == 100000) {
  52. return [true, $resp['obj'], false];
  53. }
  54. return [false , $resp['code']['desc'], false];
  55. }
  56. }
  57. public function query($refill_info)
  58. {
  59. $params['orderNumber'] = $refill_info['order_sn'];
  60. $params['username'] = config::USERNAME;
  61. $content = $params['username'] . $params['orderNumber'] . config::KEY;
  62. $params['sign'] = md5($content);
  63. $resp = http_request(config::QUERY_URL, $params , 'POST' , false , config::ExtHeaders);
  64. if ($resp === false) {
  65. return [false, '系统错误'];
  66. } else {
  67. Log::record($resp, Log::DEBUG);
  68. $resp = json_decode($resp, true);
  69. if ($resp['code']['status'] == 100000) {
  70. $order_state = ORDER_STATE_SEND;
  71. $obj = $resp['obj'];
  72. if ($obj['resultCode'] == 2) {
  73. $order_state = ORDER_STATE_SUCCESS;
  74. } elseif ($obj['resultCode'] == 3) {
  75. $order_state = ORDER_STATE_CANCEL;
  76. }
  77. return [true, $order_state];
  78. } else {
  79. return [false, $resp['code']['desc']];
  80. }
  81. }
  82. }
  83. private function sign($params)
  84. {
  85. $key = config::KEY;
  86. $content = $params['username'] . $params['orderNumber'] . $params['cardNumber'] . $params['cardExt'] . $params['rechargeNum'] . $params['rechargePwd'] . $params['productNo'];
  87. $content .= $params['timestamp'] . $key;
  88. return md5($content);
  89. }
  90. /**
  91. * 获取毫秒级别的时间戳
  92. */
  93. private static function getMillisecond()
  94. {
  95. //获取毫秒的时间戳
  96. $time = explode ( " ", microtime () );
  97. $time = $time[1] . ($time[0] * 1000);
  98. $time2 = explode( ".", $time );
  99. $time = $time2[0];
  100. return $time;
  101. }
  102. private function encryptWithOpenssl($data = '')
  103. {
  104. $key = substr(config::KEY , 0 ,16);
  105. $iv = substr(config::KEY , -16);
  106. return base64_encode(openssl_encrypt($data, "AES-128-CBC", $key, OPENSSL_RAW_DATA, $iv));
  107. }
  108. }