F2fpayController.php 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <?php
  2. namespace App\Http\Controllers\Api;
  3. use App\Components\Callback;
  4. use App\Http\Controllers\Controller;
  5. use Illuminate\Http\Request;
  6. use Log;
  7. use Payment\Client\Query;
  8. use Payment\Common\PayException;
  9. class F2fpayController extends Controller
  10. {
  11. use Callback;
  12. // 接收GET请求
  13. public function index(Request $request)
  14. {
  15. Log::info("【支付宝当面付】回调接口[GET]:".var_export($request->all(), TRUE).'['.getClientIp().']');
  16. exit("【支付宝当面付】接口正常");
  17. }
  18. // 接收POST请求
  19. public function store(Request $request)
  20. {
  21. Log::info("【支付宝当面付】回调接口[POST]:".var_export($request->all(), TRUE));
  22. $result = "fail";
  23. try{
  24. $verify_result = Query::run('ali_charge', [
  25. 'use_sandbox' => FALSE,
  26. "partner" => self::$systemConfig['f2fpay_app_id'],
  27. 'app_id' => self::$systemConfig['f2fpay_app_id'],
  28. 'sign_type' => 'RSA2',
  29. 'ali_public_key' => self::$systemConfig['f2fpay_public_key'],
  30. 'rsa_private_key' => self::$systemConfig['f2fpay_private_key'],
  31. 'notify_url' => self::$systemConfig['website_url']."/api/f2fpay", // 异步回调接口
  32. 'return_url' => self::$systemConfig['website_url'],
  33. 'return_raw' => FALSE
  34. ], [
  35. 'out_trade_no' => $request->input('out_trade_no'),
  36. 'trade_no' => $request->input('trade_no'),
  37. ]);
  38. Log::info("【支付宝当面付】回调验证查询:".var_export($verify_result, TRUE));
  39. } catch(PayException $e){
  40. Log::info("【支付宝当面付】回调验证查询出错:".var_export($e->errorMessage(), TRUE));
  41. exit($result);
  42. }
  43. if($verify_result['is_success'] == 'T'){ // 验证成功
  44. $result = "success";
  45. if($_POST['trade_status'] == 'TRADE_FINISHED' || $_POST['trade_status'] == 'TRADE_SUCCESS'){
  46. // 商户订单号
  47. $data = [];
  48. $data['out_trade_no'] = $request->input('out_trade_no');
  49. // 支付宝交易号
  50. $data['trade_no'] = $request->input('trade_no');
  51. // 交易状态
  52. $data['trade_status'] = $request->input('trade_status');
  53. // 交易金额(这里是按照结算货币汇率的金额,和rmb_fee不相等)
  54. $data['total_amount'] = $request->input('total_amount');
  55. $this->tradePaid($data, 5);
  56. }else{
  57. Log::info('支付宝当面付-POST:交易失败['.getClientIp().']');
  58. }
  59. }else{
  60. Log::info('支付宝当面付-POST:验证失败['.getClientIp().']');
  61. }
  62. // 返回验证结果
  63. exit($result);
  64. }
  65. }