Pub.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | [ WE CAN DO IT MORE SIMPLE ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2018-2020 rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Author: TABLE ME
  8. // +----------------------------------------------------------------------
  9. // | Date: 2020-08-25 17:23
  10. // +----------------------------------------------------------------------
  11. declare (strict_types=1);
  12. namespace app\api\controller;
  13. use think\facade\View;
  14. use app\BaseController;
  15. use app\Request;
  16. use library\services\UtilService;
  17. use library\utils\UtilsTool;
  18. use think\facade\Db;
  19. use think\Image;
  20. use app\model\api\AppBug;
  21. use app\model\api\User as UserModel;
  22. use app\model\api\ShowTemplate;
  23. use app\model\api\UserShowTemplate;
  24. use app\model\api\ServiceType;
  25. use app\model\api\ServiceLabel;
  26. use app\model\api\ServiceTimeType;
  27. use app\model\api\UserWorkType;
  28. use app\model\api\Advert as AdvertModel;
  29. use library\utils\WxpayV2 as wxpayApi;
  30. use app\model\api\ServiceLabel as ServiceLabelModel;
  31. class Pub extends BaseController
  32. {
  33. private $user = null;
  34. public function checkUser($token=null){
  35. if(empty($token)){
  36. return false;
  37. }
  38. $memData = (new UserModel)
  39. ->where('token',$token)
  40. ->where('status',1)
  41. ->find();
  42. if(empty($memData)){
  43. return false;
  44. }
  45. $this->user = $memData->toArray();
  46. return true;
  47. }
  48. /**
  49. * 获取支付类型数据
  50. */
  51. public function getPayTypeData(){
  52. $data = [
  53. ["code"=>"wxpay","title"=>"微信支付","img"=> env('appinfo.app_api_domain', '')."/resource/icon/"."wxicon.png"],
  54. ["code"=>"balance","title"=>"余额支付","img"=>env('appinfo.app_api_domain', '')."/resource/icon/"."balance.png"],
  55. ];
  56. return app('json')->success($data);
  57. }
  58. /**
  59. * 获取模板详情
  60. * @param Request $request
  61. * @return type
  62. */
  63. public function getShowTemplateItem(Request $request){
  64. $post = UtilService::getMore([
  65. ['id', '','empty','参数错误'],
  66. ], $request);
  67. $data = (new ShowTemplate)
  68. ->field("id,title,price,old_price,status,imgs,is_hot,is_recommend,code,look_count,real_sales,unreal_sales")
  69. ->where("id",$post["id"])
  70. ->find();
  71. if(empty($data)){
  72. return app('json')->fail("模板不存在");
  73. }
  74. if($data["status"]!=1){
  75. return app('json')->fail("模板已下架");
  76. }
  77. $data = $data->toArray();
  78. $data["is_use"] = 0;
  79. $data["imgs"] = getImageAr($data["imgs"]);
  80. $data["img"] = empty($data["imgs"]) ? "" : $data["imgs"][0];
  81. $data["sales_count"] = $data["real_sales"] + $data["unreal_sales"];
  82. unset($data["real_sales"]);
  83. unset($data["unreal_sales"]);
  84. //验证是否购买过并添加浏览记录
  85. $this->checkUser($request->header("token", ""));
  86. if(!empty($this->user)){
  87. $data["is_use"]=(new UserShowTemplate)->where("uid",$this->user["uid"])->where("show_template_id",$data["id"])->count()>0?1:0;
  88. (new ShowTemplate)->where('id', $data["id"])->inc('look_count', 1)->update();
  89. }
  90. return app('json')->success($data);
  91. }
  92. /**
  93. * 获取皮肤模板列表
  94. * @param Request $request
  95. */
  96. public function getShowTemplateList(Request $request){
  97. $post = UtilService::getMore([
  98. ['is_hot', '0'],
  99. ['is_recommend', '0'],
  100. ['page', 1],
  101. ['pageSize', 50],
  102. ], $request);
  103. $post["pageSize"] = $post["pageSize"]>50 ? 50 : (int)$post["pageSize"];
  104. $post["page"] = $post["page"]<=0 ? 1 : (int)$post["page"];
  105. $where=[];
  106. $where[]=["status","=",1];
  107. if((int)$post["is_hot"]==1){
  108. $where[]=["is_hot","=",1];
  109. }
  110. if((int)$post["is_recommend"]==1){
  111. $where[]=["is_recommend","=",1];
  112. }
  113. $totalCount = (new ShowTemplate)->where($where)->count();
  114. $data=null;
  115. if($totalCount>0){
  116. $data = (new ShowTemplate)
  117. ->field("id,title,price,old_price,status,imgs,is_hot,is_recommend,code,look_count,real_sales,unreal_sales")
  118. ->where($where)
  119. ->order("id", "desc")
  120. ->page((int)$post["page"], $post["pageSize"])
  121. ->select();
  122. foreach($data as $k=>$v){
  123. $data[$k]["is_use"] = 0;//是否已经购买或者可以使用
  124. $data[$k]["imgs"] = getImageAr($v["imgs"]);
  125. $data[$k]["img"] = empty($data[$k]["imgs"]) ? "" : $data[$k]["imgs"][0];
  126. $data[$k]["sales_count"] = $data[$k]["real_sales"] + $data[$k]["unreal_sales"];
  127. unset($data[$k]["real_sales"]);
  128. unset($data[$k]["unreal_sales"]);
  129. }
  130. }
  131. $data = empty($data)?[]:$data;
  132. return app('json')->success(["list" => $data, "pageSize" => $post["pageSize"],"page"=>$post["page"],"totalCount"=>$totalCount]);
  133. }
  134. /**
  135. * 获取轮播图
  136. * @param Request $request
  137. */
  138. public function getBannerList(Request $request){
  139. $post = UtilService::getMore([
  140. ['type', ''],
  141. ['page', 1],
  142. ['pageSize', 50],
  143. ], $request);
  144. $post["pageSize"] = $post["pageSize"]>50 ? 50 : (int)$post["pageSize"];
  145. $post["page"] = $post["page"]<=0 ? 1 : (int)$post["page"];
  146. $where=[];
  147. $where[]=["is_show","=",1];
  148. $where[]=["page_id","=",70];
  149. $totalCount = (new AdvertModel)->where($where)->count();
  150. $data=null;
  151. if($totalCount>0){
  152. $data = (new AdvertModel)
  153. ->field("id,img,title,url")
  154. ->where($where)
  155. ->order("sort","desc")
  156. ->page($post["page"], $post["pageSize"])
  157. ->select();
  158. }
  159. $data = empty($data)?[]:$data;
  160. return app('json')->success(["list" => $data, "pageSize" => $post["pageSize"],"page"=>$post["page"],"totalCount"=>$totalCount]);
  161. }
  162. /**
  163. * 获取服务类型列表
  164. * @param Request $request
  165. * @return type
  166. */
  167. public function getServiceTypeList(Request $request){
  168. $post = UtilService::getMore([
  169. ['page', 1],
  170. ['pageSize', 50],
  171. ], $request);
  172. $post["pageSize"] = $post["pageSize"]>50 ? 50 : (int)$post["pageSize"];
  173. $post["page"] = $post["page"]<=0 ? 1 : (int)$post["page"];
  174. $where=[];
  175. $where[]=["status","=",1];
  176. $totalCount = (new ServiceType)->where($where)->count();
  177. $data=null;
  178. if($totalCount>0){
  179. $data = (new ServiceType)
  180. ->field("id,title,content,img")
  181. ->where($where)
  182. ->order("seq", "desc")
  183. ->page($post["page"], $post["pageSize"])
  184. ->select();
  185. }
  186. $data = empty($data)?[]:$data;
  187. return app('json')->success(["list" => $data, "pageSize" => $post["pageSize"],"page"=>$post["page"],"totalCount"=>$totalCount]);
  188. }
  189. /**
  190. * 获取标签列表
  191. * @param Request $request
  192. * @return type
  193. */
  194. public function getServiceLabelList(Request $request){
  195. $post = UtilService::getMore([
  196. ['page', 1],
  197. ['pageSize', 50],
  198. ], $request);
  199. $post["pageSize"] = $post["pageSize"]>50 ? 50 : (int)$post["pageSize"];
  200. $post["page"] = $post["page"]<=0 ? 1 : (int)$post["page"];
  201. $where=[];
  202. $where[]=["status","=",1];
  203. $totalCount = (new ServiceLabel)->where($where)->count();
  204. $data=null;
  205. if($totalCount>0){
  206. $data = (new ServiceLabel)
  207. ->field("id,title,type")
  208. ->where($where)
  209. ->order("seq", "desc")
  210. ->page($post["page"], $post["pageSize"])
  211. ->select();
  212. }
  213. $data = empty($data)?[]:$data;
  214. return app('json')->success(["list" => $data, "pageSize" => $post["pageSize"],"page"=>$post["page"],"totalCount"=>$totalCount]);
  215. }
  216. /**
  217. * 获取用户工作服务类型
  218. * @param Request $request
  219. */
  220. public function getUserWorkTypeList(Request $request){
  221. $post = UtilService::getMore([
  222. ['page', 1],
  223. ['pageSize', 50],
  224. ], $request);
  225. $post["pageSize"] = $post["pageSize"]>50 ? 50 : (int)$post["pageSize"];
  226. $post["page"] = $post["page"]<=0 ? 1 : (int)$post["page"];
  227. $where=[];
  228. $where[]=["status","=",1];
  229. $totalCount = (new UserWorkType)->where($where)->count();
  230. $data=null;
  231. if($totalCount>0){
  232. $data = (new UserWorkType)
  233. ->field("id,title,content,img")
  234. ->where($where)
  235. ->order("seq", "desc")
  236. ->page($post["page"], $post["pageSize"])
  237. ->select();
  238. }
  239. $data = empty($data)?[]:$data;
  240. return app('json')->success(["list" => $data, "pageSize" => $post["pageSize"],"page"=>$post["page"],"totalCount"=>$totalCount]);
  241. }
  242. /**
  243. * 获取服务时长类型
  244. * @param Request $request
  245. * @return type
  246. */
  247. public function getServiceTimeTypeList(Request $request){
  248. $post = UtilService::getMore([
  249. ['page', 1],
  250. ['pageSize', 50],
  251. ], $request);
  252. $post["pageSize"] = $post["pageSize"]>50 ? 50 : (int)$post["pageSize"];
  253. $post["page"] = $post["page"]<=0 ? 1 : (int)$post["page"];
  254. $where=[];
  255. $where[]=["status","=",1];
  256. $totalCount = (new ServiceTimeType)->where($where)->count();
  257. $data=null;
  258. if($totalCount>0){
  259. $data = (new ServiceTimeType)
  260. ->field("title,code")
  261. ->where($where)
  262. ->order("id", "asc")
  263. ->page($post["page"], $post["pageSize"])
  264. ->select();
  265. }
  266. $data = empty($data)?[]:$data;
  267. return app('json')->success(["list" => $data, "pageSize" => $post["pageSize"],"page"=>$post["page"],"totalCount"=>$totalCount]);
  268. }
  269. /**
  270. * 获取系统信息
  271. * @param Request $request
  272. */
  273. public function getSysData(Request $request){
  274. $data = (new Sys)->where("id",1)->find()->toArray();
  275. $data=[];
  276. return app("json")->success($data);
  277. }
  278. /**
  279. * 首页轮播
  280. * @param Request $request
  281. */
  282. public function getHomeBanner(Request $request){
  283. $data = (new AdvertModel)
  284. ->field("id,img,title,url")
  285. ->where("page_id",70)
  286. ->where("is_show",1)
  287. ->order("sort","desc")
  288. ->select()
  289. ->toArray();
  290. $data = empty($data)?[]:$data;
  291. return app("json")->success($data);
  292. }
  293. /**
  294. * bug提交
  295. * @param Request $request
  296. */
  297. public function appBugSub(Request $request){
  298. [$error] = UtilService::getMore([
  299. ['error', '','empty',"错误信息为空"],
  300. ], $request,true);
  301. $deviceId = $request->header("deviceId", "");
  302. $deviceType = $request->header("deviceType", "");
  303. $fromPlat = $request->header("fromPlat", "");
  304. $version = $request->header("version", "");
  305. (new AppBug)->insert([
  306. "device_id" => $deviceId,
  307. "device_type" => $deviceType,
  308. "from_plat" => $fromPlat,
  309. "version" => $version,
  310. "error" => $error,
  311. "time" => time()
  312. ]);
  313. return app("json")->success("提交成功");
  314. }
  315. /**
  316. * 测试
  317. */
  318. public function appTest(Request $request){
  319. $labelData = (new ServiceLabelModel)->where("status",1)->where("id","in",["",1,2,6,7,8,0])->column('id');
  320. var_dump($labelData);exit;
  321. $money = $request->post("money",0);
  322. $money = bcadd("0", $money."",2);
  323. echo $money;exit;
  324. $xml = "<xml><appid><![CDATA[wx57a473fc2f83f7e5]]></appid>
  325. <attach><![CDATA[微信小程序支付]]></attach>
  326. <bank_type><![CDATA[OTHERS]]></bank_type>
  327. <cash_fee><![CDATA[1]]></cash_fee>
  328. <fee_type><![CDATA[CNY]]></fee_type>
  329. <is_subscribe><![CDATA[N]]></is_subscribe>
  330. <mch_id><![CDATA[1640972417]]></mch_id>
  331. <nonce_str><![CDATA[TTEMpfip075pcFNNhS5P60tDtis91veA]]></nonce_str>
  332. <openid><![CDATA[oOqrp4tndyR_iDwrGC5P7Y4moP2Y]]></openid>
  333. <out_trade_no><![CDATA[A202304201681959554328879382]]></out_trade_no>
  334. <result_code><![CDATA[SUCCESS]]></result_code>
  335. <return_code><![CDATA[SUCCESS]]></return_code>
  336. <sign><![CDATA[146B5ADFF5ADC399A92C60D62C54638A]]></sign>
  337. <time_end><![CDATA[20230420105928]]></time_end>
  338. <total_fee>1</total_fee>
  339. <trade_type><![CDATA[JSAPI]]></trade_type>
  340. <transaction_id><![CDATA[4200001803202304202712861307]]></transaction_id>
  341. </xml>";
  342. $wxpay = new wxpayApi();
  343. // $r = $wxpay->notifyCheckSign($xml);
  344. $r = $wxpay->searchOrderQuery("A202304201681959554328879382");
  345. var_dump($r);
  346. }
  347. }