PalmPayService.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. namespace app\main\service;
  3. use app\main\constants\ApiConstants;
  4. use GuzzleHttp\Client as Http;
  5. use GuzzleHttp\Exception\GuzzleException;
  6. use think\Exception;
  7. class PalmPayService
  8. {
  9. protected static $self = null;
  10. public static function instance()
  11. {
  12. if (self::$self == null) {
  13. self::$self = new self();
  14. }
  15. return self::$self;
  16. }
  17. /**
  18. * 四方调用API接口
  19. * @param $data 发送到API的数据
  20. * @param $payInfo 支付信息
  21. * @param $goodsInfo 商品信息
  22. * @param $orderInfo 订单信息
  23. * @param int $loopIndex 循环调用API的次数
  24. * @return mixed|\Psr\Http\Message\ResponseInterface
  25. */
  26. /**
  27. * @param $data 发送到API的数据
  28. * @param $payInfo 支付信息
  29. * @param $goodsInfo 商品信息
  30. * @param $orderInfo 订单信息
  31. * @param int $loopIndex 循环调用API的次数
  32. * @return mixed|\Psr\Http\Message\ResponseInterface
  33. * @throws Exception
  34. */
  35. public function payPalmApi($data, $payInfo, $goodsInfo, $orderInfo, $loopIndex = 1)
  36. {
  37. $payUrl = ApiConstants::PALM_PAY_URL;
  38. $palmApiStartTime = microtime(true);
  39. try {
  40. $client = new Http([
  41. 'connect_timeout' => 10,
  42. 'timeout' => 30,
  43. 'http_errors' => true, //抛出异常 true是 false否
  44. 'verify' => false, //不验证ssl证书
  45. ]);
  46. LogService::info(json_encode($data)); //记录日志
  47. //$res = $client->request('GET', $payUrl, ['form_params' => $data]);
  48. $result = $client->get($payUrl . '?' . http_build_query($data));
  49. $palmApiEndTime = microtime(true);
  50. $apiRunTime = round($palmApiEndTime - $palmApiStartTime, 3);
  51. if ($result->getStatusCode() != '200') {
  52. LogService::error(sprintf('palmpay_create_order_fail!wxpay_id:%s,wxpay_name:%s,mch_id:%s,channel_id:%s,user_id:%s,money:%s,good_id:%s,out_trade_no:%s,api_run_time:%s s,loop_index:%s,errmessage:%s',
  53. $payInfo['id'], $payInfo['name'], $payInfo['quartet_merchant_id'], $orderInfo['admin_id'],
  54. $orderInfo['user_id'], $goodsInfo['money'], $orderInfo['goods_id'], $orderInfo['out_trade_no'],
  55. $apiRunTime, $loopIndex, json_encode(var_export($result, true), JSON_UNESCAPED_UNICODE)));
  56. LogService::error('四方平台订单创建失败!订单内容: ' . json_encode($data) . " 四方平台返回内容: " . json_encode(var_export($result,
  57. true), JSON_UNESCAPED_UNICODE));
  58. throw new Exception('订单创建失败,请重新下单!');
  59. } else {
  60. $result = json_decode($result->getBody()->getContents(), true);
  61. if ($result['errcode'] != '0') {
  62. LogService::error(sprintf('palmpay_create_order_fail!wxpay_id:%s,wxpay_name:%s,mch_id:%s,channel_id:%s,user_id:%s,money:%s,good_id:%s,out_trade_no:%s,api_run_time:%s s,loop_index:%s,errmessage:%s',
  63. $payInfo['id'], $payInfo['name'], $payInfo['quartet_merchant_id'], $orderInfo['admin_id'],
  64. $orderInfo['user_id'], $goodsInfo['money'], $orderInfo['goods_id'], $orderInfo['out_trade_no'],
  65. $apiRunTime, $loopIndex, $result['err']));
  66. LogService::error('四方平台订单创建失败!订单内容:' . json_encode(var_export($data,
  67. true)) . " 四方平台返回内容: " . $result['err']);
  68. throw new Exception('订单创建失败,请重新下单!');
  69. }
  70. }
  71. LogService::info(sprintf('palmpay_create_order_success!wxpay_id:%s,wxpay_name:%s,mch_id:%s,channel_id:%s,user_id:%s,money:%s,good_id:%s,out_trade_no:%s,api_run_time:%s s,loop_index:%s',
  72. $payInfo['id'], $payInfo['name'], $payInfo['quartet_merchant_id'], $orderInfo['admin_id'],
  73. $orderInfo['user_id'], $goodsInfo['money'], $orderInfo['goods_id'], $orderInfo['out_trade_no'],
  74. $apiRunTime, $loopIndex));
  75. return $result;
  76. } catch (GuzzleException $exception) {
  77. $palmApiEndTime = microtime(true);
  78. $apiRunTime = round($palmApiEndTime - $palmApiStartTime, 3);
  79. LogService::error(sprintf('palmpay_create_order_fail!wxpay_id:%s,wxpay_name:%s,mch_id:%s,channel_id:%s,user_id:%s,money:%s,good_id:%s,out_trade_no:%s,api_run_time:%s s,loop_index:%s,errmessage:%s',
  80. $payInfo['id'], $payInfo['name'], $payInfo['quartet_merchant_id'], $orderInfo['admin_id'],
  81. $orderInfo['user_id'], $goodsInfo['money'], $orderInfo['goods_id'], $orderInfo['out_trade_no'],
  82. $apiRunTime, $loopIndex, $exception->getMessage()));
  83. LogService::error('四方平台订单创建失败!订单内容: ' . json_encode(var_export($data, true), JSON_UNESCAPED_UNICODE));
  84. LogService::error($exception->getMessage());
  85. LogService::error($exception->getTraceAsString());
  86. if ($loopIndex <= ApiConstants::LOOP_EXEC_API_COUNT) {
  87. $loopIndex++;
  88. return $this->payPalmApi($data, $payInfo, $goodsInfo, $orderInfo, $loopIndex);
  89. }
  90. throw new Exception('订单创建失败,请重新下单!');
  91. }
  92. }
  93. }