Pay.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\Config;
  5. use think\Db;
  6. /**
  7. * 会员接口
  8. */
  9. class Pay extends Api
  10. {
  11. protected $noNeedLogin = ['notify'];
  12. protected $noNeedRight = '*';
  13. public function _initialize()
  14. {
  15. parent::_initialize();
  16. if (!Config::get('fastadmin.usercenter')) {
  17. $this->error(__('User center already closed'));
  18. }
  19. }
  20. //二合一支付
  21. public function pay() {
  22. $user_token = input('user_token', '', 'trim');
  23. $diversionfst = input('diversionfst', '', 'trim'); //位置等导流标识
  24. $diversioncsk = input('diversioncsk', '', 'trim'); //内容等导流标识
  25. $trace_id = input('trace_id', '', 'trim'); //大数据推荐内容有trace_id
  26. $contentid = input('contentid', '', 'trim'); //订购媒资的媒资movie_id
  27. if (!$user_token) {
  28. $this->error('参数缺失');
  29. }
  30. //生成支付订单记录
  31. $rechar_order['user_id'] = $this->auth->id;
  32. $rechar_order['order_no'] = date('YmdHis', time()) . $this->auth->id . rand(10000000, 99999999); //微信订单编号
  33. $rechar_order['money'] = 49;
  34. $rechar_order['purpose'] = 3; //充值用途:1=支付订单,2=充值,3=开通会员
  35. $rechar_order['pay_type'] = 'zhuowang';
  36. $rechar_order['relation_id'] = 1;
  37. $rechar_order['createtime'] = time();
  38. //开始事务
  39. $result = Db::name('rechar_order')->insertGetId($rechar_order);
  40. if (!$result) {
  41. $this->error('网络延迟,请稍后再试');
  42. }
  43. $url = 'http://' . config('pay_ip') . '/HDC/3.0/hop/svc/pay/toPay.ajax';
  44. $data = [
  45. 'transId' => $rechar_order['order_no'],
  46. 'orderNo' => $rechar_order['order_no'],
  47. 'userToken' => $user_token,
  48. 'notifyUrl' => config('img_url') . '/api/pay/notify',
  49. 'backUrl' => config('back_url'),
  50. 'deskCode' => config('desk_code'),
  51. 'products' => [
  52. [
  53. 'productCode' => config('product_code'),
  54. 'productPrice' => '29',
  55. 'productUnit' => '个',
  56. 'productCount' => 1
  57. ],
  58. /*[
  59. 'productCode' => '005912cp0028',
  60. 'productPrice' => '0',
  61. 'productUnit' => '7天体验',
  62. 'productCount' => 1
  63. ],*/
  64. [
  65. 'productCode' => '005912cp0004',
  66. 'productPrice' => '0',
  67. 'productUnit' => '30天体验',
  68. 'productCount' => 1
  69. ],
  70. [
  71. 'productCode' => '0002112cp0030',
  72. 'productPrice' => '0',
  73. 'productUnit' => '90天体验',
  74. 'productCount' => 1
  75. ],
  76. [
  77. 'productCode' => '005911cp0022',
  78. 'productPrice' => '199',
  79. 'productUnit' => '年度特惠',
  80. 'productCount' => 1
  81. ],
  82. [
  83. 'productCode' => '005912cp0051',
  84. 'productPrice' => '119',
  85. 'productUnit' => '半年特惠',
  86. 'productCount' => 1
  87. ],
  88. [
  89. 'productCode' => '005912cp0052',
  90. 'productPrice' => '59',
  91. 'productUnit' => '季度特惠',
  92. 'productCount' => 1
  93. ],
  94. [
  95. 'productCode' => '005912cp0044',
  96. 'productPrice' => '20',
  97. 'productUnit' => '咪咕叠加包',
  98. 'productCount' => 1
  99. ],
  100. [
  101. 'productCode' => '005912cp0047',
  102. 'productPrice' => '30',
  103. 'productUnit' => '咪咕叠加包',
  104. 'productCount' => 1
  105. ],
  106. [
  107. 'productCode' => '0002112cp0031',
  108. 'productPrice' => '39',
  109. 'productUnit' => '畅享会员',
  110. 'productCount' => 1
  111. ],
  112. [
  113. 'productCode' => '005912cp0035',
  114. 'productPrice' => '20',
  115. 'productUnit' => '两年特惠',
  116. 'productCount' => 1
  117. ],
  118. [
  119. 'productCode' => '005912cp0043',
  120. 'productPrice' => '20',
  121. 'productUnit' => '两年折扣',
  122. 'productCount' => 1
  123. ],
  124. /*[
  125. 'productCode' => '005912cp0034',
  126. 'productPrice' => '468',
  127. 'productUnit' => '两年特惠',
  128. 'productCount' => 1
  129. ],*/
  130. [
  131. 'productCode' => '005912cp0046',
  132. 'productPrice' => '49',
  133. 'productUnit' => '连续包月',
  134. 'productCount' => 1
  135. ],
  136. /*[
  137. 'productCode' => '005912cp0039',
  138. 'productPrice' => '12',
  139. 'productUnit' => '一日会员',
  140. 'productCount' => 1
  141. ],*/
  142. [
  143. 'productCode' => '0002112cp0031T1',
  144. 'productPrice' => '1',
  145. 'productUnit' => '畅享折扣',
  146. 'productCount' => 1
  147. ],
  148. [
  149. 'productCode' => '0002112cp0031T9',
  150. 'productPrice' => '9',
  151. 'productUnit' => '畅享折扣',
  152. 'productCount' => 1
  153. ],
  154. [
  155. 'productCode' => '0002112cp0031T19',
  156. 'productPrice' => '19',
  157. 'productUnit' => '畅享折扣',
  158. 'productCount' => 1
  159. ],
  160. [
  161. 'productCode' => '0002112cp0029',
  162. 'productPrice' => '29',
  163. 'productUnit' => '限时特惠',
  164. 'productCount' => 1
  165. ],
  166. [
  167. 'productCode' => '005912cp0002',
  168. 'productPrice' => '35',
  169. 'productUnit' => '畅享特惠',
  170. 'productCount' => 1
  171. ],
  172. /*[
  173. 'productCode' => '0002112cp0031Z39',
  174. 'productPrice' => '39',
  175. 'productUnit' => '畅享会员',
  176. 'productCount' => 1
  177. ],*/
  178. /*[
  179. 'productCode' => '005912cp0040',
  180. 'productPrice' => '39',
  181. 'productUnit' => '月包会员',
  182. 'productCount' => 1
  183. ],*/
  184. [
  185. 'productCode' => '005912cp0036',
  186. 'productPrice' => '105',
  187. 'productUnit' => '连续包季',
  188. 'productCount' => 1
  189. ],
  190. [
  191. 'productCode' => '005912cp0021',
  192. 'productPrice' => '299',
  193. 'productUnit' => '连续包年',
  194. 'productCount' => 1
  195. ],
  196. [
  197. 'productCode' => '005912cp0012',
  198. 'productPrice' => '365',
  199. 'productUnit' => '连续包年',
  200. 'productCount' => 1
  201. ],
  202. [
  203. 'productCode' => '005912cp0037',
  204. 'productPrice' => '59',
  205. 'productUnit' => '30天会员',
  206. 'productCount' => 1
  207. ],
  208. [
  209. 'productCode' => '005911cp0001',
  210. 'productPrice' => '111',
  211. 'productUnit' => '季度会员',
  212. 'productCount' => 1
  213. ],
  214. [
  215. 'productCode' => '005911cp0005',
  216. 'productPrice' => '209',
  217. 'productUnit' => '半年会员',
  218. 'productCount' => 1
  219. ],
  220. [
  221. 'productCode' => '005911cp0002',
  222. 'productPrice' => '399',
  223. 'productUnit' => '年度会员',
  224. 'productCount' => 1
  225. ],
  226. /*[
  227. 'productCode' => '008888cp0004',
  228. 'productPrice' => '399',
  229. 'productUnit' => '线下年包',
  230. 'productCount' => 1
  231. ],*/
  232. /*[
  233. 'productCode' => '2400000560_YRHY',
  234. 'productPrice' => '5',
  235. 'productUnit' => '一日会员',
  236. 'productCount' => 1
  237. ],*/
  238. /*[
  239. 'productCode' => '005912cp0017',
  240. 'productPrice' => '39',
  241. 'productUnit' => '手柄',
  242. 'productCount' => 1
  243. ],*/
  244. /*[
  245. 'productCode' => '2000012947_ZY',
  246. 'productPrice' => '39',
  247. 'productUnit' => '手柄',
  248. 'productCount' => 1
  249. ],*/
  250. /*[
  251. 'productCode' => '005912cp0066',
  252. 'productPrice' => '499',
  253. 'productUnit' => '年度会员',
  254. 'productCount' => 1
  255. ],
  256. [
  257. 'productCode' => '005912cp0067',
  258. 'productPrice' => '998',
  259. 'productUnit' => '两年会员',
  260. 'productCount' => 1
  261. ],*/
  262. ],
  263. 'diversionCode' => config('product_code')
  264. ];
  265. if ($diversionfst) {
  266. $data['diversionFST'] = 'SC::' . $diversionfst;
  267. }
  268. if ($diversioncsk) {
  269. $data['diversionCSK'] = '::' . $diversioncsk;
  270. }
  271. if ($trace_id) {
  272. $data['trace_id'] = $trace_id;
  273. }
  274. if ($contentid) {
  275. $data['contentid'] = $contentid;
  276. }
  277. $data = json_encode($data, 320);
  278. //获取鉴权token
  279. $sign_bytes = '/3.0/hop/svc/pay/toPay.ajax' . $this->base16_encode(md5($data));
  280. $hdc_token = hash_hmac('sha256', $sign_bytes, base64_decode(config('pay_appkey')), false);
  281. $header = [
  282. 'Host:' . config('pay_ip'),
  283. 'HDC-Service:2',
  284. 'HDC-APPID:' . config('pay_appid'),
  285. 'HDC-Token:' . $hdc_token,
  286. 'Content-Type:application/json'
  287. ];
  288. $rs = httpRequest($url, 'POST', $data, $header);
  289. if (!$rs) {
  290. $this->error('您的网络开小差了~');
  291. }
  292. $rs = json_decode($rs, true);
  293. if ($rs['resultCode'] != 0) {
  294. $this->error('您的网络开小差了~');
  295. }
  296. $this->success('链接', $rs['data']);
  297. }
  298. //SDK二合一支付
  299. public function paysdk() {
  300. $user_token = input('user_token', '', 'trim');
  301. $diversionfst = input('diversionfst', '', 'trim'); //位置等导流标识
  302. $diversioncsk = input('diversioncsk', '', 'trim'); //内容等导流标识
  303. $trace_id = input('trace_id', '', 'trim'); //大数据推荐内容有trace_id
  304. $contentid = input('contentid', '', 'trim'); //订购媒资的媒资movie_id
  305. if (!$user_token) {
  306. $this->error('参数缺失');
  307. }
  308. //生成支付订单记录
  309. $rechar_order['user_id'] = $this->auth->id;
  310. $rechar_order['order_no'] = date('YmdHis', time()) . $this->auth->id . rand(10000000, 99999999); //微信订单编号
  311. $rechar_order['money'] = 49;
  312. $rechar_order['purpose'] = 3; //充值用途:1=支付订单,2=充值,3=开通会员
  313. $rechar_order['pay_type'] = 'zhuowang';
  314. $rechar_order['relation_id'] = 1;
  315. $rechar_order['createtime'] = time();
  316. //开始事务
  317. $result = Db::name('rechar_order')->insertGetId($rechar_order);
  318. if (!$result) {
  319. $this->error('网络延迟,请稍后再试');
  320. }
  321. $url = 'http://' . config('pay_ip') . '/HDC/3.0/hop/svc/pay/toPay.ajax';
  322. $data = [
  323. 'transId' => $rechar_order['order_no'],
  324. 'orderNo' => $rechar_order['order_no'],
  325. 'userToken' => $user_token,
  326. 'notifyUrl' => config('img_url') . '/api/pay/notify',
  327. 'backUrl' => config('back_url'),
  328. 'deskCode' => config('desk_code'),
  329. 'products' => [
  330. [
  331. 'productCode' => config('product_code'),
  332. 'productPrice' => '29',
  333. 'productUnit' => '个',
  334. 'productCount' => 1
  335. ],
  336. /*[
  337. 'productCode' => '005912cp0028',
  338. 'productPrice' => '0',
  339. 'productUnit' => '7天体验',
  340. 'productCount' => 1
  341. ],*/
  342. [
  343. 'productCode' => '005912cp0004',
  344. 'productPrice' => '0',
  345. 'productUnit' => '30天体验',
  346. 'productCount' => 1
  347. ],
  348. [
  349. 'productCode' => '0002112cp0030',
  350. 'productPrice' => '0',
  351. 'productUnit' => '90天体验',
  352. 'productCount' => 1
  353. ],
  354. [
  355. 'productCode' => '005911cp0022',
  356. 'productPrice' => '199',
  357. 'productUnit' => '年度特惠',
  358. 'productCount' => 1
  359. ],
  360. [
  361. 'productCode' => '005912cp0051',
  362. 'productPrice' => '119',
  363. 'productUnit' => '半年特惠',
  364. 'productCount' => 1
  365. ],
  366. [
  367. 'productCode' => '005912cp0052',
  368. 'productPrice' => '59',
  369. 'productUnit' => '季度特惠',
  370. 'productCount' => 1
  371. ],
  372. [
  373. 'productCode' => '005912cp0044',
  374. 'productPrice' => '20',
  375. 'productUnit' => '咪咕叠加包',
  376. 'productCount' => 1
  377. ],
  378. [
  379. 'productCode' => '005912cp0047',
  380. 'productPrice' => '30',
  381. 'productUnit' => '咪咕叠加包',
  382. 'productCount' => 1
  383. ],
  384. [
  385. 'productCode' => '0002112cp0031',
  386. 'productPrice' => '39',
  387. 'productUnit' => '畅享会员',
  388. 'productCount' => 1
  389. ],
  390. [
  391. 'productCode' => '005912cp0035',
  392. 'productPrice' => '20',
  393. 'productUnit' => '两年特惠',
  394. 'productCount' => 1
  395. ],
  396. [
  397. 'productCode' => '005912cp0043',
  398. 'productPrice' => '20',
  399. 'productUnit' => '两年折扣',
  400. 'productCount' => 1
  401. ],
  402. /*[
  403. 'productCode' => '005912cp0034',
  404. 'productPrice' => '468',
  405. 'productUnit' => '两年特惠',
  406. 'productCount' => 1
  407. ],*/
  408. [
  409. 'productCode' => '005912cp0046',
  410. 'productPrice' => '49',
  411. 'productUnit' => '连续包月',
  412. 'productCount' => 1
  413. ],
  414. /*[
  415. 'productCode' => '005912cp0039',
  416. 'productPrice' => '12',
  417. 'productUnit' => '一日会员',
  418. 'productCount' => 1
  419. ],*/
  420. [
  421. 'productCode' => '0002112cp0031T1',
  422. 'productPrice' => '1',
  423. 'productUnit' => '畅享折扣',
  424. 'productCount' => 1
  425. ],
  426. [
  427. 'productCode' => '0002112cp0031T9',
  428. 'productPrice' => '9',
  429. 'productUnit' => '畅享折扣',
  430. 'productCount' => 1
  431. ],
  432. [
  433. 'productCode' => '0002112cp0031T19',
  434. 'productPrice' => '19',
  435. 'productUnit' => '畅享折扣',
  436. 'productCount' => 1
  437. ],
  438. [
  439. 'productCode' => '0002112cp0029',
  440. 'productPrice' => '29',
  441. 'productUnit' => '限时特惠',
  442. 'productCount' => 1
  443. ],
  444. [
  445. 'productCode' => '005912cp0002',
  446. 'productPrice' => '35',
  447. 'productUnit' => '畅享特惠',
  448. 'productCount' => 1
  449. ],
  450. /*[
  451. 'productCode' => '0002112cp0031Z39',
  452. 'productPrice' => '39',
  453. 'productUnit' => '畅享会员',
  454. 'productCount' => 1
  455. ],*/
  456. /*[
  457. 'productCode' => '005912cp0040',
  458. 'productPrice' => '39',
  459. 'productUnit' => '月包会员',
  460. 'productCount' => 1
  461. ],*/
  462. [
  463. 'productCode' => '005912cp0036',
  464. 'productPrice' => '105',
  465. 'productUnit' => '连续包季',
  466. 'productCount' => 1
  467. ],
  468. [
  469. 'productCode' => '005912cp0021',
  470. 'productPrice' => '299',
  471. 'productUnit' => '连续包年',
  472. 'productCount' => 1
  473. ],
  474. [
  475. 'productCode' => '005912cp0012',
  476. 'productPrice' => '365',
  477. 'productUnit' => '连续包年',
  478. 'productCount' => 1
  479. ],
  480. [
  481. 'productCode' => '005912cp0037',
  482. 'productPrice' => '59',
  483. 'productUnit' => '30天会员',
  484. 'productCount' => 1
  485. ],
  486. [
  487. 'productCode' => '005911cp0001',
  488. 'productPrice' => '111',
  489. 'productUnit' => '季度会员',
  490. 'productCount' => 1
  491. ],
  492. [
  493. 'productCode' => '005911cp0005',
  494. 'productPrice' => '209',
  495. 'productUnit' => '半年会员',
  496. 'productCount' => 1
  497. ],
  498. [
  499. 'productCode' => '005911cp0002',
  500. 'productPrice' => '399',
  501. 'productUnit' => '年度会员',
  502. 'productCount' => 1
  503. ],
  504. /*[
  505. 'productCode' => '008888cp0004',
  506. 'productPrice' => '399',
  507. 'productUnit' => '线下年包',
  508. 'productCount' => 1
  509. ],*/
  510. /*[
  511. 'productCode' => '2400000560_YRHY',
  512. 'productPrice' => '5',
  513. 'productUnit' => '一日会员',
  514. 'productCount' => 1
  515. ],*/
  516. /*[
  517. 'productCode' => '005912cp0017',
  518. 'productPrice' => '39',
  519. 'productUnit' => '手柄',
  520. 'productCount' => 1
  521. ],*/
  522. /*[
  523. 'productCode' => '2000012947_ZY',
  524. 'productPrice' => '39',
  525. 'productUnit' => '手柄',
  526. 'productCount' => 1
  527. ],*/
  528. /*[
  529. 'productCode' => '005912cp0066',
  530. 'productPrice' => '499',
  531. 'productUnit' => '年度会员',
  532. 'productCount' => 1
  533. ],
  534. [
  535. 'productCode' => '005912cp0067',
  536. 'productPrice' => '998',
  537. 'productUnit' => '两年会员',
  538. 'productCount' => 1
  539. ],*/
  540. ],
  541. 'diversionCode' => config('product_code')
  542. ];
  543. if ($diversionfst) {
  544. $data['diversionFST'] = 'SC::' . $diversionfst;
  545. }
  546. if ($diversioncsk) {
  547. $data['diversionCSK'] = '::' . $diversioncsk;
  548. }
  549. if ($trace_id) {
  550. $data['trace_id'] = $trace_id;
  551. }
  552. if ($contentid) {
  553. $data['contentid'] = $contentid;
  554. }
  555. $data = json_encode($data, 320);
  556. //获取鉴权token
  557. $sign_bytes = '/3.0/hop/svc/pay/toPay.ajax' . $this->base16_encode(md5($data));
  558. $hdc_token = hash_hmac('sha256', $sign_bytes, base64_decode(config('pay_appkey')), false);
  559. $header = [
  560. 'Host:' . config('pay_ip'),
  561. 'HDC-Service:2',
  562. 'HDC-APPID:' . config('pay_appid'),
  563. 'HDC-Token:' . $hdc_token,
  564. 'Content-Type:application/json'
  565. ];
  566. $return_data['url'] = $url;
  567. $return_data['data'] = $data;
  568. $return_data['host'] = config('pay_ip');
  569. $return_data['appid'] = config('pay_appid');
  570. $return_data['token'] = $hdc_token;
  571. /*$rs = httpRequest($url, 'POST', $data, $header);
  572. if (!$rs) {
  573. $this->error('您的网络开小差了~');
  574. }
  575. $rs = json_decode($rs, true);
  576. if ($rs['resultCode'] != 0) {
  577. $this->error('您的网络开小差了~');
  578. }*/
  579. $this->success('参数', $return_data);
  580. }
  581. //支付回调
  582. public function notify() {
  583. $data = file_get_contents('php://input');
  584. if (!$data) {
  585. $this->error('参数缺失');
  586. }
  587. $data = json_decode($data, true);
  588. if (!$data) {
  589. $this->error('参数缺失');
  590. }
  591. if ($data['orderstate'] != 0) {
  592. echo json_encode([
  593. 'transid' => $data['transid'],
  594. 'orderid' => $data['orderid'],
  595. 'statuscode' => -1,
  596. 'statusdesc' => '订单状态失败'
  597. ], 320);
  598. die;
  599. }
  600. $order_no = $data['orderid'];
  601. $where['order_no'] = $order_no;
  602. $order_info = Db::name('rechar_order')->where($where)->find();
  603. if (!$order_info) {
  604. echo json_encode([
  605. 'transid' => $data['transid'],
  606. 'orderid' => $data['orderid'],
  607. 'statuscode' => -1,
  608. 'statusdesc' => '业务订单不存在'
  609. ], 320);
  610. die;
  611. }
  612. if ($order_info['status'] == 1) { //已回调成功
  613. echo json_encode([
  614. 'transid' => $data['transid'],
  615. 'orderid' => $data['orderid'],
  616. 'statuscode' => 0,
  617. 'statusdesc' => ''
  618. ], 320);
  619. die;
  620. }
  621. //构建支付订单处理结果信息
  622. $_data['status'] = 1;
  623. $_data['updatetime'] = time();
  624. if ($order_info['purpose'] == 3) {
  625. //开通会员
  626. Db::startTrans();
  627. //充值
  628. $rs = Db::name('user')->where(['id' => $order_info['user_id']])->setField('is_vip', 1);
  629. if ($rs === false) {
  630. Db::rollback();
  631. $_data['pay_status'] = 3; //回调状态:1=支付订单回调失败,2=充值回调失败,3=开通会员回调失败
  632. } else {
  633. Db::commit();
  634. }
  635. }
  636. //修改订单信息
  637. Db::name('rechar_order')->where($where)->setField($_data);
  638. echo json_encode([
  639. 'transid' => $data['transid'],
  640. 'orderid' => $data['orderid'],
  641. 'statuscode' => 0,
  642. 'statusdesc' => ''
  643. ], 320);
  644. }
  645. }