Pay.php 95 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300
  1. <?php
  2. namespace app\api\controller\v1;
  3. use AlibabaCloud\Client\Request\RoaRequest;
  4. use app\api\services\AliPayServices;
  5. use app\api\services\ThirdPayServices;
  6. use app\api\services\WxPayServices;
  7. use app\common\model\PaymentModel;
  8. use app\common\model\ShopGoodsModel;
  9. use app\common\model\ShopOrderGoodsModel as OrderGoods;
  10. use app\common\model\ShopOrderModel;
  11. use app\common\model\UserModel;
  12. use app\model\UserDataModel;
  13. use app\model\VipOrderModel;
  14. use app\Request;
  15. use app\services\balancePayServices;
  16. use app\services\OfflinePayServices;
  17. use jobs\VipOrderJob;
  18. use services\CacheServices;
  19. use think\db\Where;
  20. use think\Exception;
  21. use think\facade\Db;
  22. use utils\AES;
  23. use utils\WBAes;
  24. use function Composer\Autoload\includeFile;
  25. class Pay
  26. {
  27. // 之前对接的支付备份
  28. private function payOldAction(Request $request){
  29. $setting = [];
  30. $appresource = $request->post('app_sources', '');
  31. $order_type = $request->post('order_type');
  32. // if (empty($order_type) || empty($appresource)){
  33. if (empty($order_type)){
  34. return api_error_return('参数错误');
  35. }
  36. // 畅联H5支付宝支付 已经废了
  37. // array_push($setting, ['is_open'=>1,'channel'=>8, 'title'=>'支付宝h5支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  38. // 畅联A版支付宝支付
  39. // array_push($setting, ['is_open'=>1,'channel'=>10, 'title'=>'支付宝A版支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  40. // 实名
  41. // if ($order_type == 2){
  42. //
  43. //// if ($appresource != 'ios'){
  44. //// 畅联微信支付
  45. // array_push($setting, ['channel'=>7, 'title'=>'微信支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_wechat_pay.png']);
  46. //// }
  47. //
  48. //// if ($appresource != 'ios'){
  49. // if ($request->uid == 7512635){
  50. // // 支付宝原生支付
  51. // array_push($setting, ['channel'=>2, 'title'=>'支付宝', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  52. ////
  53. // }
  54. //
  55. // }
  56. // 汇付支付宝支付
  57. // array_push($setting, ['is_open'=>1,'channel'=>14, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  58. // 无卡快捷支付 银盛直联
  59. // array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  60. // 石区支付宝支付
  61. array_push($setting, ['is_open'=>1,'channel'=>22, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  62. // 商城购买
  63. if ($order_type == 4){
  64. // mo宝富友银联支付
  65. // array_push($setting, ['is_open'=>1,'channel'=>9, 'title'=>'银联支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  66. // 提示苹果 无法使用无效
  67. // 畅联D版支付宝支付
  68. // array_push($setting, ['is_open'=>1,'channel'=>11, 'title'=>'支付宝D版支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  69. //// if ($appresource == 'ios'){
  70. //// if ($request->uid == 7503399){
  71. //// }
  72. //// }
  73. // 易票联 支付宝支付
  74. // if (in_array($request->uid, [7493487, 7493666,7494925,7523024])){
  75. // array_push($setting, ['is_open'=>1,'channel'=>12, 'title'=>'支付宝', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  76. // }
  77. // array_push($setting, ['is_open'=>1,'channel'=>78, 'title'=>'支付宝', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  78. // 畅联微信支付
  79. // array_push($setting, ['is_open'=>1,'channel'=>7, 'title'=>'微信支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_wechat_pay.png']);
  80. // if ($appresource != 'ios'){
  81. // if (in_array($request->uid, [7493487,7493666])){
  82. //云闪付
  83. // array_push($setting, ['is_open'=>1,'channel'=>13, 'title'=>'云闪付', 'icon'=>getWebUrl().'/static/img/payconfig/ysf.png']);
  84. // }
  85. // }
  86. if ($appresource == 'android'){
  87. // 余额支付
  88. // array_push($setting, ['is_open'=>1,'channel'=>3, 'title'=>'余额支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yue_mkjw.png']);
  89. // 石区长微信支付
  90. // array_push($setting, ['is_open'=>1,'channel'=>17, 'title'=>'微信支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_wechat_pay.png']);
  91. // 石区支付宝支付
  92. // array_push($setting, ['is_open'=>1,'channel'=>16, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  93. // 石学长 银联支付
  94. array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联(协议绑卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  95. // 银联快捷
  96. // array_push($setting, ['is_open'=>1,'channel'=>18, 'title'=>'银联快捷', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  97. // 无卡快捷支付 银盛直联
  98. // array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  99. }
  100. if ($appresource == 'ios'){
  101. // 余额支付
  102. // array_push($setting, ['is_open'=>1,'channel'=>3, 'title'=>'余额支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yue_mkjw.png']);
  103. // 石区长微信支付
  104. // array_push($setting, ['is_open'=>1,'channel'=>17, 'title'=>'微信支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_wechat_pay.png']);
  105. // 石区支付宝支付
  106. // array_push($setting, ['is_open'=>1,'channel'=>16, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  107. // 石学长 银联支付
  108. array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  109. // 银联快捷
  110. // array_push($setting, ['is_open'=>1,'channel'=>18, 'title'=>'银联快捷', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  111. // 无卡快捷支付
  112. // array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  113. }
  114. // array_push($setting, ['is_open'=>2,'channel'=>99, 'title'=>'数字资产支付', 'icon'=>getWebUrl().'/static/img/payconfig/shuzi.png']);
  115. }
  116. // 余额充值
  117. // {
  118. // if ($order_type == 5){
  119. //
  120. //
  121. // if ($appresource == 'android'){
  122. //
  123. // // 余额支付
  124. //// array_push($setting, ['is_open'=>1,'channel'=>3, 'title'=>'余额支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yue_mkjw.png']);
  125. //
  126. // // 石区长微信支付
  127. //// array_push($setting, ['is_open'=>1,'channel'=>17, 'title'=>'微信支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_wechat_pay.png']);
  128. //
  129. // // 石区支付宝支付
  130. //// array_push($setting, ['is_open'=>1,'channel'=>16, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  131. //
  132. // // 石学长 银联支付
  133. // array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  134. //
  135. // // 银联快捷
  136. //// array_push($setting, ['is_open'=>1,'channel'=>18, 'title'=>'银联快捷', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  137. //
  138. // // 无卡快捷支付
  139. // array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  140. //
  141. // // usdt
  142. //// array_push($setting, ['is_open'=>1,'channel'=>19, 'title'=>'USDT转账', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  143. // }
  144. //
  145. // if ($appresource == 'ios'){
  146. //
  147. // // 石区支付宝支付
  148. //// array_push($setting, ['is_open'=>1,'channel'=>16, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  149. //
  150. // // 石学长 银联支付
  151. // array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联(协议绑卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  152. //
  153. // // 银联快捷 首信易
  154. //// array_push($setting, ['is_open'=>1,'channel'=>18, 'title'=>'银联快捷', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  155. //
  156. // // 无卡快捷支付
  157. // array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  158. //
  159. // // usdt
  160. //// array_push($setting, ['is_open'=>1,'channel'=>19, 'title'=>'USDT转账', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  161. //
  162. // }
  163. //
  164. //
  165. //
  166. //
  167. //
  168. //// array_push($setting, ['is_open'=>2,'channel'=>99, 'title'=>'数字资产支付', 'icon'=>getWebUrl().'/static/img/payconfig/shuzi.png']);
  169. //
  170. //
  171. // }
  172. // }
  173. // 购买服务商
  174. if ($order_type == 6){
  175. // mo宝富友银联支付
  176. // array_push($setting, ['is_open'=>1,'channel'=>9, 'title'=>'银联支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  177. // 提示苹果 无法使用无效
  178. // 畅联D版支付宝支付
  179. // array_push($setting, ['is_open'=>1,'channel'=>11, 'title'=>'支付宝D版支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  180. //// if ($appresource == 'ios'){
  181. //// if ($request->uid == 7503399){
  182. //// }
  183. //// }
  184. // 易票联 支付宝支付
  185. // if (in_array($request->uid, [7493487, 7493666,7494925,7523024])){
  186. // array_push($setting, ['is_open'=>1,'channel'=>12, 'title'=>'支付宝', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  187. // }
  188. // array_push($setting, ['is_open'=>1,'channel'=>78, 'title'=>'支付宝', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  189. // 畅联微信支付
  190. // array_push($setting, ['is_open'=>1,'channel'=>7, 'title'=>'微信支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_wechat_pay.png']);
  191. // if ($appresource != 'ios'){
  192. // if (in_array($request->uid, [7493487,7493666])){
  193. //云闪付
  194. // array_push($setting, ['is_open'=>1,'channel'=>13, 'title'=>'云闪付', 'icon'=>getWebUrl().'/static/img/payconfig/ysf.png']);
  195. // }
  196. // }
  197. // 汇付支付宝支付
  198. // array_push($setting, ['is_open'=>1,'channel'=>14, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  199. if ($appresource == 'android'){
  200. // 余额支付
  201. // array_push($setting, ['is_open'=>1,'channel'=>3, 'title'=>'余额支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yue_mkjw.png']);
  202. // 石区长微信支付
  203. // array_push($setting, ['is_open'=>1,'channel'=>17, 'title'=>'微信支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_wechat_pay.png']);
  204. // 石区支付宝支付
  205. // array_push($setting, ['is_open'=>1,'channel'=>16, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  206. // 石学长 银联支付
  207. array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联(协议绑卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  208. // 银联快捷
  209. // array_push($setting, ['is_open'=>1,'channel'=>18, 'title'=>'银联快捷', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  210. // 无卡快捷支付 直连银盛
  211. array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  212. }
  213. if ($appresource == 'ios'){
  214. // 余额支付
  215. // array_push($setting, ['is_open'=>1,'channel'=>3, 'title'=>'余额支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yue_mkjw.png']);
  216. // 石区长微信支付
  217. // array_push($setting, ['is_open'=>1,'channel'=>17, 'title'=>'微信支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_wechat_pay.png']);
  218. // 石区支付宝支付
  219. // array_push($setting, ['is_open'=>1,'channel'=>16, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  220. // 石学长 银联支付
  221. array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联(协议绑卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  222. // 银联快捷
  223. // array_push($setting, ['is_open'=>1,'channel'=>18, 'title'=>'银联快捷', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  224. // 无卡快捷支付
  225. array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  226. }
  227. // array_push($setting, ['is_open'=>2,'channel'=>99, 'title'=>'数字资产支付', 'icon'=>getWebUrl().'/static/img/payconfig/shuzi.png']);
  228. }
  229. }
  230. // 支付方式配置
  231. public function payconfig(Request $request){
  232. $setting = [];
  233. $appresource = $request->post('app_sources', '');
  234. $order_type = $request->post('order_type');
  235. // if (empty($order_type) || empty($appresource)){
  236. if (empty($order_type)){
  237. return api_error_return('参数错误');
  238. }
  239. // 石区长 支付宝支付
  240. array_push($setting, ['is_open'=>1,'channel'=>22, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  241. // 石区长 广汇商(微宝富支付 支付宝)
  242. array_push($setting, ['is_open'=>1,'channel'=>57, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  243. // 石区长 广汇商(直连支付宝)
  244. array_push($setting, ['is_open'=>1,'channel'=>58, 'title'=>'支付宝支付', 'icon'=>getWebUrl().'/static/img/payconfig/ic_zhifubao.png']);
  245. // 商城购买
  246. if ($order_type == 4){
  247. if ($appresource == 'android'){
  248. // 石学长 银联支付
  249. array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  250. }
  251. if ($appresource == 'ios'){
  252. // 石学长 银联支付
  253. array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  254. }
  255. }
  256. // 购买服务商
  257. if ($order_type == 6){
  258. if ($appresource == 'android'){
  259. // 石学长 银联支付
  260. array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  261. // 无卡快捷支付 直连银盛
  262. // array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  263. }
  264. if ($appresource == 'ios'){
  265. // 石学长 银联支付
  266. array_push($setting, ['is_open'=>1,'channel'=>15, 'title'=>'银联', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  267. // 无卡快捷支付
  268. // array_push($setting, ['is_open'=>1,'channel'=>20, 'title'=>'无卡快捷银联支付(支持信用卡)', 'icon'=>getWebUrl().'/static/img/payconfig/ic_yinlian_pay.png']);
  269. }
  270. // array_push($setting, ['is_open'=>2,'channel'=>99, 'title'=>'数字资产支付', 'icon'=>getWebUrl().'/static/img/payconfig/shuzi.png']);
  271. }
  272. // 余额支付
  273. return api_succ_return(['msg'=>'成功', 'data'=>['setting'=>$setting]]);
  274. }
  275. // 生成支付订单
  276. public function paymentInfo(Request $request)
  277. {
  278. // 这是测试 上线要干掉
  279. // return api_error_return('暂未开放');
  280. $post = $request->post();
  281. $user = $request->user_info;
  282. $curandroid = env('app.CUR_ANDROID_VERSION', '');
  283. $curios = env('app.CUR_IOS_VERSION', '');;
  284. $curAndroidVersion = str_replace('.', '', $curandroid);
  285. $curAndroidVersion = dispRepair($curAndroidVersion, 4, '0', '0');
  286. $curIosVersion = str_replace('.', '', $curios);
  287. $curIosVersion = dispRepair($curIosVersion, 4, '0', '0');
  288. $app_sources = $request->param('app_sources');
  289. $app_version = $request->param('app_version');
  290. $app_version = str_replace('.', '', $app_version);
  291. $app_version = dispRepair($app_version, 4, '0', '0');
  292. if ($app_sources == 'ios'){
  293. if ($curIosVersion > $app_version){
  294. return api_error_return('app版本号过低,请更新');
  295. }
  296. }
  297. if ($app_sources == 'android'){
  298. if ($curAndroidVersion > $app_version){
  299. return api_error_return('app版本号过低,请更新');
  300. }
  301. }
  302. if (empty($app_sources) || empty($app_version)){
  303. if ($curAndroidVersion > $app_version){
  304. return api_error_return('app版本号过低,请更新');
  305. }
  306. }
  307. if ($post['order_type'] == 6){
  308. if ($user['store_type'] == 1){
  309. return api_error_return('已是服务商,无需再次开通');
  310. }
  311. }
  312. try {
  313. $channel = $request->data['channel']; // 支付方式 1 支付宝支付 2 微信支付 3 余额 4 线下
  314. // if (!in_array($channel, [2, 5, 6, 7, 8, 9, 10, 11, 12, 78])) {
  315. if (!in_array($channel, [14, 15, 20, 22, 57, 58])) {
  316. return api_error_return('支付类型错误');
  317. }
  318. $order_type = $request->data['order_type']; // 订单类型
  319. // if (!in_array($order_type, [2, 4])) {
  320. // return api_error_return('订单类型错误');
  321. // }
  322. // if (intval($order_type) == 4){
  323. // if (!in_array(intval($channel), $pay_timearr)){
  324. // return api_error_return('订单类型错误');
  325. // }
  326. // }
  327. if ($post['order_type'] == 4) {
  328. if (empty($post['order_id'])) {
  329. return api_error_return('参数错误');
  330. }
  331. $m_order = new ShopOrderModel();
  332. $orderinfo = $m_order->where('order_sn', $post['order_id'])->find();
  333. if ($orderinfo['status'] != 0) {
  334. return api_error_return('状态错误');
  335. }
  336. $count = Db::name('payment')->where('uid', $request->uid)->where('order_type', 4)->where('state', 7)->whereTime('creat_at', '-2 hours')->count('id');
  337. // 这是测试 线要干掉
  338. if ($count > 20){
  339. return api_error_return('未支付订单过多');
  340. }
  341. }
  342. // if (strpos($request->user['path'], '5344240') || intval($request->user['id']) == 5344240){
  343. // return api_error_return('失败,请联系客服');
  344. // }
  345. switch ($channel) {
  346. case 1:
  347. return WxPayServices::instance()->userId($request->uid)->data($request->data)->getUnifiedOrder();
  348. break;
  349. case 2:
  350. // 支付宝支付
  351. $result = AliPayServices::instance()->uid($request->uid)->data($request->data)->getUnifiedOrder();
  352. break;
  353. case 3:
  354. getActionSecury($request->uid, $request->post('security_pass', ''));
  355. $ser = new \app\api\services\BalancePayServices();
  356. $ser->balanceToOrder($request->uid, $request->post('order_id', ''));
  357. $result = api_succ_return(['msg'=>'成功', 'data'=>[]]);
  358. break;
  359. // case 4:
  360. //// return OfflinePayServices::instance()->uid($request->uid)->data($request->data)->getUnifiedOrder();
  361. // break;
  362. // case 5:
  363. // // 多乐宝贝 支付支付
  364. // {
  365. // $pay = new ThirdPayServices();
  366. // $result = $pay->getPayInfo($request->uid, $request->data);
  367. // }
  368. // break;
  369. // case 6:
  370. //// 第三方支付 微信支付
  371. //// 多乐宝 微信支付
  372. // {
  373. // $pay = new ThirdPayServices();
  374. // $result = $pay->getWxPayInfo($request->uid, $request->data);
  375. // }
  376. // break;
  377. // case 7:
  378. //// 第三方支付 畅联 微信支付
  379. // {
  380. // $pay = new ThirdPayServices();
  381. // $result = $pay->getWxPayInfoCL($request->uid, $request->data);
  382. // }
  383. // break;
  384. // case 8:
  385. //// 第三方支付 畅联 支付宝支付
  386. // {
  387. // $pay = new ThirdPayServices();
  388. // $result = $pay->getAliPayInfoCL($request->uid, $request->data, 'h5ban');
  389. // }
  390. // break;
  391. // case 9:
  392. //// 第三方支付 mo宝 富有 银联支付
  393. // {
  394. // $pay = new ThirdPayServices();
  395. // $params = $request->data;
  396. // $params['app_sources'] = $request->post('app_sources', 'ios');
  397. // $result = $pay->getBankPayInfoFY($request->uid, $params);
  398. //
  399. // }
  400. // break;
  401. // case 10:
  402. //// 第三方支付 畅联 A版支付宝支付
  403. // {
  404. // $pay = new ThirdPayServices();
  405. // $result = $pay->getAliPayInfoCL($request->uid, $request->data, 'aban');
  406. // }
  407. // break;
  408. // case 11:
  409. //// 第三方支付 畅联 D版支付宝支付
  410. // {
  411. // $pay = new ThirdPayServices();
  412. // $result = $pay->getAliPayInfoCL($request->uid, $request->data, 'dban');
  413. // }
  414. // break;
  415. // case 12:
  416. //// 第三方支付 易票联支付宝支付
  417. // {
  418. // $pay = new ThirdPayServices();
  419. // $result = $pay->getZfbPayInfoYPL($request->uid, $request->data);
  420. // }
  421. // break;
  422. // case 13:
  423. //// 第三方支付 易票联云闪付
  424. // {
  425. // sr_throw('支付失败');
  426. // $pay = new ThirdPayServices();
  427. // $result = $pay->getYsfPayInfoYPL($request->uid, $request->data);
  428. // }
  429. // break;
  430. case 14:
  431. //// 第三方支付 汇付支付支付
  432. {
  433. $pay = new ThirdPayServices();
  434. $result = $pay->getHfPayInfoHF($request->uid, $request->data);
  435. }
  436. break;
  437. case 15:
  438. // 第三方支付 石区长
  439. {
  440. $pay = new ThirdPayServices();
  441. $result = $pay->getPayInfoSQZ($request->uid, $request->data);
  442. }
  443. break;
  444. case 16:
  445. // 第三方支付 支付宝 石区长
  446. {
  447. $pay = new ThirdPayServices();
  448. $result = $pay->getPayInfoSQZAlipay($request->uid, $request->data);
  449. }
  450. break;
  451. case 17:
  452. // 第三方支付 微信 石区长
  453. {
  454. $pay = new ThirdPayServices();
  455. $result = $pay->getPayInfoSQZWechat($request->uid, $request->data);
  456. }
  457. break;
  458. case 18:
  459. // 第三方支付 银联快捷 石区长 首信易
  460. {
  461. $pay = new ThirdPayServices();
  462. $result = $pay->getPayInfoSQZBankkuai($request->uid, $request->data);
  463. }
  464. break;
  465. case 19:
  466. // 第三方支付 usdt充值
  467. {
  468. $pay = new ThirdPayServices();
  469. $result = $pay->getPayInfoUsdt($request->uid, $request->data);
  470. }
  471. break;
  472. case 20:
  473. // 直连银盛 无卡快捷
  474. {
  475. $pay = new ThirdPayServices();
  476. $result = $pay->getPayInfoYSwk($request->uid, $request->data);
  477. // $result = $pay->kjPayWithCode($request->uid, $request->data);
  478. }
  479. break;
  480. case 22:
  481. // 支付宝 电科科技支付
  482. {
  483. $pay = new ThirdPayServices();
  484. $result = $pay->getPayInfoDiankeZfb($request->uid, $request->data);
  485. // $result = $pay->kjPayWithCode($request->uid, $request->data);
  486. }
  487. break;
  488. case 56:
  489. // 第三方支付 易票联统一支付
  490. {
  491. $pay = new ThirdPayServices();
  492. $result = $pay->getYsfPayInfoTY($request->uid, $request->data);
  493. }
  494. break;
  495. case 57:
  496. // 广汇商(微宝富支付 支付宝)
  497. {
  498. $pay = new ThirdPayServices();
  499. $result = $pay->getPayWeiBaoAli($request->uid, $request->data);
  500. }
  501. break;
  502. case 58:
  503. // 广汇商(直连支付宝)
  504. {
  505. $pay = new ThirdPayServices();
  506. $result = $pay->getPayZhiLianAli($request->uid, $request->data);
  507. }
  508. break;
  509. }
  510. // if (intval($channel) > 55){
  511. // $pay = new ThirdPayServices();
  512. // $result = $pay->getZfbPayInfoYPL($request->uid, $request->data);
  513. // }
  514. } catch (Exception $e) {
  515. // sr_log('payment'. $e->getMessage());
  516. return api_error_return($e->getMessage());
  517. }
  518. return $result;
  519. }
  520. public function zlysSurePay(Request $request){
  521. $post = $request->post();
  522. if (empty($post['trade_no']) || empty($post['sms_code'])){
  523. return api_error_return('参数错误');
  524. }
  525. Db::startTrans();
  526. try {
  527. $ser = new ThirdPayServices();
  528. $res = $ser->kjPayWithCode($post['trade_no'], $post['sms_code']);
  529. Db::commit();
  530. }catch (\Exception $e){
  531. Db::rollback();
  532. return api_error_return($e->getMessage());
  533. }
  534. return $res;
  535. }
  536. // 直连银盛 银行卡列表
  537. public function zlysBankList(Request $request){
  538. $where = array();
  539. $post = $request->post();
  540. $keyword = $post['keyword'];
  541. if (!empty($keyword)){
  542. $where[] = ['bank_name|bank_sub', 'like', "%{$keyword}%"];
  543. }
  544. $where[] = ['status', '=', "1"];
  545. $list = Db::name('ys_banklist')->where($where)->page($post['page'], $post['limit'])->order('id asc')->select()->toArray();
  546. return api_succ_return(['msg'=>'成功', 'data'=>$list]);
  547. }
  548. public function zlysBankPayWay(Request $request){
  549. return api_succ_return(['msg'=>'成功', 'data'=>[
  550. ['bank_name'=>'工商银行','xiane'=>'单笔1万、单日1万、单月5万' ,'jieji'=>'是','xinyong'=>'是'],
  551. ['bank_name'=>'中国银行','xiane'=>'单笔5万,单日5万' ,'jieji'=>'否','xinyong'=>'是'],
  552. ['bank_name'=>'建设银行','xiane'=>'单笔1万、单日1万、单月5万' ,'jieji'=>'是','xinyong'=>'是'],
  553. ['bank_name'=>'招商银行','xiane'=>'单笔5万,单日5万' ,'jieji'=>'否','xinyong'=>'是'],
  554. ['bank_name'=>'光大银行','xiane'=>'单笔0.5万、单日5万 ' ,'jieji'=>'是','xinyong'=>'是'],
  555. ['bank_name'=>'民生银行','xiane'=>'2万/2万' ,'jieji'=>'是','xinyong'=>'是'],
  556. ['bank_name'=>'浦发银行','xiane'=>'借单笔/日2万、贷单笔/日1万、月不限' ,'jieji'=>'是','xinyong'=>'是'],
  557. ['bank_name'=>'平安银行','xiane'=>'单笔5万、单日5万、月不限' ,'jieji'=>'是','xinyong'=>'否'],
  558. ['bank_name'=>'广发银行','xiane'=>'贷记卡(单笔3w,单日3w)、借记卡(单笔2w,单日2w)' ,'jieji'=>'是','xinyong'=>'是'],
  559. ['bank_name'=>'中信银行','xiane'=>'单笔5万、日/月不限' ,'jieji'=>'是','xinyong'=>'是'],
  560. ['bank_name'=>'交通银行','xiane'=>'单笔2万,单日2万,单月5万' ,'jieji'=>'否','xinyong'=>'是'],
  561. ['bank_name'=>'渤海银行','xiane'=>'借单笔3w,单日3w;贷单笔2w,单日2w' ,'jieji'=>'是','xinyong'=>'是'],
  562. ['bank_name'=>'上海银行','xiane'=>'借单笔1w单日1万;贷单笔2w,日不限' ,'jieji'=>'是','xinyong'=>'是'],
  563. ['bank_name'=>'华夏银行','xiane'=>'日累计2万,月累计60万' ,'jieji'=>'是','xinyong'=>'否'],
  564. ['bank_name'=>'邮储银行','xiane'=>'借记卡:无限额,以发卡测为准;贷记卡:单笔2万、单日2万','jieji'=>'是','xinyong'=>'是'],
  565. ['bank_name'=>'浙商银行','xiane'=>'单笔2万、单日2万' ,'jieji'=>'是','xinyong'=>'是'],
  566. ['bank_name'=>'区域银行','xiane'=>'无' ,'jieji'=>'是','xinyong'=>'是']]
  567. ]);
  568. }
  569. /**
  570. * 支付宝支付回调
  571. * @param Request $request
  572. * @return mixed
  573. */
  574. public function aliResult(Request $request)
  575. {
  576. // sr_log(json_encode($request->param()));
  577. return AliPayServices::instance()->data($request->param())->getNotifyInfo()->afterPay();
  578. }
  579. /**
  580. * 支付宝支付回调 多来贝
  581. * @param Request $request
  582. * @return mixed
  583. */
  584. public function aliResultDLB(Request $request){
  585. sr_log('----------------------支付三方回调-------------------------');
  586. sr_log($request);
  587. sr_log($request->param());
  588. sr_log('----------------------支付三方回调-------------------------');
  589. // DLB1649854201945040279940469OP
  590. $result = [
  591. 'order_id' => 'DLB1649854201945040279940469OP'
  592. ];
  593. // 897d9ea909093173b24dd89c772181e4
  594. // if (!$result || !$result->sign){
  595. // echo 'success';
  596. // die();
  597. // }
  598. // $sign = thirdPayGetSign($result, '897d9ea909093173b24dd89c772181e4');
  599. // if ($result['sign'] != $sign){
  600. // echo 'success';
  601. // die();
  602. // }
  603. $pay_info= Db::name('payment')->where('out_trade_no', $result['order_id'])->find();
  604. if (!$pay_info){
  605. echo 'success';
  606. die();
  607. }else{
  608. if ($pay_info['state'] != 7){
  609. echo 'success';
  610. die();
  611. }
  612. Db::startTrans();
  613. try {
  614. Db::name('payment')->where('id', $pay_info['id'])->update(['state' => 6, 'pay_at' => date('Y-m-d H:i:s')]); // 更改订单状态
  615. switch ($pay_info['order_type']) {
  616. case 1: // 充值
  617. break;
  618. case 3:
  619. // 充值会员
  620. //
  621. break;
  622. case 4: //购买商品
  623. // $order = Order::where(['order_sn' => explode(',', $pay_info['remarks'])])->select()->toArray();
  624. // Order::payDoneOrderCallback($order, 3, $pay_info['uid']);
  625. $m_goods = new ShopGoodsModel();
  626. $m_user = new UserModel();
  627. $m_shoporder = new ShopOrderModel();
  628. // 更改订单状态
  629. $order = ShopOrderModel::where('order_sn', $pay_info['remarks'])->find();
  630. $nowTime = date('Y-m-d H:i:s', time());
  631. Db::name('shop_order')->where(['order_sn' => $pay_info['remarks']])
  632. ->update(['pay_type' => 2, 'status' => 1, 'updated_time' => $nowTime]);
  633. // 增加销量
  634. $orderGoods = OrderGoods::where(['order_id' => $order['order_id']])->select()->toArray();
  635. foreach ($orderGoods as $k => $v) {
  636. ShopGoodsModel::where(['goods_id' => $v['goods_id']])->inc('sales_volume', $v['num'])->inc('real_sales_volume', $v['num'])->update();
  637. }
  638. // 送积分
  639. edit_user_score(5, $order['user_id'], $order['rebate_score']);
  640. edit_user_redscore(1, $order['user_id'], $order['rebate_lock_score']);
  641. break;
  642. }
  643. Db::commit();
  644. echo 'success';
  645. die;
  646. } catch (\Exception $e) {
  647. Db::rollback();
  648. echo 'failure';
  649. die;
  650. }
  651. }
  652. echo 'success';
  653. die();
  654. }
  655. /**
  656. * 微信支付回调 多来贝
  657. * @param Request $request
  658. * @return mixed
  659. */
  660. public function wechatResultDLB(Request $request){
  661. sr_log('----------------------支付三方回调-------------------------');
  662. sr_log(json_encode($request->param()));
  663. sr_log('----------------------支付三方回调-------------------------');
  664. $result = $request->param();
  665. // {"body":"\u8d2d\u4e70\u5546\u54c1","order_no":"DLB1649940431291160101494681OP","external_order_no":"35054704392204140847101649940430","channel_order_no":"22041420471399027444900","total_amount":"0.01","pay_amount":"0.01","status":"1","note":"","pay_time":"1649940443","sign":"A836A4214BE26C145DF55C0F1F1ACDAB"}
  666. // {
  667. // "body": "购买商品",
  668. // "order_no": "DLB1649939394489656266205439OP",
  669. // "external_order_no": "55936444392204140829541649939394",
  670. // "channel_order_no": "22041420300550260054535",
  671. // "total_amount": "0.01",
  672. // "pay_amount": "0.01",
  673. // "status": "1",
  674. // "note": "",
  675. // "pay_time": "1649939414",
  676. // "sign": "7614744071B389F19388E681DD02A353"
  677. // }
  678. // 897d9ea909093173b24dd89c772181e4
  679. // sr_log('开始回调');
  680. try {
  681. if (!$result || !$result['sign']){
  682. sr_log('11111');
  683. echo 'success';
  684. die();
  685. }
  686. $sign = thirdPayGetSign($result, '897d9ea909093173b24dd89c772181e4');
  687. if ($result['sign'] != $sign){
  688. sr_log('222222');
  689. echo 'success';
  690. die();
  691. }
  692. if ($result['status'] != 1){
  693. sr_log('33333333');
  694. echo 'success';
  695. die();
  696. }
  697. }catch (Exception $e){
  698. echo 'success';
  699. sr_log('aaa'.$e->getMessage());
  700. die();
  701. }
  702. $pay_info= Db::name('payment')->where('out_trade_no', $result['order_no'])->find();
  703. if (!$pay_info){
  704. sr_log('333333333');
  705. echo 'success';
  706. die();
  707. }else{
  708. if ($pay_info['state'] != 7){
  709. sr_log('8888'.'已经处理过了');
  710. echo 'success';
  711. die();
  712. }
  713. if ($result['total_amount'] < $pay_info['total_fee']){
  714. sr_testDb(json_encode($pay_info), 1);
  715. sr_log('9999'.'支付金额错误');
  716. echo 'success';
  717. die();
  718. }
  719. Db::startTrans();
  720. try {
  721. Db::name('payment')->where('id', $pay_info['id'])->update(['state' => 6, 'pay_at' => date('Y-m-d H:i:s')]); // 更改订单状态
  722. switch ($pay_info['order_type']) {
  723. case 1: // 充值
  724. break;
  725. case 3:
  726. // 充值会员
  727. //
  728. break;
  729. case 4: //购买商品
  730. // $order = Order::where(['order_sn' => explode(',', $pay_info['remarks'])])->select()->toArray();
  731. // Order::payDoneOrderCallback($order, 3, $pay_info['uid']);
  732. $m_goods = new ShopGoodsModel();
  733. $m_user = new UserModel();
  734. $m_shoporder = new ShopOrderModel();
  735. // 更改订单状态
  736. $order = ShopOrderModel::where('order_sn', $pay_info['remarks'])->find();
  737. $nowTime = date('Y-m-d H:i:s', time());
  738. Db::name('shop_order')->where(['order_sn' => $pay_info['remarks']])
  739. ->update(['pay_type' => 2, 'status' => 1, 'updated_time' => $nowTime]);
  740. // 增加销量
  741. $orderGoods = OrderGoods::where(['order_id' => $order['order_id']])->select()->toArray();
  742. foreach ($orderGoods as $k => $v) {
  743. ShopGoodsModel::where(['goods_id' => $v['goods_id']])->inc('sales_volume', $v['num'])->inc('real_sales_volume', $v['num'])->update();
  744. }
  745. // 送积分
  746. edit_user_score(5, $order['user_id'], $order['rebate_score']);
  747. edit_user_redscore(1, $order['user_id'], $order['rebate_lock_score']);
  748. break;
  749. }
  750. Db::commit();
  751. echo 'success';
  752. die;
  753. } catch (\Exception $e) {
  754. Db::rollback();
  755. echo 'failure';
  756. sr_log('微信多乐宝报错:'. $e->getMessage());
  757. die;
  758. }
  759. }
  760. echo 'success';
  761. die();
  762. }
  763. /**
  764. * 微信支付回调 畅联
  765. * @param Request $request
  766. * @return mixed
  767. */
  768. public function wechatResultCL(Request $request){
  769. sr_log('----------------------支付三方回调-------------------------');
  770. sr_log(json_encode($request->param()));
  771. sr_log('----------------------支付三方回调-------------------------');
  772. $result = $request->param();
  773. // {
  774. // "callbacks": "CODE_SUCCESS",
  775. // "appid": "1059174",
  776. // "pay_type": "wechat",
  777. // "success_url": "http:\/\/www.baidu.com",
  778. // "error_url": "http:\/\/www.baidu.com",
  779. // "out_trade_no": "90898975872204150713401650021220",
  780. // "amount": "0.02",
  781. // "sign": "3F63CCE3522D487BEEDBDCA97B306C86"
  782. //}
  783. // "amount": "609",
  784. try {
  785. if (!$result || !$result['sign']){
  786. sr_log('cl11111');
  787. echo 'success';
  788. die();
  789. }
  790. $sign = thirdPayCheckSignCL($result, 'XMLfjHMPOGexsSaadIWSVCNG0XJBClZZ');
  791. if ($result['sign'] != $sign){
  792. sr_log('cl222222');
  793. echo 'success';
  794. die();
  795. }
  796. if ($result['callbacks'] != 'CODE_SUCCESS'){
  797. sr_log('cl33333333');
  798. echo 'success';
  799. die();
  800. }
  801. }catch (Exception $e){
  802. echo 'success';
  803. sr_log('claaa'.$e->getMessage());
  804. die();
  805. }
  806. $pay_info= Db::name('payment')->where('out_trade_no', $result['out_trade_no'])->find();
  807. if (!$pay_info){
  808. sr_log('cl333333333');
  809. echo 'success';
  810. die();
  811. }else{
  812. if ($pay_info['state'] != 7){
  813. sr_log('cl8888'.'已经处理过了');
  814. echo 'success';
  815. die();
  816. }
  817. if ($result['amount'] < $pay_info['total_fee']){
  818. sr_testDb(json_encode($pay_info), 1);
  819. sr_log('cl9999'.'支付金额错误');
  820. echo 'success';
  821. die();
  822. }
  823. Db::startTrans();
  824. try {
  825. $pay_info= Db::name('payment')->where('out_trade_no', $result['out_trade_no'])->lock(true)->find();
  826. Db::name("thirdpay_back")->insert([
  827. 'out_order_no'=>$result['out_trade_no'],
  828. 'content'=>json_encode($result),
  829. 'create_time'=>sr_getcurtime(time()),
  830. 'type'=>1,
  831. 'uid'=>$pay_info['uid']
  832. ]);
  833. if (empty($pay_info)) {
  834. throw new Exception('畅联并发了');
  835. }
  836. Db::name('payment')->where('id', $pay_info['id'])->update(['state' => 6, 'pay_at' => date('Y-m-d H:i:s')]); // 更改订单状态
  837. switch ($pay_info['order_type']) {
  838. case 1: // 充值
  839. break;
  840. case 3:
  841. // 充值会员
  842. //
  843. break;
  844. case 4: //购买商品
  845. // $order = Order::where(['order_sn' => explode(',', $pay_info['remarks'])])->select()->toArray();
  846. // Order::payDoneOrderCallback($order, 3, $pay_info['uid']);
  847. $m_goods = new ShopGoodsModel();
  848. $m_user = new UserModel();
  849. $m_shoporder = new ShopOrderModel();
  850. // 更改订单状态
  851. $order = ShopOrderModel::where('order_sn', $pay_info['remarks'])->find();
  852. $nowTime = date('Y-m-d H:i:s', time());
  853. Db::name('shop_order')->where(['order_sn' => $pay_info['remarks']])
  854. ->update(['status' => 1, 'pay_type'=>7,'updated_time' => $nowTime]);
  855. // 增加销量
  856. $orderGoods = OrderGoods::where(['order_id' => $order['order_id']])->select()->toArray();
  857. foreach ($orderGoods as $k => $v) {
  858. ShopGoodsModel::where(['goods_id' => $v['goods_id']])->inc('sales_volume', $v['num'])->inc('real_sales_volume', $v['num'])->update();
  859. }
  860. $user = $m_user->where('id', $pay_info['uid'])->find();
  861. // if ($user['pid'] > 0){
  862. // if (Db::name('user')->where('id', $user['pid'])->where('is_auth', 1)->find()){
  863. // edit_user_score(15, $user['pid'], number_format($pay_info['total_fee']/100, 4, '.', ''));
  864. // }
  865. //
  866. // }
  867. // 送积分
  868. edit_user_score(5, $order['user_id'], $order['rebate_score']);
  869. edit_user_redscore(1, $order['user_id'], $order['rebate_lock_score']);
  870. break;
  871. }
  872. Db::commit();
  873. } catch (\Exception $e) {
  874. Db::rollback();
  875. sr_log('cl微信报错:'. $e->getMessage());
  876. echo 'failure';
  877. die;
  878. }
  879. echo 'success';
  880. die();
  881. }
  882. echo 'success';
  883. die();
  884. }
  885. /**
  886. * 支付宝支付回调 畅联
  887. * @param Request $request
  888. * @return mixed
  889. */
  890. public function AliResultCL(Request $request){
  891. sr_log('----------------------支付三方回调-------------------------');
  892. sr_log(json_encode($request->param()));
  893. sr_log('----------------------支付三方回调-------------------------');
  894. $result = $request->param();
  895. // {
  896. // "callbacks": "CODE_SUCCESS",
  897. // "appid": "1059174",
  898. // "pay_type": "wechat",
  899. // "success_url": "http:\/\/www.baidu.com",
  900. // "error_url": "http:\/\/www.baidu.com",
  901. // "out_trade_no": "90898975872204150713401650021220",
  902. // "amount": "0.02",
  903. // "sign": "3F63CCE3522D487BEEDBDCA97B306C86"
  904. //}
  905. // "amount": "609",
  906. // try {
  907. // if (!$result || !$result['sign']){
  908. // sr_log('cl11111');
  909. // echo 'success';
  910. // die();
  911. // }
  912. // $sign = thirdPayCheckSignCL($result, 'XMLfjHMPOGexsSaadIWSVCNG0XJBClZZ');
  913. // if ($result['sign'] != $sign){
  914. // sr_log('cl222222');
  915. // echo 'success';
  916. // die();
  917. // }
  918. //
  919. // if ($result['callbacks'] != 'CODE_SUCCESS'){
  920. // sr_log('cl33333333');
  921. // echo 'success';
  922. // die();
  923. // }
  924. //
  925. // }catch (Exception $e){
  926. // echo 'success';
  927. // sr_log('claaa'.$e->getMessage());
  928. // die();
  929. // }
  930. $pay_info= Db::name('payment')->where('out_trade_no', $result['out_trade_no'])->find();
  931. if (!$pay_info){
  932. sr_log('cl333333333');
  933. echo 'success';
  934. die();
  935. }else{
  936. if ($pay_info['state'] != 7){
  937. sr_log('cl8888'.'已经处理过了');
  938. echo 'success';
  939. die();
  940. }
  941. if ($result['amount'] < $pay_info['total_fee']){
  942. sr_testDb(json_encode($pay_info), 1);
  943. sr_log('cl9999'.'支付金额错误');
  944. echo 'success';
  945. die();
  946. }
  947. $key = 'api'.$request->pathinfo().$result['out_trade_no'];
  948. Db::startTrans();
  949. try {
  950. redisLock($key);
  951. $pay_info= Db::name('payment')->where('out_trade_no', $result['out_trade_no'])->lock(true)->find();
  952. Db::name("thirdpay_back")->insert([
  953. 'out_order_no'=>$result['out_trade_no'],
  954. 'content'=>json_encode($result),
  955. 'create_time'=>sr_getcurtime(time()),
  956. 'type'=>1,
  957. 'uid'=>$pay_info['uid']
  958. ]);
  959. if (empty($pay_info)) {
  960. throw new Exception('畅联支付宝并发了');
  961. }
  962. Db::name('payment')->where('id', $pay_info['id'])->update(['state' => 6, 'pay_at' => date('Y-m-d H:i:s')]); // 更改订单状态
  963. switch ($pay_info['order_type']) {
  964. case 1: // 充值
  965. break;
  966. case 3:
  967. // 充值会员
  968. //
  969. break;
  970. case 4: //购买商品
  971. // $order = Order::where(['order_sn' => explode(',', $pay_info['remarks'])])->select()->toArray();
  972. // Order::payDoneOrderCallback($order, 3, $pay_info['uid']);
  973. $m_goods = new ShopGoodsModel();
  974. $m_user = new UserModel();
  975. $m_shoporder = new ShopOrderModel();
  976. // 更改订单状态
  977. $order = ShopOrderModel::where('order_sn', $pay_info['remarks'])->find();
  978. $nowTime = date('Y-m-d H:i:s', time());
  979. Db::name('shop_order')->where(['order_sn' => $pay_info['remarks']])
  980. ->update(['status' => 1, 'pay_type'=>8,'updated_time' => $nowTime]);
  981. // 增加销量
  982. $orderGoods = OrderGoods::where(['order_id' => $order['order_id']])->select()->toArray();
  983. foreach ($orderGoods as $k => $v) {
  984. ShopGoodsModel::where(['goods_id' => $v['goods_id']])->inc('sales_volume', $v['num'])->inc('real_sales_volume', $v['num'])->update();
  985. }
  986. $user = $m_user->where('id', $pay_info['uid'])->find();
  987. // if ($user['pid'] > 0){
  988. // if (Db::name('user')->where('id', $user['pid'])->where('is_auth', 1)->find()){
  989. // edit_user_score(15, $user['pid'], number_format($pay_info['total_fee']/100, 4, '.', ''));
  990. // }
  991. //
  992. // }
  993. // 送积分
  994. edit_user_score(5, $order['user_id'], $order['rebate_score']);
  995. edit_user_redscore(1, $order['user_id'], $order['rebate_lock_score']);
  996. break;
  997. }
  998. Db::commit();
  999. } catch (\Exception $e) {
  1000. Db::rollback();
  1001. if ($e->getCode() != apiPingFanCode()){
  1002. redisFree($key);
  1003. }
  1004. sr_log('cl支付宝报错:'. $e->getMessage());
  1005. echo 'failure';
  1006. die;
  1007. }
  1008. redisFree($key);
  1009. echo 'success';
  1010. die();
  1011. }
  1012. echo 'success';
  1013. die();
  1014. }
  1015. /**
  1016. * mo宝银联回调 富友
  1017. * @param Request $request
  1018. * @return mixed
  1019. */
  1020. public function BankResultFY(Request $request){
  1021. $res = file_get_contents('php://input');
  1022. sr_log('----------------------支付三方富有回调-------------------------');
  1023. sr_log($res);
  1024. sr_log('----------------------支付三方富有回调-------------------------');
  1025. // $res = '{"mchnt_cd":"0002900F0096235","message":"Y+s9Pef1211xf3Ibyn+OWwgJPT6byY+8KNlelvpVdiA2FdIAQdaxsZcD0zz/NIt4pQDh0ogyRSh6XlG89XFH6v+YdJe3wMZlbFK//dVHZdpk/jaRbt8dKxIv6ViS/EtQldRKWHQqcrmG8/CHTPweM5+K4GUMmaqRuqYD3+6qFTT7Mt2teDgYkPhPc55epXvrYxJXKEX5tyAyPogDM+Yi6uEXWntMJHaqjM1hIv8/1EfLceCDeNzc8GAM/EllWjUeUoUMvPQ7X3Ay0itv2wS96THh4Iwxk60LWhek+lZaG2EY2spVJmMNSktt/htqwf/LtBpm9FBiJDuJTuOWD4lHqazEHUnwA1kDsLtTSKqqiLJiesanXs5nQ7h3f0Nmu94qCP9vIvm9ZWSXwehPB7kRXp5vWgcjXMzWlNWbHJmLt0myHl/6EesMMAHRCS+Le3o1JVExgFDccI1jcpwUll6GqCmT7G1qRilt30LOhHhDk9IPJRdiRJvqcWP003GLUt9E6Z+PSHuJlCILVWZVlaAVh4Bl2sMCd84exiJVCXZPaXDaCoMHmbbMtaKaWCWn4El6HlC5tONZpdNX5OkDN0FZxxBrDvPr0M3BZgQhHmvQRfPjzLYV3BgT8iIwlT6G2x/lv/7jbk/7JhPRGLtZ09UCuFu3r1hB3pRVXVm/yMaNlZQ=","resp_code":"0000","resp_desc":"交易成功"}';
  1026. $result = json_decode($res);
  1027. if (isset($result->mchnt_cd) && isset($result->message) && isset($result->resp_code) && isset($result->resp_desc)) {
  1028. if ($result->resp_code == 0000) {
  1029. $res_decode = json_decode(RSA_openssl($result->message, 'decode'));
  1030. if (isset($res_decode->order_st) && $res_decode->order_st == 1) {
  1031. $out_trade_no = 'FYYL' . $res_decode->order_id;
  1032. $pay_info = Db::name('payment')->where('out_trade_no', $out_trade_no)->find();
  1033. if ($pay_info) {
  1034. if ($pay_info['state'] == 7) {
  1035. if ($res_decode->order_amt < bcmul($pay_info['total_fee'], 100, 0)) {
  1036. echo 'success';
  1037. die();
  1038. }
  1039. $key = 'api'.$request->pathinfo().$out_trade_no;
  1040. Db::startTrans();
  1041. try {
  1042. redisLock($key);
  1043. $pay_info = Db::name('payment')->where('out_trade_no', $out_trade_no)->lock(true)->find();
  1044. Db::name("thirdpay_back")->insert([
  1045. 'out_order_no' => $out_trade_no,
  1046. 'content' => json_encode($res_decode),
  1047. 'create_time' => sr_getcurtime(time()),
  1048. 'type' => 2,
  1049. 'uid' => $pay_info['uid']
  1050. ]);
  1051. Db::name('payment')->where('id', $pay_info['id'])->update(['state' => 6, 'pay_at' => date('Y-m-d H:i:s')]); // 更改订单状态
  1052. switch ($pay_info['order_type']) {
  1053. case 1: // 充值
  1054. break;
  1055. case 3:
  1056. // 充值会员
  1057. //
  1058. break;
  1059. case 4: //购买商品
  1060. // $order = Order::where(['order_sn' => explode(',', $pay_info['remarks'])])->select()->toArray();
  1061. // Order::payDoneOrderCallback($order, 3, $pay_info['uid']);
  1062. $m_goods = new ShopGoodsModel();
  1063. $m_user = new UserModel();
  1064. $m_shoporder = new ShopOrderModel();
  1065. // 更改订单状态
  1066. $order = ShopOrderModel::where('order_sn', $pay_info['remarks'])->find();
  1067. $nowTime = date('Y-m-d H:i:s', time());
  1068. Db::name('shop_order')->where(['order_sn' => $pay_info['remarks']])
  1069. ->update(['status' => 1, 'pay_type' => 9, 'updated_time' => $nowTime]);
  1070. // 增加销量
  1071. $orderGoods = OrderGoods::where(['order_id' => $order['order_id']])->select()->toArray();
  1072. foreach ($orderGoods as $k => $v) {
  1073. ShopGoodsModel::where(['goods_id' => $v['goods_id']])->inc('sales_volume', $v['num'])->inc('real_sales_volume', $v['num'])->update();
  1074. }
  1075. $user = $m_user->where('id', $pay_info['uid'])->find();
  1076. // if ($user['pid'] > 0){
  1077. // if (Db::name('user')->where('id', $user['pid'])->where('is_auth', 1)->find()){
  1078. // edit_user_score(15, $user['pid'], number_format($pay_info['total_fee']/100, 4, '.', ''));
  1079. // }
  1080. //
  1081. // }
  1082. // 送积分
  1083. edit_user_score(5, $order['user_id'], $order['rebate_score']);
  1084. edit_user_redscore(1, $order['user_id'], $order['rebate_lock_score']);
  1085. // 释放用户福利积分或者锁定积分到余额
  1086. $sf_money = intval(intval($pay_info['total_fee'])/100) * 5;
  1087. if ($sf_money > 0){
  1088. $is_sf = false;
  1089. if ($user['score_away'] > $sf_money && !$is_sf){
  1090. if ($user['score_away'] <= $sf_money){
  1091. $sf_money = intval($user['score_away']);
  1092. }
  1093. edit_user_score(24, $pay_info['uid'], $sf_money);
  1094. edit_user_scoreaway(8, $pay_info['uid'], $sf_money);
  1095. $is_sf = true;
  1096. }
  1097. if ($user['score_lock'] > $sf_money && !$is_sf){
  1098. edit_user_score(25, $pay_info['uid'], $sf_money);
  1099. edit_user_lock_score(2, $pay_info['uid'], $sf_money);
  1100. $is_sf = true;
  1101. }
  1102. }
  1103. break;
  1104. }
  1105. Db::commit();
  1106. } catch (\Exception $e) {
  1107. Db::rollback();
  1108. if ($e->getCode() != apiPingFanCode()){
  1109. redisFree($key);
  1110. }
  1111. sr_log('fy支付报错:' . $e->getMessage());
  1112. echo 'failure';
  1113. die;
  1114. }
  1115. }
  1116. }
  1117. }
  1118. }
  1119. }
  1120. redisFree($key);
  1121. echo 'success';
  1122. die;
  1123. }
  1124. // 进件审核回调
  1125. public function yplApplyResult(Request $request){
  1126. $res = file_get_contents('php://input');
  1127. sr_log('----------------------ypl审核回调-------------------------');
  1128. sr_log($res);
  1129. sr_log('----------------------ypl审核回调-------------------------');
  1130. echo "0000";
  1131. die();
  1132. }
  1133. public function ZfbResultYPL(Request $request){
  1134. $res = file_get_contents('php://input');
  1135. sr_log('----------------------ypl回调-------------------------');
  1136. sr_log($res);
  1137. sr_log('----------------------ypl回调-------------------------');
  1138. // {"amount":5,"payTime":"20220622201730","transactionNo":"32202206228301997902995","cashAmount":5,"customerCode":"562012003860535","payState":"00","attachData":"attachData","channelOrder":"192022062222001491231433402953","buyerId":"2088612998991235","buyerLogonId":"sun***@163.com","nonceStr":"fba32d45251940f1b4acbfe5112aa7f6","procedureFee":0,"payerInfo":{"cardType":"D","fundChannel":"ALIPAYACCOUNT"},"outTradeNo":"YPL202206212246385110016927164"}
  1139. $res = json_decode($res, true);
  1140. // $res = json_decode('{"amount":5,"payTime":"20220622201730","transactionNo":"32202206228301997902995","cashAmount":5,"customerCode":"562012003860535","payState":"00","attachData":"attachData","channelOrder":"192022062222001491231433402953","buyerId":"2088612998991235","buyerLogonId":"sun***@163.com","nonceStr":"fba32d45251940f1b4acbfe5112aa7f6","procedureFee":0,"payerInfo":{"cardType":"D","fundChannel":"ALIPAYACCOUNT"},"outTradeNo":"YPL202206212246385110016927164"}', true);
  1141. Db::startTrans();
  1142. try {
  1143. if ($res['payState'] != '00'){
  1144. echo "0000";
  1145. die();
  1146. }
  1147. $pay_info= Db::name('payment')->where('out_trade_no', $res['outTradeNo'])->lock(true)->find();
  1148. // if (Db::name('thirdpay_back')->where('out_order_no')->find()){
  1149. // echo "0000";
  1150. // die();
  1151. // }
  1152. Db::name("thirdpay_back")->insert([
  1153. 'out_order_no'=>$res['outTradeNo'],
  1154. 'content'=>json_encode($res),
  1155. 'create_time'=>sr_getcurtime(time()),
  1156. 'type'=>3,
  1157. 'uid'=>$pay_info['uid']
  1158. ]);
  1159. Db::name('payment')->where('id', $pay_info['id'])->update(['state' => 6, 'pay_at' => date('Y-m-d H:i:s')]); // 更改订单状态
  1160. switch ($pay_info['order_type']) {
  1161. case 1: // 充值
  1162. break;
  1163. case 3:
  1164. // 充值会员
  1165. //
  1166. break;
  1167. case 4: //购买商品
  1168. // $order = Order::where(['order_sn' => explode(',', $pay_info['remarks'])])->select()->toArray();
  1169. // Order::payDoneOrderCallback($order, 3, $pay_info['uid']);
  1170. $m_goods = new ShopGoodsModel();
  1171. $m_user = new UserModel();
  1172. $m_shoporder = new ShopOrderModel();
  1173. // 更改订单状态
  1174. $order = ShopOrderModel::where('order_sn', $pay_info['remarks'])->find();
  1175. $nowTime = date('Y-m-d H:i:s', time());
  1176. Db::name('shop_order')->where(['order_sn' => $pay_info['remarks']])
  1177. ->update(['status' => 1, 'pay_type'=>8,'updated_time' => $nowTime]);
  1178. // 增加销量
  1179. $orderGoods = OrderGoods::where(['order_id' => $order['order_id']])->select()->toArray();
  1180. foreach ($orderGoods as $k => $v) {
  1181. ShopGoodsModel::where(['goods_id' => $v['goods_id']])->inc('sales_volume', $v['num'])->inc('real_sales_volume', $v['num'])->update();
  1182. }
  1183. $user = $m_user->where('id', $pay_info['uid'])->find();
  1184. // if ($user['pid'] > 0){
  1185. // if (Db::name('user')->where('id', $user['pid'])->where('is_auth', 1)->find()){
  1186. // edit_user_score(15, $user['pid'], number_format($pay_info['total_fee']/100, 4, '.', ''));
  1187. // }
  1188. //
  1189. // }
  1190. // 送积分
  1191. edit_user_score(5, $order['user_id'], $order['rebate_score']);
  1192. edit_user_redscore(1, $order['user_id'], $order['rebate_lock_score']);
  1193. // 释放用户福利积分或者锁定积分到余额
  1194. $sf_money = intval(intval($pay_info['total_fee'])/100) * 5;
  1195. if ($sf_money > 0){
  1196. $is_sf = false;
  1197. if ($user['score_away'] > $sf_money && !$is_sf){
  1198. if ($user['score_away'] <= $sf_money){
  1199. $sf_money = intval($user['score_away']);
  1200. }
  1201. edit_user_score(24, $pay_info['uid'], $sf_money);
  1202. edit_user_scoreaway(8, $pay_info['uid'], $sf_money);
  1203. $is_sf = true;
  1204. }
  1205. if ($user['score_lock'] > $sf_money && !$is_sf){
  1206. edit_user_score(25, $pay_info['uid'], $sf_money);
  1207. edit_user_lock_score(2, $pay_info['uid'], $sf_money);
  1208. $is_sf = true;
  1209. }
  1210. }
  1211. break;
  1212. }
  1213. Db::commit();
  1214. } catch (\Exception $e) {
  1215. Db::rollback();
  1216. sr_log('ypl报错:'. $e->getMessage());
  1217. echo "0000";
  1218. die();
  1219. }
  1220. echo "0000";
  1221. die();
  1222. }
  1223. public function ZfbResultHF(Request $request){
  1224. /**
  1225. * 判断支付异步回调业务处理
  1226. * User: shuaishuai.niu
  1227. * Date: 2020/11/16
  1228. * Time: 14:01
  1229. */
  1230. // $res = file_get_contents('php://input');
  1231. // $post_data = json_decode($_POST['data'],1);
  1232. sr_log('----------------------汇付回调-------------------------');
  1233. sr_log($_POST['data']);
  1234. sr_log('----------------------汇付回调-------------------------');
  1235. $params = $_POST['data'];
  1236. # 加载SDK需要的文件
  1237. include_once "../extend/thirdpay/AdapaySdk/init.php";
  1238. # 加载商户的配置文件
  1239. include_once "../extend/thirdpay/config.php";
  1240. $adapay_tools = new \AdaPaySdk\AdapayTools();
  1241. # POST 接收的数据的key
  1242. # create_time, data, prod_mode, sign, id, type,app_id
  1243. # array(
  1244. # 'app_id' => 'app_fe1ec54d-e7cd-432a-a994-c12c3d8295f8',
  1245. # 'created_time' => '20201115182858',
  1246. # 'end_time' => '20201115182904',
  1247. # 'expend' => [
  1248. # 'bank_type' => 'OTHERS',
  1249. # 'open_id' => '1123213123123',
  1250. # 'sub_open_id'=> '36323333333'
  1251. # ],
  1252. # 'id' => '002112020111518285710173995928213929984',
  1253. # 'order_no' => 'SH20201115182857625624',
  1254. # 'out_trans_id' => '4200000839202011155051561044',
  1255. # 'party_order_id' => '02212011156653808201465',
  1256. # 'pay_amt' => '02212011156653808201465',
  1257. # 'pay_channel' => '02212011156653808201465',
  1258. # 'status' => 'succeeded'
  1259. # )
  1260. $post_data = json_decode($_POST['data'],1);
  1261. // $post_data = json_decode('{"app_id":"app_4f8d1f05-bcfd-4e9e-b093-b60c43036f2d","created_time":"1662776991","description":"\u8d2d\u4e70\u5546\u54c1","expend":{"pay_info":"https:\/\/qr.alipay.com\/bax04520xxibramp0fkm30ac"},"id":"002112022091010295110414500898441043968","object":"payment","order_no":"HFPAY202209101029485308739531608","party_order_id":"02212209103779136200665","pay_amt":"0.19","pay_channel":"alipay","prod_mode":"true","query_url":"https:\/\/api.adapay.tech\/v1\/expire\/payments\/1\/fae1cfb9d8fd3b44cf5645dab40603a4","status":"succeeded"}', true);
  1262. $post_data_str = json_encode($post_data,JSON_UNESCAPED_UNICODE);
  1263. $post_sign_str = isset($_POST['sign']) ? $_POST['sign']: '';
  1264. // 此处只是个示例 需要测试请去掉注释
  1265. //$post_data_str = "{\"app_id\":\"app_fe1ec54d-e7cd-432a-a994-c12c3d8295f8\",\"created_time\":\"20201115182858\",\"end_time\":\"20201115182904\",\"expend\":{\"bank_type\":\"OTHERS\",\"open_id\":\"o8jhotwaUEffs1fyWE5O3N4HWvbk\",\"sub_open_id\":\"o4WGIxA59TYBzEKdwz_s6actNIYY\"},\"id\":\"002112020111518285710173995928213929984\",\"order_no\":\"SH20201115182857625624\",\"out_trans_id\":\"4200000839202011155051561044\",\"party_order_id\":\"02212011156653808201465\",\"pay_amt\":\"0.01\",\"pay_channel\":\"wx_pub\",\"status\":\"succeeded\"}";
  1266. //
  1267. //$sign_flag = $adapay_tools->verifySign($post_data_str,"YXOWP5pyL38cZvXbVTyr4Lp9tpr2IzYmc5+EXuNofMTPPlCMfgXX4aBHT8QhxmKMYe95TBklWrM6IAdSLqIBXyc7CYnEYh0o54QHH4H\/yKy5yiOqFCbcHAHPhtJPU28rj+dHbG7YG\/4Qk5psFoBuOTP99ACizLy\/uiILYY3UhJk=");
  1268. # 先校验签名和返回的数据的签名的数据是否一致
  1269. $sign_flag = $adapay_tools->verifySign($post_data_str, $post_sign_str);
  1270. // sr_log('汇付支付宝回调:'.json_encode($post_data));
  1271. // sr_log('$post_data_str:'.$post_data_str);
  1272. if ($sign_flag){
  1273. // sr_log("签名验证通过");
  1274. # 业务方自己的逻辑
  1275. // $res = {"app_id":"app_4f8d1f05-bcfd-4e9e-b093-b60c43036f2d","created_time":"1662713634","description":"\u8d2d\u4e70\u5546\u54c1","expend":{"pay_info":"https:\/\/qr.alipay.com\/bax08139bwvehcew1b3t30c8"},"id":"002112022090916535410414235160744284160","object":"payment","order_no":"HFPAY20220909165205254560022948","party_order_id":"02212209096083454601956","pay_amt":"0.19","pay_channel":"alipay","prod_mode":"true","query_url":"https:\/\/api.adapay.tech\/v1\/expire\/payments\/1\/380d6a9c3aa72e53eeb65e04ec062043","status":"succeeded"}
  1276. Db::startTrans();
  1277. try {
  1278. if ($post_data['status'] != 'succeeded'){
  1279. sr_throw('成功1');
  1280. }
  1281. $pay_info= Db::name('payment')->where('out_trade_no', $post_data['order_no'])->lock(true)->find();
  1282. if ($pay_info['state'] != 7){
  1283. sr_throw('成功1');
  1284. }
  1285. $service = new ThirdPayServices();
  1286. $service->payBack($post_data['order_no'], 0, 14, json_encode($params));
  1287. Db::commit();
  1288. }
  1289. catch (\Exception $e) {
  1290. Db::rollback();
  1291. sr_log('汇付支付宝回调报错:'. $e->getMessage());
  1292. return api_succ_return('成功2'.$e->getMessage());
  1293. die();
  1294. }
  1295. return api_succ_return('成功');
  1296. die();
  1297. }else{
  1298. sr_log('签名不通过:['.$post_sign_str.']'.'post_data_str--['.$post_data_str.']');
  1299. return api_succ_return('成功1');
  1300. die();
  1301. }
  1302. }
  1303. /**
  1304. * 微信支付回调
  1305. * @param Request $request
  1306. * @return mixed
  1307. */
  1308. public function wxResult(Request $request)
  1309. {
  1310. file_put_contents('/www/wwwroot/lxzn.lebogyl.com/wechat.txt', var_export(file_get_contents('php://input'), true) . '--------' . date('H:i:s') . PHP_EOL, FILE_APPEND);
  1311. file_put_contents('/www/wwwroot/lxzn.lebogyl.com/wechat1.txt', var_export($request->header(), true) . '--------' . date('H:i:s') . PHP_EOL, FILE_APPEND);
  1312. // $data['body'] = '{"id":"d7d3eeff-7dc7-525b-99ea-fe362afc0ce8","create_time":"2022-03-31T21:20:42+08:00","resource_type":"encrypt-resource","event_type":"TRANSACTION.SUCCESS","summary":"支付成功","resource":{"original_type":"transaction","algorithm":"AEAD_AES_256_GCM","ciphertext":"y5G7RcAN27Nc42W/Ciw97A+Ts8SeRx/72EDgdDbr2Jc4zK00rCW4T2h8Fp/ny+9Hefii4EhrwRD4g76QMKW81kA44x9j9/uH/jmjR0wCglnDuwaoePPDACgYpBL1gj+O9zxqtzcvpRTyQtzEpbtxG9aVp3muNVfh52le9qZbtNaDjMJfCjZRj6a4qJ1XHxjwS3AC5I3E5q9n3a2nyhMiEsgiwbTR5m+fUY3FTxE1WGO7DY+xfYoz3GDiGdGi+gsDeLBxX/w3U1ieajUTUCtBlf9XAaa08fAuj05F6/SicntJc9SnRxNGBVqmX7LrWWKI6jpRdmSOHYfUuoz4+e1FzPBAtAY+9BjYcRP+XdRf659YpuWlUuzvTPQ+gdiADPo4Aszt8jHqtYADxLoeO7KwZraVme5oH5RPogiGd/30Pqn6y3PkhDmkpnvYmL9xDYB2PQMxbNeZX9n3mtDE41ZqoYUULPJSGhxc/fAtFrLV/C5Vj/NVPhomQhRBZgQx8myfUA4yRrJF/Xs0oVIbkUknoXacRBm02qaTNmxv+dLv+YrIQ9xt/3KP3VoaHvTqVAkEza65kGDijEyNdRQJYw==","associated_data":"transaction","nonce":"hZrJycCZANaX"}}';
  1313. // $data['header'] =array (
  1314. // 'host' => 'lbktza.lebogyl.com',
  1315. // 'content-length' => '923',
  1316. // 'user-agent' => 'Mozilla/4.0',
  1317. // 'pragma' => 'no-cache',
  1318. // 'wechatpay-timestamp' => '1648733686',
  1319. // 'wechatpay-signature' => 'bkSmqJCBL4PpkhvReywNR1e6RCUfKLJmKpKTp0EkVYWMU6MSOeA8pI4BaKCPHmqene3cr5vM3+I0T9hcr0NpxlWiau87S97L+amCRT6UBpLy6Rzf6+jewMJccJCxN/SnjUXKA08N7gdw5YLFdeW1XMpQDSftBWpAPiVylf2XtrfWvhzq/D/xQINDPMb9HMbWXVRdcj9FKMr3uzGzLnM2SB4OzIXifW5MsYxbuSS1GRjKaSRM0q41e9oAeTegJ6MlY1QN+WuXByhexO64/CWcSthektvoj9RYPNbftGUj0nOQizNPWjIzzJouQmuyJ6uTKOi8VU5t8F3HXEI42RKW1A==',
  1320. // 'connection' => 'Keep-Alive',
  1321. // 'content-type' => 'application/json',
  1322. // 'wechatpay-serial' => '3266CA67E9DE559412849E0E65845FC22BABA399',
  1323. // 'wechatpay-nonce' => 'XGjZGY2a0zqxYecblrRAX8N3ASFuDCcb',
  1324. // 'wechatpay-signature-type' => 'WECHATPAY2-SHA256-RSA2048',
  1325. // 'accept' => '*/*',
  1326. // );
  1327. $data['body'] = file_get_contents('php://input');
  1328. $data['header'] = $request->header();
  1329. return \app\api\services\WxPayServices::instance()->data($data)->getNotifyInfo()->afterPay();
  1330. }
  1331. // 绑定支付宝账号
  1332. public function bindAlipay(Request $request, UserDataModel $model)
  1333. {
  1334. $re_data = $request->data;
  1335. if (isset($re_data['real_name']) || isset($re_data['alipay'])) {
  1336. return api_error_return('参数错误--算出sign_str不要传real_name跟alipay');
  1337. }
  1338. [$sign_str] = $request->getMore([
  1339. ['sign_str', '']
  1340. ], true);
  1341. if (empty($sign_str))
  1342. return api_error_return('参数错误');
  1343. $data = json_decode(AESjiemi($sign_str));
  1344. if (empty($data))
  1345. return api_error_return('参数错误');
  1346. $data = object_array($data);
  1347. try {
  1348. return api_succ_return(['msg' => '绑定成功', 'data' => $model->bindAlipay($data, $request->uid)]);
  1349. } catch (\Exception $e) {
  1350. return api_error_return('绑定失败');
  1351. }
  1352. }
  1353. // 解绑支付宝
  1354. public function unbindAlipay(Request $request, UserDataModel $model){
  1355. try {
  1356. return api_succ_return(['msg' => '解绑成功', 'data' => $model->unbindAlipay($request)]);
  1357. } catch (\Exception $e) {
  1358. return api_error_return('解绑失败');
  1359. }
  1360. }
  1361. // public function payResult(Request $request){
  1362. //// $out_no = $request->post('')
  1363. //// $out_trade_no = 'YPL202209240649074123527091115';
  1364. //
  1365. //
  1366. // }
  1367. public function thirdPaySqzBack(Request $request){
  1368. // 协议绑卡
  1369. // {"orderid":"SYL202209280158007492161561569","opstate":"0","ovalue":"0.26","systime":"2022\/09\/28 02:25:47","sysorderid":"22092802252822020418","completiontime":"2022\/09\/28 02:25:47","attach":"","msg":"","sign":"aa9b11c9ea303c43424ec7d762fca0da"}
  1370. sr_log('----------------------thirdPaySqzBack支付三方sqz回调-------------------------');
  1371. sr_log($request->param());
  1372. sr_log('----------------------支付三方sqz回调-------------------------');
  1373. $params = $request->param();
  1374. if (isset($params['orderid']) && isset($params['opstate']) && isset($params['ovalue'])){
  1375. // 校验签名
  1376. if (isset($params['sign'])){
  1377. $sign = md5('orderid='.$params['orderid'].'&opstate='.$params['opstate'].'&ovalue='.$params['ovalue'].env('PAYSQZ.SIGNKEY'));
  1378. if ($sign === $params['sign']){
  1379. if ($params['opstate'] == 0){
  1380. Db::startTrans();
  1381. try {
  1382. $service = new ThirdPayServices();
  1383. $service->payBack($params['orderid'], $params['ovalue'], 15, json_encode($params));
  1384. Db::commit();
  1385. }catch (\Exception $e){
  1386. Db::rollback();
  1387. sr_log($e->getMessage());
  1388. return 'opstate=0'.$e->getMessage();
  1389. }
  1390. }else{
  1391. return 'opstate=01';
  1392. }
  1393. }else{
  1394. sr_log('协议绑卡签名不通过');
  1395. return 'opstate=0';
  1396. }
  1397. }
  1398. }
  1399. return 'opstate=0';
  1400. }
  1401. public function thirdPaySqzAliBack(Request $request){
  1402. // {"orderid":"SYL202209280158007492161561569","opstate":"0","ovalue":"0.26","systime":"2022\/09\/28 02:25:47","sysorderid":"22092802252822020418","completiontime":"2022\/09\/28 02:25:47","attach":"","msg":"","sign":"aa9b11c9ea303c43424ec7d762fca0da"}
  1403. sr_log('----------------------三方支付宝sqz回调-------------------------');
  1404. sr_log($request->param());
  1405. sr_log('----------------------三方支付宝sqz回调-------------------------');
  1406. $params = $request->param();
  1407. if (isset($params['orderid']) && isset($params['opstate']) && isset($params['ovalue'])){
  1408. // 校验签名
  1409. if (isset($params['sign'])){
  1410. $sign = md5('orderid='.$params['orderid'].'&opstate='.$params['opstate'].'&ovalue='.$params['ovalue'].env('PAYSQZ.SIGNKEY'));
  1411. if ($sign === $params['sign']){
  1412. if ($params['opstate'] == 0){
  1413. Db::startTrans();
  1414. try {
  1415. $service = new ThirdPayServices();
  1416. $service->payBack($params['orderid'], $params['ovalue'], 16, json_encode($params));
  1417. Db::commit();
  1418. }catch (\Exception $e){
  1419. Db::rollback();
  1420. sr_log($e->getMessage());
  1421. return 'opstate=0'.$e->getMessage();
  1422. }
  1423. }else{
  1424. return 'opstate=01';
  1425. }
  1426. }else{
  1427. return 'opstate=0';
  1428. }
  1429. }
  1430. }
  1431. return 'opstate=0';
  1432. }
  1433. public function thirdPayZfbNewBack(Request $request){
  1434. // {"pay":"true","appId":"dianke","amount":"28","orderId":"20230206160818959664875","version":"1.0","transactionId":"2023020622001491231429909739","sign":"D9560AEACD28FD948D979AF098C06451"}
  1435. sr_log('----------------------三方支付宝电科回调-------------------------');
  1436. sr_log($request->param());
  1437. sr_log('----------------------三方支付宝电科回调-------------------------');
  1438. $params = $request->param();
  1439. $params = json_decode('{"pay":"true","appId":"dianke","amount":"28800","orderId":"20230216212932433597198","version":"1.0","transactionId":"2023021622001469551440188061","sign":"724FA8632852E605189A3E586B2678D1"}', true);
  1440. $service = new ThirdPayServices();
  1441. if (isset($params['orderId']) && isset($params['amount']) && isset($params['pay']) && $params['pay']=='true'){
  1442. // 校验签名
  1443. if (isset($params['sign'])){
  1444. $back_sign = $params['sign'];
  1445. unset($params['sign']);
  1446. $sign = $service->diankesign($params);
  1447. if ($sign == $back_sign){
  1448. Db::startTrans();
  1449. try {
  1450. $service->payBack($params['orderId'], $params['amount'], 22, json_encode($params));
  1451. Db::commit();
  1452. }catch (\Exception $e){
  1453. Db::rollback();
  1454. sr_log('电科报错'.$e->getMessage());
  1455. return 'success';
  1456. }
  1457. }else{
  1458. return 'success';
  1459. }
  1460. }
  1461. }
  1462. return 'success';
  1463. }
  1464. public function thirdPayWBPayBackUrl(Request $request){
  1465. // {"pay":"true","appId":"dianke","amount":"28","orderId":"20230206160818959664875","version":"1.0","transactionId":"2023020622001491231429909739","sign":"D9560AEACD28FD948D979AF098C06451"}
  1466. sr_log('----------------------广汇商(微宝富支付)-------------------------');
  1467. sr_log($request->param());
  1468. sr_log($request->header());
  1469. sr_log('----------------------广汇商(微宝富支付)-------------------------');
  1470. $params = $request->param();
  1471. $header = $request->header();
  1472. // $params = json_decode('{"pay":"true","appId":"dianke","amount":"23","orderId":"20230211051634709607926","version":"1.0","transactionId":"2023021122001411311446728675","sign":"CE5B60938178B3F383E332D652A9EFB9"}', true);
  1473. if (isset($header['visitauth']) && isset($header['timestamp'])){
  1474. $md5Key = "~-7Hwu+s55A";
  1475. $aesKey = "G0qapUJ887t8PTaTNoi96G5L";
  1476. // $timestamps = time();
  1477. $timestamps = $header['timestamp'];
  1478. $cipherText = $header['visitauth'];
  1479. $plainText = md5($md5Key. ":" .$timestamps);
  1480. $iv = substr($aesKey,0,16);
  1481. $aesTool = new WBAes($aesKey, 'AES-192-CBC', $iv);
  1482. // 解密
  1483. $outPlainText = $aesTool->decrypt($cipherText);
  1484. if ($outPlainText == $plainText){
  1485. Db::startTrans();
  1486. try {
  1487. $service = new ThirdPayServices();
  1488. $service->payBack($params['merchantTradeNo'], $params['totalAmount'], 57, json_encode($params));
  1489. Db::commit();
  1490. }catch (\Exception $e){
  1491. Db::rollback();
  1492. sr_log('广汇商(微宝富支付)回调报错'.$e->getMessage());
  1493. return 'success';
  1494. }
  1495. }else{
  1496. return 'success';
  1497. }
  1498. }else{
  1499. return 'success';
  1500. }
  1501. // if (isset($params['orderId']) && isset($params['amount']) && isset($params['pay']) && $params['pay']=='true'){
  1502. // // 校验签名
  1503. // if (isset($params['sign'])){
  1504. // $back_sign = $params['sign'];
  1505. // unset($params['sign']);
  1506. // $sign = $service->diankesign($params);
  1507. // if ($sign == $back_sign){
  1508. // Db::startTrans();
  1509. // try {
  1510. // $service->payBack($params['orderId'], $params['amount'], 22, json_encode($params));
  1511. //
  1512. // Db::commit();
  1513. // }catch (\Exception $e){
  1514. // Db::rollback();
  1515. // sr_log('电科报错'.$e->getMessage());
  1516. // return 'success';
  1517. // }
  1518. //
  1519. //
  1520. // }else{
  1521. // return 'success';
  1522. // }
  1523. // }
  1524. //
  1525. // }
  1526. return 'success';
  1527. }
  1528. // 代付回调
  1529. public function thirdPayZfbNewBackdf(Request $request){
  1530. // {"status":"1","appId":"diankef","amount":"120","orderId":"WD51565253559","version":"1.0","sign":"90B754A2099D32097399A103A9451DE2"}
  1531. sr_log('----------------------三方支付宝代付电科回调-------------------------1');
  1532. sr_log($request->param());
  1533. sr_log('----------------------三方支付宝代付电科回调-------------------------2');
  1534. $params = $request->param();
  1535. // $params = json_decode('{"status":"1","appId":"diankef","amount":"120","orderId":"WD51565253559","version":"1.0","sign":"90B754A2099D32097399A103A9451DE2"}', true);
  1536. $service = new ThirdPayServices();
  1537. if (isset($params['orderId']) && isset($params['amount'])){
  1538. // 校验签名
  1539. if (isset($params['sign'])){
  1540. $back_sign = $params['sign'];
  1541. unset($params['sign']);
  1542. $sign = $service->diankesigndf($params);
  1543. if ($sign == $back_sign){
  1544. // Db::startTrans();
  1545. // try {
  1546. try {
  1547. $service->payDfBack($params['orderId'], $params['amount'], $params, json_encode($params));
  1548. }catch (Exception $e){
  1549. sr_log('电科报错'.$e->getMessage());
  1550. return 'success';
  1551. }
  1552. // Db::commit();
  1553. // }catch (\Exception $e){
  1554. // Db::rollback();
  1555. // sr_log('电科报错'.$e->getMessage());
  1556. // return 'success';
  1557. // return $e->getMessage();
  1558. // }
  1559. }else{
  1560. return 'success';
  1561. }
  1562. }
  1563. }
  1564. return 'success';
  1565. }
  1566. public function thirdPaySqzWeixinBack(Request $request){
  1567. // {"orderid":"SYL202209280158007492161561569","opstate":"0","ovalue":"0.26","systime":"2022\/09\/28 02:25:47","sysorderid":"22092802252822020418","completiontime":"2022\/09\/28 02:25:47","attach":"","msg":"","sign":"aa9b11c9ea303c43424ec7d762fca0da"}
  1568. sr_log('----------------------三方微信sqz回调-------------------------');
  1569. sr_log($request->param());
  1570. sr_log('----------------------三方微信sqz回调-------------------------');
  1571. $params = $request->param();
  1572. if (isset($params['orderid']) && isset($params['opstate']) && isset($params['ovalue'])){
  1573. // 校验签名
  1574. if (isset($params['sign'])){
  1575. $sign = md5('orderid='.$params['orderid'].'&opstate='.$params['opstate'].'&ovalue='.$params['ovalue'].env('PAYSQZ.SIGNKEY'));
  1576. if ($sign === $params['sign']){
  1577. if ($params['opstate'] == 0){
  1578. Db::startTrans();
  1579. try {
  1580. $service = new ThirdPayServices();
  1581. $service->payBack($params['orderid'], $params['ovalue'], 17, json_encode($params));
  1582. Db::commit();
  1583. }catch (\Exception $e){
  1584. Db::rollback();
  1585. sr_log($e->getMessage());
  1586. return 'opstate=0'.$e->getMessage();
  1587. }
  1588. }else{
  1589. return 'opstate=01';
  1590. }
  1591. }else{
  1592. return 'opstate=0';
  1593. }
  1594. }
  1595. }
  1596. return 'opstate=0';
  1597. }
  1598. public function thirdPaySqzKuaiBack(Request $request){
  1599. // {"orderid":"SK202210082016332330018423433","opstate":"0","ovalue":"0.21","systime":"2022\/10\/08 20:17:39","sysorderid":"22100820163428020468","completiontime":"2022\/10\/08 20:17:39","attach":"","msg":"","sign":"a969e851d73444f5d8c34d7782e4d9f3"}
  1600. sr_log('----------------------三方银行快捷sqz回调-------------------------');
  1601. sr_log($request->param());
  1602. sr_log('----------------------三方银行快捷sqz回调-------------------------');
  1603. $params = $request->param();
  1604. // $params['orderid'] = 'SK202210082016332330018423433';
  1605. // $params['opstate'] = 0;
  1606. // $params['ovalue'] = 0.21;
  1607. // $params['systime'] = "2022\/10\/08 20:17:39";
  1608. // $params['sysorderid'] = "22100820163428020468";
  1609. // $params['completiontime'] = "22100820163428020468";
  1610. // $params['sign'] = "a969e851d73444f5d8c34d7782e4d9f3";
  1611. if (isset($params['orderid']) && isset($params['opstate']) && isset($params['ovalue'])){
  1612. // 校验签名
  1613. if (isset($params['sign'])){
  1614. $sign = md5('orderid='.$params['orderid'].'&opstate='.$params['opstate'].'&ovalue='.$params['ovalue'].env('PAYSQZ.SXY_SIGNKEY'));
  1615. if ($sign === $params['sign']){
  1616. if ($params['opstate'] == 0){
  1617. Db::startTrans();
  1618. try {
  1619. $service = new ThirdPayServices();
  1620. $service->payBack($params['orderid'], $params['ovalue'], 18, json_encode($params));
  1621. Db::commit();
  1622. }catch (\Exception $e){
  1623. Db::rollback();
  1624. sr_log($e->getMessage());
  1625. return 'opstate=0'.$e->getMessage();
  1626. }
  1627. }else{
  1628. return 'opstate=01';
  1629. }
  1630. }else{
  1631. sr_log('yinsheng快捷银行签名有问题');
  1632. return 'opstate=01';
  1633. }
  1634. }
  1635. }
  1636. return 'opstate=0';
  1637. }
  1638. public function thirdPayYsBack(Request $request){
  1639. sr_log('----------------------银盛回调-------------------------');
  1640. sr_log($request->param());
  1641. sr_log('----------------------银盛回调-------------------------');
  1642. $params = $request->post();
  1643. $res = $this->sign_verify($params);
  1644. if ($res){
  1645. Db::startTrans();
  1646. try {
  1647. $service = new ThirdPayServices();
  1648. $service->payBack($params['out_trade_no'], $params['settlement_amount'], 20, json_encode($params));
  1649. Db::commit();
  1650. }catch (\Exception $e){
  1651. Db::rollback();
  1652. sr_log('银盛回调报错:'.$e->getMessage());
  1653. return 'success';
  1654. }
  1655. }else{
  1656. sr_log('银盛签名有问题');
  1657. return 'success';
  1658. }
  1659. return 'success';
  1660. }
  1661. /**
  1662. * 验签转明码
  1663. * @param input check
  1664. * @param input msg
  1665. * @return data
  1666. * @return success
  1667. */
  1668. public function sign_check($sign, $data)
  1669. {
  1670. $publickeyFile = env('ZLYS.CER_PATH'); //公钥
  1671. $certificateCAcerContent = file_get_contents($publickeyFile);
  1672. $certificateCApemContent = '-----BEGIN CERTIFICATE-----' . PHP_EOL . chunk_split(base64_encode($certificateCAcerContent), 64, PHP_EOL) . '-----END CERTIFICATE-----' . PHP_EOL;
  1673. // 签名验证
  1674. $success = openssl_verify($data, base64_decode($sign), openssl_get_publickey($certificateCApemContent), OPENSSL_ALGO_SHA1);
  1675. return $success;
  1676. }
  1677. //验签
  1678. public function sign_verify($data)
  1679. {
  1680. //返回的数据处理
  1681. $sign = trim($data['sign']);
  1682. unset($data['sign']);
  1683. ksort($data);
  1684. $url = "";
  1685. foreach ($data as $key => $val) {
  1686. /* 验证签名 */
  1687. if ($val) $url .= $key . '=' . $val . '&';
  1688. }
  1689. $str = trim($url, '&');
  1690. if ($this->sign_check($sign, $str) != true) {
  1691. return false;
  1692. } else {
  1693. return true;
  1694. }
  1695. }
  1696. public function userSignBank(Request $request){
  1697. sr_log('----------------------支付三方签约sqz回调-------------------------');
  1698. sr_log($request->param());
  1699. sr_log('----------------------支付三方签约sqz回调-------------------------');
  1700. // $res = file_get_contents('php://input');
  1701. // sr_log('----------------------sqz签约回调-------------------------');
  1702. // sr_log($res);
  1703. // sr_log('----------------------sqz签约回调-------------------------');
  1704. // {"orderid":"signbank534422852485710152","opstate":"0","userno":"57270bf05df92c95f5ad21d9166d8e38","sign":"dd8e86baede215b3687713258213a721"}
  1705. $para = $request->param();
  1706. if (isset($para['userno']) && $para['userno']){
  1707. // 校验签名
  1708. if (isset($para['orderid']) && isset($para['opstate']) && isset($para['userno']) && isset($para['sign'])){
  1709. $sign = md5('orderid='.$para['orderid'].'&opstate='.$para['opstate'].'&userno='.$para['userno'].env('PAYSQZ.SIGNKEY'));
  1710. if ($sign === $para['sign']){
  1711. $sign_orderinfo = Db::name('user_bank_sign')->where('signorder_id', $para['orderid'])->find();
  1712. if ($sign_orderinfo){
  1713. // 获取userno 然后保存
  1714. Db::name('user_bank_sign')->where('signorder_id', $para['orderid'])->save([
  1715. 'userno'=>$para['userno'],
  1716. 'status'=>2
  1717. ]);
  1718. }
  1719. }else{
  1720. return 'error';
  1721. }
  1722. }
  1723. $res = $request->param('signorder_id');
  1724. //
  1725. // https://www.yj.com/api/userSignBank?signorder_id=signbank534422851555549509
  1726. $order_id = $res;
  1727. $sign_info = Db::name('user_bank_sign')->where('signorder_id', $order_id)->find();
  1728. // if ($sign_info)
  1729. // userno
  1730. }
  1731. }
  1732. public function sylSurePay(Request $request){
  1733. Db::startTrans();
  1734. try {
  1735. $third_pay = new ThirdPayServices();
  1736. $third_pay->sylSurePay($request->uid, $request->post());
  1737. Db::commit();
  1738. }catch (\Exception $e){
  1739. Db::rollback();
  1740. return api_error_return($e->getMessage());
  1741. }
  1742. return api_succ_return('支付订单提交成功,稍后请关注订单列表');
  1743. }
  1744. // 用户绑定银行卡
  1745. public function userToSignBank(Request $request){
  1746. //
  1747. Db::startTrans();
  1748. try {
  1749. $third_pay = new ThirdPayServices();
  1750. $sign_url = $third_pay->userBankSign($request->uid, $request->post());
  1751. Db::commit();
  1752. }catch (\Exception $e){
  1753. Db::rollback();
  1754. return api_error_return($e->getMessage());
  1755. }
  1756. return api_succ_return(['msg'=>'成功', 'data'=>['sign_url'=>$sign_url]]);
  1757. }
  1758. // 用户解绑银行卡
  1759. public function userToUnSignBank(Request $request){
  1760. Db::startTrans();
  1761. try {
  1762. $third_pay = new ThirdPayServices();
  1763. $third_pay->userUnBankSign($request->uid, $request->post());
  1764. Db::commit();
  1765. }catch (\Exception $e){
  1766. Db::rollback();
  1767. return api_error_return($e->getMessage());
  1768. }
  1769. return api_succ_return('成功');
  1770. }
  1771. // 用户绑定银行卡签名
  1772. public function myBankSignList(Request $request){
  1773. $list = Db::name('user_bank_sign')->where('uid', $request->uid)->where('status', 2)->field('id,name,bank_card,phone')->withAttr('bank_card', function ($val, $data){
  1774. $len = strlen($val);
  1775. return substr($val,0, 4).'****'.substr($val,$len-5, $len-1);
  1776. })->select()->toArray();
  1777. return api_succ_return(['msg'=>'成功', 'data'=>$list]);
  1778. }
  1779. public function ylBindCanSignList(Request $request){
  1780. return api_succ_return(['msg'=>'成功', 'data'=>[
  1781. 'chuxuka'=>['中国银行','建设银行','工商银行','浦发银行','光大银行','华夏银行','民生银行','平安银行','上海银行','交通银行','邮政储蓄银行','中信银行','浙商银行','广东省农村信用社','山西省农村信用社','内蒙古自治区农村信用社','吉林农村信用社','河南省农村信用社','黄河农村商业银行','深圳农村商业银行','天津滨海农村商业银行股份有限公司','大连农村商业银行','鄞州银行','天津农商银行','辽宁省农村信用社','湖北农信','云南省农村信用社联合社','陕西省农村信用社','青海省农村信用社联合社','湖南省农村信用社','黑龙江省农村信用社','广西农村信用社','苏州银行','四川省农村信用社','甘肃省农村信用社','山东省农村信用社联合社','广西北部湾银行','抚顺银行股份有限公司','辽阳银行股份有限公司','贵州银行','晋中银行股份有限公司','西藏银行股份有限公司','新疆汇和银行股份有限公司','江苏江阴农村商业银行股份有限公司','大连银行','阜新银行','吉林银行','宁夏银行','嘉兴银行','常熟农商银行','江苏江南农村商业银行股份公司','江苏长江商行','台州银行','温州银行','浙江稠州商业银行','绍兴银行','宁波通商银行股份有限公司','温州民商银行','浙江民泰商业银行','浙江泰隆商业银行','金华银行股份有限公司','南洋商业银行','贵阳银行','韩亚银行','宜宾商业银行','自贡市商业银行','顺德农村商业银行','桂林银行股份有限公司','承德银行','富滇银行','昆仑银行','新韩银行中国','邢台银行','张家口市商业银行','沧州银行','兰州银行','友利银行','焦作中旅银行','泉州银行','厦门国际银行','营口银行','朝阳银行股份有限公司','广东华兴银行','长沙银行','锦州银行','九江银行','石嘴山银行股份有限公司','哈尔滨银行','龙江银行','江西银行','攀枝花市商业银行','重庆三峡银行','广州银行','晋城银行','上饶银行','赣州银行','长城华西银行','盛京银行','甘肃银行','中原银行','湖北银行','郑州银行','富邦华一银行有限公司','星展银行','乐山市商业银行股份有限公司','长治银行','上海华瑞银行','湖南三湘银行','海南银行','福建海峡银行','北京农商银行','河北省农村信用社','上海农村商业银行','江苏省农村信用社联合社','浙江农信','安徽省农村信用社联合社','福建省农村信用社联合社','江西省农村信用社','海南省农村信用社','重庆农村商业银行','贵州省农村信用社','新疆自治区农村信用社','武汉农村商业银行','成都农商银行','张家港农村商业银行','江苏紫金农村商业银行','无锡农村商业银行','太仓农村商业银行','昆山农村商业银行','广东南海农村商业银行','浙江长兴农村商业银行'],
  1782. 'xinyongka'=>['招商银行','中国银行','中信银行','民生银行','浦发银行','平安银行','光大银行','广东发展银行','上海银行','华夏银行','工商银行','建设银行','交通银行','邮政储蓄银行','浙商银行','北京银行']
  1783. ]]);
  1784. }
  1785. }