Index.php 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774
  1. <?php
  2. namespace app\api\controller;
  3. use AlibabaCloud\DBFS\V20200418\DbfsRecord;
  4. use app\common\model\Article;
  5. use app\common\model\ArticleCate;
  6. use app\common\model\GoodsCate;
  7. use app\common\model\Goods;
  8. use app\common\model\GoodsNumber;
  9. use app\common\model\Order;
  10. use app\common\model\Banner;
  11. use app\common\model\User;
  12. use app\common\controller\Api;
  13. use app\common\model\UserForm;
  14. use app\store\controller\Video;
  15. use think\Exception;
  16. use think\facade\Validate;
  17. use think\Db;
  18. /**
  19. * @title 首页
  20. * @controller Index
  21. */
  22. class Index extends Api
  23. {
  24. /**
  25. * @title 首页banner
  26. * @desc 首页banner
  27. * @url /api/Index/banner_list
  28. * @method POST
  29. * @tag 基础
  30. */
  31. public function banner_list(){
  32. $result = Banner::BannerList();
  33. $this->success($result['msg'],$result['data']);
  34. }
  35. public function text(){
  36. print_r(getConfig('tuijian'));die;
  37. // $sta_week = date("Y-m-d H:i:s", mktime(0,0,0,date("m"),date("d")-date("w")+1,date("Y"))); //2020-03-09 00:00:00
  38. // $end_week = date("Y-m-d H:i:s", mktime(0,0,0,date("m"),date("d")-date("w")+7,date("Y"))); //2020-03-09 00:00:00
  39. // $weeek_regiz = Db::name('store_member')->whereBetween('create_at',[$sta_week,$end_week])->fetchSql()->count();
  40. // print_r($weeek_regiz);
  41. // $userId = 9;
  42. // $list = Db::name('store_member_interested')
  43. // ->alias('i')
  44. // ->join('store_member m', 'm.id=i.i_id')
  45. //// ->join('store_area a', 'm.province_id=a.id')
  46. // ->where('mid', 9)
  47. // ->field('i_id,nickname,age,headimg')
  48. // ->select();
  49. // print_r($list);die;
  50. $pr = av_status(8);
  51. // $use = Db::name('store_member')->where('id',9)->find();
  52. // $url = 'https://xiangqinim.zhousi.hdlkeji.com/addons/fastim/api.user/createUser?username='.$use['nickname'].'&avatar='.$use['nickname'].'&id='.$userId;
  53. // curlRequest($url);
  54. }
  55. /**
  56. * 首页公告
  57. */
  58. public function notice(){
  59. $mid = $this->check_login();
  60. $sex = Db::name('store_member')->where('id',$mid)->value('sex');
  61. if($sex==1) {
  62. $p_sex = 2;
  63. }
  64. else{
  65. $p_sex = 1;
  66. }
  67. $notice = Db::name('store_notice')->order('id','DESC')->find();
  68. unset($notice['is_deleted']);
  69. $ids = Db::name('store_recommend')->where('m_id',$mid)->find();
  70. if(empty($ids['tuijian'])){
  71. $member = [];
  72. }
  73. else {
  74. $time_a = time() - $ids['createtime'];
  75. $time_b = 86400 * getConfigValue('tuijian');
  76. if ($time_a >= $time_b) {
  77. $this->save_recommend($mid, $p_sex);
  78. $ids = Db::name('store_recommend')->where('m_id', $mid)->find();
  79. }
  80. $u_ids = explode(',', $ids['tuijian']);
  81. $member = Db::name('store_member')->whereIn('id', $u_ids)->field('id,sex,nickname,headimg,im_id')->select();
  82. }
  83. // $member = Db::name('store_member')->where('sex','=',$p_sex)->where('vip_level','=',1)->whereIn('status','1,3,4')->orderRaw('rand()')->limit(3)->field('id,sex,nickname,headimg,im_id')->select();
  84. $video = Db::name('store_video')->where('is_deleted',0)->orderRaw('rand()')->limit(3)->field('id,title,video_url,show_image,video_time')->select();
  85. $article = Db::name('store_article')->where('is_deleted',0)->order('id','DESC')->field('id,title,content,show_image,subtitle')->limit(3)->select();
  86. $this->success('首页数据',['notice' => $notice,'member'=>$member,'video'=>$video,'article'=>$article]);
  87. }
  88. /**
  89. * 视频列表
  90. */
  91. public function videolist(){
  92. $listRows = input('listRows','10');
  93. $page = input('page','1');
  94. $key = input('title');
  95. $where = [];
  96. if(isset($key)&&$key){
  97. $where[] = ['title','like','%'.$key.'%'];
  98. }
  99. $video = Db::name('store_video')
  100. ->where($where)
  101. ->where('is_deleted',3)
  102. ->field('id,title,video_url,create_at,show_image,video_time')
  103. ->order('id','DESC')
  104. ->paginate($listRows,'',['page'=>$page]);
  105. $this->success('首页数据',$video);
  106. }
  107. public function article_class(){
  108. $class = Db::name('store_article_class')->where('is_deleted','=',0)->field('id,title')->select();
  109. $this->success('文章分类',$class);
  110. }
  111. /**
  112. * 文章列表
  113. */
  114. public function articlelist(){
  115. $listRows = input('listRows','10');
  116. $page = input('page','1');
  117. $key = input('title');
  118. $where = [];
  119. if(isset($key)&&$key){
  120. $where[] = ['title','like','%'.$key.'%'];
  121. }
  122. $video = Db::name('store_article')
  123. ->where($where)
  124. ->where('is_deleted',0)
  125. ->field('id,title,show_image,create_at,subtitle,type')
  126. ->order('id','DESC')
  127. ->paginate($listRows,'',['page'=>$page]);
  128. $this->success('首页数据',$video);
  129. }
  130. /**
  131. * 文章详情
  132. */
  133. public function articlederail(){
  134. $id = input('id');
  135. $article = Db::name('store_article')
  136. ->where('id',$id)
  137. ->find();
  138. unset($article['is_deleted']);
  139. $this->success('首页数据',$article);
  140. }
  141. /**
  142. * 注册用户
  143. */
  144. public function registered_user(){
  145. $this->check_login();
  146. $page = input('page',1);
  147. $page_num = input('page_num',6);
  148. $age_max = input('age_max');
  149. $age_min = input('age_min');
  150. $nature = input('nature');
  151. $education = input('education');
  152. $sex = input('sex');
  153. $where = [];
  154. if(isset($age_max)&&isset($age_min)) {
  155. if (!empty($age_max) && !empty($age_min)) {
  156. $where[] = ['age', 'between', [$age_min, $age_max]];
  157. }
  158. }
  159. if(isset($nature)) {
  160. if (!empty($nature)) {
  161. $where[] = ['nature', 'in', $nature];
  162. }
  163. }
  164. if(isset($education)) {
  165. if (!empty($education)) {
  166. $where[] = ['education', 'in', $education];
  167. }
  168. }
  169. if(isset($sex)) {
  170. if (!empty($sex)) {
  171. $where[] = ['sex', '=', $sex];
  172. }
  173. }
  174. $member = Db::name('store_member')
  175. ->where('vip_level',0)
  176. ->where($where)
  177. ->order('id','DESC')
  178. ->field('id,nickname,sex,height,province_id,age,headimg,vip_level,im_id')
  179. ->paginate($page_num,'',['page'=>$page]);
  180. $member= $member->items();
  181. foreach ($member as $k=>$v){
  182. $member[$k]['province_id'] = Db::name('store_area')->where('id',$member[$k]['province_id'])->value('shortname');
  183. }
  184. $this->success('注册用户',$member);
  185. }
  186. /**
  187. * 认证用户
  188. */
  189. public function certified_user(){
  190. $this->check_login();
  191. $page = input('page',1);
  192. $page_num = input('page_num',6);
  193. $age_max = input('age_max');
  194. $age_min = input('age_min');
  195. $nature = input('nature');
  196. $education = input('education');
  197. $sex = input('sex');
  198. $level = input('level','');
  199. $where = [];
  200. if(isset($age_max)&&isset($age_min)) {
  201. if (!empty($age_max) && !empty($age_min)) {
  202. $where[] = ['age', 'between', [$age_min, $age_max]];
  203. }
  204. }
  205. if(isset($nature)) {
  206. if (!empty($nature)) {
  207. $where[] = ['nature', 'in', $nature];
  208. }
  209. }
  210. if(isset($education)) {
  211. if (!empty($education)) {
  212. $where[] = ['education', 'in', $education];
  213. }
  214. }
  215. if(isset($sex)) {
  216. if (!empty($sex)) {
  217. $where[] = ['sex', '=', $sex];
  218. }
  219. }
  220. if(isset($level)) {
  221. if ($level!='') {
  222. $where[] = ['vip_level', '=', $level];
  223. }
  224. }
  225. $member = Db::name('store_member')
  226. ->whereIn('vip_level','0,1')
  227. ->where($where)
  228. ->order('id','DESC')
  229. ->field('id,nickname,sex,height,area_id,age,headimg,vip_level,im_id')
  230. ->paginate($page_num,'',['page'=>$page]);
  231. $member= $member->items();
  232. foreach ($member as $k=>$v){
  233. $member[$k]['province_id'] = Db::name('store_area')->where('id',$member[$k]['area_id'])->value('shortname');
  234. }
  235. $this->success('认证用户',$member);
  236. }
  237. /**
  238. * 工作性质
  239. */
  240. public function WorkNature(){
  241. $nature = Db::name('store_work_nature')->where('is_deleted',0)->field('id,name')->select();
  242. $this->success('工作性质',$nature);
  243. }
  244. /*
  245. * 智能匹配
  246. */
  247. public function Intelligent(){
  248. $user_id = $this->check_login();;
  249. $data = input();
  250. $sex = Db::name('store_member')->where('id',$user_id)->value('sex');
  251. if($sex==1) {
  252. $p_sex = 2;
  253. }
  254. else{
  255. $p_sex = 1;
  256. }
  257. $add_data=[
  258. 'age'=>$data['age_min'].'-'.$data['age_max'],
  259. 'education'=>$data['education'],
  260. 'height'=>$data['height_min'].'-'.$data['height_max'],
  261. 'income' => $data['income_min'].'-'.$data['income_max'],
  262. 'nature'=>$data['nature'],
  263. 'area_id'=>$data['area_id'],
  264. ];
  265. Db::name('store_marriage')->insert($add_data);
  266. $where = [];
  267. if($data['age_min']&&$data['age_max']&&$data['nature']&&$data['education']&&$data['height_min']&&$data['height_max']&&$data['income_min']&&$data['income_max']&&$data['area_id']){
  268. $where[] = ['age','between',[$data['age_min'],$data['age_max']]];
  269. $where[] = ['nature','=',$data['nature']];
  270. $where[] = ['education','=',$data['education']];
  271. $where[] = ['height','between',[$data['height_min'],$data['height_max']]];
  272. $where[] = ['income','between',[$data['income_min'],$data['income_max']]];
  273. $where[] = ['area_id','=',$data['area_id']];
  274. $member = Db::name('store_member')
  275. ->where('sex',$p_sex)
  276. ->where('is_deleted',1)
  277. ->where($where)
  278. ->field('id,nickname,sex,height,province_id,age,headimg')
  279. ->select();
  280. foreach ($member as $k=>$v){
  281. $member[$k]['province_id'] = Db::name('store_area')->where('id',$member[$k]['province_id'])->value('shortname');
  282. }
  283. $this->success('匹配结果',$member);
  284. }
  285. else{
  286. $this->error('筛选信息不能为空');
  287. }
  288. }
  289. /**
  290. * 三区九县
  291. */
  292. public function linyi(){
  293. $area = Db::name('store_area')->where('pid','=',1479)->field('id,name')->select();
  294. $this->success('三区九县',$area);
  295. }
  296. /**
  297. * 举报类型
  298. */
  299. public function report_problem(){
  300. $list = Db::name('store_report_problem')->where('is_deleted',0)->field('id,title')->select();
  301. $this->success('举报类型',$list);
  302. }
  303. /**
  304. * 我要举报uuid举报
  305. */
  306. public function report(){
  307. $mid = $this->check_login();
  308. // $this->check_login()
  309. $data = input();
  310. $r_id = Db::name('store_member')->where('vip_number',$data['uuid'])->value('id');
  311. if(empty($r_id)){
  312. $this->error('填写正确要举报人的会员ID');
  313. }
  314. if(empty($data['type'])){
  315. $this->error('填写举报类型不能为空');
  316. }
  317. $p_name = Db::name('store_report_problem')->where('id',$data['type'])->value('title');
  318. if(empty($data['content'])){
  319. $this->error('填写举报内容不能为空');
  320. }
  321. if(empty($data['r_images'])){
  322. $this->error('填写举报图片不能为空');
  323. }
  324. $insert = [
  325. 'm_id'=>$r_id,
  326. 'r_id'=>$mid,
  327. 'p_id'=>$data['type'],
  328. 'p_name'=>$p_name,
  329. 'r_content'=>$data['content'],
  330. 'r_images'=>$data['r_images'],
  331. 'reject'=>'',
  332. 'status'=>1,
  333. 'is_deleted'=>0,
  334. 'create_at'=>date('Y-m-d H:i:s')
  335. ];
  336. Db::startTrans();
  337. try {
  338. $is_have = Db::name('store_report')->where(array('m_id'=>$r_id,'r_id'=>$mid))->find();
  339. if($is_have){
  340. Db::name('store_report')->where('id',$is_have['id'])->update($insert);
  341. }
  342. else {
  343. Db::name('store_report')->insert($insert);
  344. }
  345. Db::commit();
  346. }catch (Exception $e) {
  347. Db::rollback();
  348. $this->error('举报未成功,重新举报');
  349. }
  350. $this->success('举报成功,等待结果');
  351. }
  352. /**
  353. * 我要举报指定用户举报
  354. */
  355. public function user_report(){
  356. $mid = $this->check_login();
  357. // $this->check_login()
  358. $data = input();
  359. if(empty($data['type'])){
  360. $this->error('填写举报类型不能为空');
  361. }
  362. $p_name = Db::name('store_report_problem')->where('id',$data['type'])->value('title');
  363. if(empty($data['content'])){
  364. $this->error('填写举报内容不能为空');
  365. }
  366. if(empty($data['r_images'])){
  367. $this->error('填写举报图片不能为空');
  368. }
  369. $insert = [
  370. 'm_id'=>$data['r_id'],
  371. 'r_id'=>$mid,
  372. 'p_id'=>$data['type'],
  373. 'p_name'=>$p_name,
  374. 'r_content'=>$data['content'],
  375. 'r_images'=>$data['r_images'],
  376. 'reject'=>'',
  377. 'status'=>1,
  378. 'is_deleted'=>0,
  379. 'create_at'=>date('Y-m-d H:i:s')
  380. ];
  381. Db::startTrans();
  382. try {
  383. $is_have = Db::name('store_report')->where(array('m_id'=>$data['r_id'],'r_id'=>$mid))->find();
  384. if($is_have){
  385. Db::name('store_report')->where('id',$is_have['id'])->update($insert);
  386. }
  387. else {
  388. Db::name('store_report')->insert($insert);
  389. }
  390. Db::commit();
  391. }catch (Exception $e) {
  392. Db::rollback();
  393. $this->error('举报未成功,重新举报');
  394. }
  395. $this->success('举报成功,等待结果');
  396. }
  397. public function banner(){
  398. $list = Db::name('store_banner')->where('is_deleted',0)->field('show_image')->select();
  399. $this->success('轮播图',$list);
  400. }
  401. public function xcxtuisong($uid){
  402. $openid = Db::name('third')->where('user_id',2)->field('openid')->find();
  403. //请求access_token
  404. $getToken = file_get_contents("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=wx4c96fac89070fe7a&secret=36edc36c9ec2fb309fd90c9a9e719560");
  405. //json解析返回数据
  406. $getToken = json_decode($getToken);
  407. //拿到access_token
  408. $token = $getToken ->{'access_token'};
  409. // 获取请求路径
  410. //sprintf=php方法
  411. //推送消息url
  412. $msgUrl = 'https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token='.$token;
  413. //订阅消息的模板消息
  414. $msgObj = [
  415. //模板属性
  416. "thing1"=> [
  417. //模板属性值
  418. "value"=> "339208499"
  419. ],
  420. "thing3"=> [
  421. "value"=> "17503008888"
  422. ],
  423. "date2"=> [
  424. "value"=> "120"
  425. ],
  426. ];
  427. //请求的data数据
  428. $msgData = [
  429. 'access_token'=> $token,
  430. 'touser'=> $openid['openid'],
  431. 'template_id'=> '6gBL8zRZ3YKjA7iNXpeS7SBguNKNQM8hmXrHK3VWr9M',
  432. 'data'=> $msgObj
  433. ];
  434. //curl_post自定封装post请求
  435. curl_post($msgUrl,$msgData);
  436. }
  437. /**
  438. * @return void
  439. * 情感咨询
  440. */
  441. public function emotion(){
  442. $mid = $this->check_login();
  443. $problem = input('problem','');
  444. if($problem==''){
  445. $this->error('咨询问题不能为空');
  446. }
  447. $add_data = [
  448. 'm_id'=>$mid,
  449. 'problem'=>$problem,
  450. 'create_time'=>date('Y-m-d H:i:s')
  451. ];
  452. Db::startTrans();
  453. try {
  454. $res = Db::name('store_emotional_counseling')->insertGetId($add_data);
  455. $add_data_new = [
  456. 'e_id'=>$res,
  457. 'type'=>1,
  458. 'answer'=>$problem,
  459. 'create_time'=>date('Y-m-d H:i:s')
  460. ];
  461. Db::name('store_answer_log')->insert($add_data_new);
  462. Db::commit();
  463. }catch (Exception $e){
  464. $this->error('提交失败联系管理人员');
  465. }
  466. $this->success('情感咨询已提交,等待专员回复');
  467. }
  468. /**
  469. * @return void
  470. * 持续回复
  471. */
  472. public function answer(){
  473. $this->check_login();
  474. $eid = input('e_id');
  475. $answer = input('answer');
  476. $add_data_new = [
  477. 'e_id'=>$eid,
  478. 'type'=>1,
  479. 'answer'=>$answer,
  480. 'create_time'=>date('Y-m-d H:i:s')
  481. ];
  482. Db::startTrans();
  483. try {
  484. Db::name('store_answer_log')->insert($add_data_new);
  485. Db::name('store_emotional_counseling')->where('id',$eid)->update(['status'=>1]);
  486. Db::commit();
  487. }catch (Exception $e){
  488. $this->error('发送失败,联系管理人员');
  489. }
  490. $this->success('发送成功,等待专员回复');
  491. }
  492. /**
  493. * @return void
  494. * @throws \think\db\exception\DataNotFoundException
  495. * @throws \think\db\exception\ModelNotFoundException
  496. * @throws \think\exception\DbException
  497. * 问答记录
  498. */
  499. public function answer_log(){
  500. $this->check_login();
  501. $eid = input('e_id');
  502. $list = Db::name('store_answer_log')->where('e_id',$eid)->order('id','asc')->field('type,answer,create_time')->select();
  503. $this->success('问答记录',$list);
  504. }
  505. /**
  506. * @return void
  507. * @throws \think\db\exception\DataNotFoundException
  508. * @throws \think\db\exception\ModelNotFoundException
  509. * @throws \think\exception\DbException
  510. * 情感咨询记录
  511. */
  512. public function emotion_list(){
  513. $mid = $this->check_login();
  514. $list = Db::name('store_emotional_counseling')->where('m_id',$mid)->where('is_deleted','=',0)->field('id,problem,create_time')->select();
  515. $this->success('情感咨询记录',$list);
  516. }
  517. public function delete_emotion(){
  518. $this->check_login();
  519. $eid = input('e_id');
  520. Db::name('store_emotional_counseling')->where('id',$eid)->update(['is_deleted'=>1]);
  521. $this->success('情感咨询记录已删除');
  522. }
  523. /**
  524. * @return void
  525. * @throws Exception
  526. * @throws \think\exception\PDOException
  527. * 基础信息
  528. */
  529. public function member_basic(){
  530. $uid = $this->check_login();
  531. $ceshi = input('type');
  532. $nickname = input('nickname');
  533. $height =input('height');
  534. $weight = input('weight');
  535. $area_id = input('area_id');
  536. $working = input('working');
  537. $username = input('username');
  538. $sex = input('sex');
  539. $ID_car = input('ID_car');
  540. $age = input('age');
  541. $education = input('education');
  542. $phone = input('phone');
  543. $code = input('code');
  544. $headimg = input('headimg');
  545. if(!$code||!$phone||!$username||!$ID_car||!$age||!$education){
  546. $this->error('参数不能为空');
  547. }
  548. $time = time()-60;
  549. $sms = Db::name('store_sms')->where(['mobile' => $phone, 'event' => 'yzm'])
  550. ->where('createtime','>',$time)
  551. ->order('id', 'DESC')
  552. ->find();
  553. if (!$sms || $sms['code'] != $code) $this->error('短信验证码不正确!');
  554. $data = [
  555. 'working'=>$working,
  556. 'username'=>$username,
  557. 'sex'=>$sex,
  558. 'ID_car'=>$ID_car,
  559. 'age'=>$age,
  560. 'education'=>$education,
  561. 'phone'=>$phone,
  562. 'state'=>0,
  563. 'create_at'=>date('Y-m-d H:i:s')
  564. ];
  565. if(isset($ceshi)){
  566. $data = [
  567. 'nickname'=>$nickname,
  568. 'username'=>$username,
  569. 'sex'=>$sex,
  570. 'ID_car'=>$ID_car,
  571. 'age'=>$age,
  572. 'education'=>$education,
  573. 'height'=>$height,
  574. 'weight'=>$weight,
  575. 'area_id'=>$area_id,
  576. 'phone'=>$phone,
  577. 'headimg'=>$headimg,
  578. 'state'=>0,
  579. 'create_at'=>date('Y-m-d H:i:s')
  580. ];
  581. }
  582. $is_have = Db::name('store_member_basic')->where('mid',$uid)->find();
  583. if($is_have){
  584. Db::name('store_member_basic')->where('id',$is_have['id'])->update($data);
  585. }
  586. else{
  587. $data['mid']=$uid;
  588. Db::name('store_member_basic')->insert($data);
  589. }
  590. $this->success('基础信息提已提交等待审核');
  591. }
  592. /**
  593. * 合作商家列表
  594. */
  595. public function business(){
  596. $page = input('page',1);
  597. $page_num = input('page_num',5);
  598. $list = Db::name('store_business')
  599. ->order('id','DESC')
  600. ->paginate($page_num,'',['page'=>$page]);
  601. $this->success('合作商家列表',$list);
  602. }
  603. /*
  604. * 定时任务
  605. */
  606. public function disable_time(){
  607. $time = time();
  608. $list = Db::name('store_member')->where('vip_level',2)->where('disable_time','<',$time)->select();
  609. foreach ($list as &$v){
  610. Db::name('store_member')->where('id',$v['id'])->update(['vip_level'=>1,'disable_time'=>0]);
  611. }
  612. }
  613. /*
  614. * 会员推荐
  615. */
  616. public function recommend(){
  617. $user_id = 43;
  618. $ids = Db::name('store_recommend')->where('m_id',$user_id)->find();
  619. if(empty($ids['tuijian'])){
  620. $this->error('没有数据');
  621. }
  622. $time_a = time()-$ids['createtime'];
  623. $time_b = 86400*getConfigValue('tuijian');
  624. if($time_a>=$time_b){
  625. $sex = Db::name('store_member')->where('id',$user_id)->value('sex');
  626. if($sex==1) {
  627. $p_sex = 2;
  628. }
  629. else{
  630. $p_sex = 1;
  631. }
  632. $this->save_recommend($user_id,$p_sex);
  633. $ids = Db::name('store_recommend')->where('m_id',$user_id)->find();
  634. }
  635. $u_ids = explode(',',$ids['tuijian']);
  636. $list=[];
  637. foreach ($u_ids as $k=>$v){
  638. $list[$k]= Db::name('store_member')->where('id',$u_ids[$k])->field('id,sex,nickname,headimg,im_id')->select();
  639. }
  640. $this->success('推荐会员',$list);
  641. }
  642. public function save_recommend($user_id,$p_sex)
  643. {
  644. $data = Db::name('store_member_appeals')->where('mid', $user_id)->find();
  645. if ($data) {
  646. $education = json_decode(education($data['education']));
  647. $education = implode(',',$education);
  648. $height_a = $data['height']-2;
  649. $height_b = $data['height']+2;
  650. $where[] = ['age', 'between', [$data['age_min'], $data['age_max']]];
  651. $where[] = ['education', 'in', $education];
  652. $where[] = ['weight', '<', $data['weight']];
  653. $where[] = ['height', 'between', [$height_a, $height_b]];
  654. $where[] = ['income', '>=', $data['income']];
  655. $where[] = ['area_id', '=', $data['area_id']];
  656. $member = Db::name('store_member')
  657. ->where('sex', $p_sex)
  658. ->where('is_deleted', 1)
  659. ->where($where)
  660. ->orderRaw('rand()')
  661. ->limit(3)
  662. ->field('id')
  663. ->select();
  664. $array = [];
  665. foreach ($member as $k => $v) {
  666. $array[$k] = $member[$k]['id'];
  667. }
  668. $tuijian = implode(',', $array);
  669. $is_have = Db::name('store_recommend')->where('m_id', $user_id)->find();
  670. if ($is_have) {
  671. Db::name('store_recommend')->where('m_id', $user_id)->update(['tuijian' => $tuijian, 'createtime' => time()]);
  672. } else {
  673. Db::name('store_recommend')->insert(['m_id' => $user_id, 'tuijian' => $tuijian, 'createtime' => time()]);
  674. }
  675. }
  676. }
  677. public function notice1(){
  678. $user_id = 43;
  679. $p_sex = 1;
  680. $data = Db::name('store_member_appeals')->where('mid', $user_id)->find();
  681. if ($data) {
  682. $education = json_decode(education($data['education']));
  683. $education = implode(',',$education);
  684. $height_a = $data['height']-2;
  685. $height_b = $data['height']+2;
  686. $where[] = ['age', 'between', [$data['age_min'], $data['age_max']]];
  687. $where[] = ['education', 'in', $education];
  688. $where[] = ['weight', '<', $data['weight']];
  689. $where[] = ['height', 'between', [$height_a, $height_b]];
  690. $where[] = ['income', '>=', $data['income']];
  691. $where[] = ['area_id', '=', $data['area_id']];
  692. $member = Db::name('store_member')
  693. ->where('sex', $p_sex)
  694. ->where('is_deleted', 1)
  695. ->where($where)
  696. ->orderRaw('rand()')
  697. ->limit(3)
  698. ->field('id')
  699. ->select();
  700. $array = [];
  701. foreach ($member as $k => $v) {
  702. $array[$k] = $member[$k]['id'];
  703. }
  704. $tuijian = implode(',', $array);
  705. $is_have = Db::name('store_recommend')->where('m_id', $user_id)->find();
  706. if ($is_have) {
  707. Db::name('store_recommend')->where('m_id', $user_id)->update(['tuijian' => $tuijian, 'createtime' => time()]);
  708. } else {
  709. Db::name('store_recommend')->insert(['m_id' => $user_id, 'tuijian' => $tuijian, 'createtime' => time()]);
  710. }
  711. }
  712. }
  713. }