TestController.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <?php
  2. namespace App\Http\Controllers\Api;
  3. use App\Helpers\Jwt;
  4. use App\Http\Controllers\Api\v1\NotifyController;
  5. use App\Models\MemberModel;
  6. use App\Models\UserModel;
  7. use App\Services\NotifyService;
  8. use App\Services\RedisService;
  9. use App\Services\SnapshotService;
  10. use App\Services\WechatService;
  11. use Illuminate\Support\Facades\Session;
  12. /**
  13. * 测试控制器类
  14. * @author wesmiler
  15. * @since 2020/11/10
  16. * Class TestController
  17. * @package App\Http\Controllers
  18. */
  19. class TestController extends BaseController
  20. {
  21. /**
  22. * 构造函数
  23. * @author wesmiler
  24. * @since 2020/11/11
  25. * TestController constructor.
  26. */
  27. public function __construct()
  28. {
  29. parent::__construct();
  30. }
  31. public function index(){
  32. $json = '{
  33. "result": {
  34. "id": "f2a8cd57-9450-5f94-bec0-310825e29f87",
  35. "create_time": "2021-07-19T13:32:01+08:00",
  36. "resource_type": "encrypt-resource",
  37. "event_type": "TRANSACTION.SUCCESS",
  38. "summary": "支付成功",
  39. "resource": {
  40. "original_type": "transaction",
  41. "algorithm": "AEAD_AES_256_GCM",
  42. "ciphertext": "FORph2bcy9H9mob0pQBoxmCDj0c7Uxj+robp1INckVLkVzEhwGCJzjtevbfs2PYzblPkbv0J2HEWj3uX9XVRvHa3KzZTw8\/aMHSMLNdL9ABWfW1LlhWFrhjeh5Zeb38eQ2nKkXBBqMErSkq+sp6rHW0JX\/R9r4yJwVylnMm50BEFUiaYIeooc2ka86zKOlqBozhpoK8SdUcyOPeDwRPEFsiR6pBqFLbfDcZ03KpoehRlB4SC+h+PyGUevkinC1KyvWeqYSJ3s21oTkL4WZBm+d\/6C+L5uUeT+hkFVVAetezE\/OV8hpSymYmNPG2XG59J5DgNmpMOs\/DMm5ueTlySnegWAKMo7quYHBepbZ\/BGDNKed3MjJ69e\/OlWyJZNvExMFnkyuMeOTOPT12figD7XNFpAn4zJWIWdDR1rawzOt5oG9Lz4l2n+njM6solr4frqpUeIAlWATloJNmvfz63QKpiUJHNbHig6frnP0yTxuHYm5Doh+YfqJNslT0CtYXPPy2UVlLHCRatxUdmafBnMbDzwPzf7rEzgzm\/q35LM7qfjAJgIXjXirbun1tKDqjKKpSg8OO6KcqdlqtpbbLWjST1jcSeSXAYetJM6d7xn3tywFm0rKNf19aLbW\/WiTywSy\/BtF+eRyD5pCJLjrVDxSEpQiMs9qYj+artq30CfrvcYWqgeevkAnVnuxRELXbDO49YFoBmzZyKIoru+nuAUwYu52f6FQ==",
  43. "associated_data": "transaction",
  44. "nonce": "I9XWeVfjyb7N"
  45. },
  46. "s": "\/api\/notify\/pay\/index"
  47. },
  48. "sign": "K0ZBu0hE14W8hf2z095KnyRO7o48TZP8JvP\/bpkzGH7bvYwpuiNPBzLCes8DT+tiZ85AdE1gKYzN4jMIDtHYUDSMV+LeX6OxptPA6+pQXpReOA2S8\/RzQJhCA0MAJCF7hiYZYC6X3cSuwaXF+rTTQPhtwbrc093FEUMwtGPLiMlkBwH2okSGxv+CPH\/VRMGQKeitWLsj1PpjIiOkeu8CK8IL0EjQ\/idlu+iZ\/DK2iVquet1HqPGGJpaiKqIQvk0vszumOleh1PJse\/uqshmiyiquZhRn+mvo2Nplwt94je7GQTbw6uN2Mzmgc5MMAk5I+0sQzEvHIEQyj2Qf1sBxFg==",
  49. "date": "2021-07-19 13:32:01"
  50. }';
  51. $json = json_decode($json, true);
  52. $data = $json['result'];
  53. /* $data = [
  54. "original_type"=> "transaction",
  55. "algorithm"=> "AEAD_AES_256_GCM",
  56. "ciphertext"=> "//hUHdektloiqMVIQ0nOEZj91e2oIEUNZ7EtnLdLnjriyKQwKes9VcEvfmFYMnTFXr1Lg/mFHJaNE2C4hZrVykVpiT0aahWSV4pn1m9867LOwXWbE2uhMMPXtDLT9bfYT3gzXbxkdo\/LkOB7Bke20MnEq3mgSkPbRytyQ96RhZGPsqa9S7QiycshC82Hw\/QhGwqvLsUOdCP8y6yt28\/MPJc+VB1sSi\/hIDKIlYFxb7TIWRtzpIu057ICyNHtPXRzCEUEtK7t9gywxYJd6kXYEKQqOTqUlXoHAHQt4lIHN27TCuAE0KujE1+ub5CDYEQl4gG8lX\/kDgEqvKVSzCjVhXWL2VBG41Q0Hs+O5SpTYHkhhKDLEnEopEOAs\/h7NUVAhUHpM1TTYxWp9hL2q\/es6sGIW15hXOv5GarqNL3SI\/aTuIsYP\/wrinBLbe8yjwqpn0TFtMeCa7deuTlWF\/xBXmDfnH\/je+vS6cofeZeKJbCspWZ0upBTi4JARtiQL7bEvjnpVhgApn2iZ0\/Ta0KUmg6dy52W1lsdJn81ACQxUxD8gCdtfqwFtBcvBRbxR1uPCqQEBJo2NWrKqtq1409H7F4WtEbqsJUBHaR4LQAoiz49rw1fW06U5UBmbRUMBT0c+4GD3iRUdhRo6WsoSvld5LbY6bIzSdwcuAZ8jfWTBtY7qqw4i9fd6UlrX4WYTZJOKW80RmgIyPOCiMbA6dZTnGbfcs3LMw==",
  57. "associated_data"=> "transaction",
  58. "nonce"=> "jyvk10O4xN5a"
  59. ];*/
  60. // $cc = new NotifyController();
  61. //$result = $cc->pay('index',$data );
  62. unset($data['s']);
  63. //ksort($data);
  64. $signStr = "1626672721\nOpMHKndhcOTAf0OsuQRGpr80o4WzUHXo\n".json_encode($data)."\n";
  65. var_dump($signStr);
  66. $result = WechatService::checkJsapiNotifyV3($signStr,$json['sign']);
  67. var_dump($result);
  68. return message(1005,'true',['ddd'=> []]);
  69. }
  70. /**
  71. * 支付回调
  72. */
  73. public function pay($scene){
  74. $postData = request()->all();
  75. $sign = request()->headers->get('Wechatpay-Signature');
  76. $nonce = request()->headers->get('Wechatpay-Nonce');
  77. $timestamp = request()->headers->get('Wechatpay-Timestamp');
  78. $body = file_get_contents('php://input');
  79. $signStr = "{$timestamp}\n{$nonce}\n{$body}\n";
  80. $id = isset($postData['id'])? '_'.$postData['id'] : '';
  81. RedisService::set('caches:payments:'.$scene.':result'.$id.'_'.date('YmdHis'), ['result'=> $postData,'sign'=> $sign,'date'=> date('Y-m-d H:i:s')], 7200);
  82. $postData = isset($postData['resource'])? $postData['resource'] : [];
  83. if(empty($scene) || empty($postData)){
  84. return NotifyService::make()->rebackMsg('回调参数错误');
  85. }
  86. // 解密
  87. $ciphertext = isset($postData['ciphertext'])? $postData['ciphertext'] : '';
  88. RedisService::set('caches:payments:'.$scene.':result'.$id.'_ciphertext', ['result'=> $postData,'date'=> date('Y-m-d H:i:s')], 7200);
  89. if(empty($ciphertext)){
  90. return NotifyService::make()->rebackMsg('解密数据不存在');
  91. }
  92. $postData = WechatService::decryptNotifyData($postData);
  93. $postData = $postData? json_decode($postData, true) : [];
  94. // var_dump($postData);
  95. $outTradeNo = isset($postData['out_trade_no']) ? $postData['out_trade_no'] : '';
  96. if(empty($postData) || empty($outTradeNo)){
  97. return NotifyService::make()->rebackMsg('获取解密数据失败');
  98. }
  99. RedisService::set('caches:payments:'.$scene.':result'.$id.'_'.$outTradeNo, ['result'=> $postData], 7200);
  100. RedisService::set('caches:payments:'.$scene.':check'.$id.'_'.$outTradeNo, ['data'=> $postData,'signStr'=> $signStr,'sign'=> $sign], 3600);
  101. if (WechatService::checkJsapiNotifyV3($signStr, $sign, $postData)) {
  102. switch($scene){
  103. case 'index': // 供灯订单
  104. return NotifyService::make()->notifyGongdeng($postData, $outTradeNo);
  105. case 'recharge': // 充值
  106. break;
  107. default:
  108. break;
  109. }
  110. }
  111. return 'fail';
  112. }
  113. }