JiamengController.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421
  1. <?php
  2. namespace app\index\controller;
  3. use app\index\service\CategoryService;
  4. use app\index\service\IpService;
  5. use app\index\service\JiamengService;
  6. use app\index\service\LinkService;
  7. use app\index\service\MessageService;
  8. use app\index\service\PageService;
  9. use app\index\service\RedisService;
  10. use cmf\controller\HomeBaseController;
  11. use think\Db;
  12. class JiamengController extends HomeBaseController
  13. {
  14. public function index()
  15. {
  16. return $this->fetch();
  17. }
  18. public function home(){
  19. //二级分类
  20. $param = $this->request->param();
  21. isset($param['enname']) or $this->error('需要父分类');
  22. $curarr = Db::name('category')->where('enname',$param['enname'])->find();
  23. if($curarr['parent_id']>0){
  24. header("Location:".url('/404'));
  25. exit;
  26. }
  27. $sonarr = Db::name('category')->where('parent_id',$curarr['id'])->order('list_order')->limit(10)->select();
  28. $this->assign('sonarr',$sonarr);
  29. return $this->fetch();
  30. }
  31. public function category(){
  32. return $this->fetch();
  33. }
  34. /**
  35. * 列表
  36. * @return mixed
  37. * @throws \think\db\exception\DataNotFoundException
  38. * @throws \think\db\exception\ModelNotFoundException
  39. * @throws \think\exception\DbException
  40. */
  41. public function lists(){
  42. $param = $this->request->param();
  43. //var_dump($param);die();
  44. $enname = isset($param['enname'])? trim($param['enname']) : '';
  45. $pcid = isset($param['pcid'])? intval($param['pcid']) : 0;
  46. $param = [
  47. 'kw'=> isset($param['kw'])? trim($param['kw']) : '',
  48. 'enname'=> isset($param['enname'])? trim($param['enname']) : '',
  49. 'catid'=> isset($param['catid'])? intval($param['catid']) : 0,
  50. 'pcid'=> isset($param['pcid'])? intval($param['pcid']) : 0,
  51. 'lv'=> isset($param['lv'])? intval($param['lv']) : '-1',
  52. 'aid'=> isset($param['aid'])? intval($param['aid']) : 0,
  53. ];
  54. $sonid = 0;
  55. if($enname || $pcid){
  56. $where = [];
  57. if($enname){
  58. $where['enname'] = $enname;
  59. }
  60. if($pcid){
  61. $where['id'] = $pcid;
  62. }
  63. $cateData = Db::name('category')->where($where)->find();
  64. $this->assign('hangye',$cateData['catname']);
  65. $enname = isset($cateData['enname'])? $cateData['enname'] : '';
  66. $param['sid'] = $cateData['parent_id']? $cateData['id'] : 0;
  67. $param['pid'] = $cateData['parent_id']? $cateData['parent_id'] : $cateData['id'];
  68. $seo_title = str_replace('|',$cateData['catname'],$cateData['seo_title']);
  69. $seo_keywords = str_replace('|',$cateData['catname'],$cateData['seo_keywords']);
  70. $seo_desc = str_replace('|',$cateData['catname'],$cateData['seo_desc']);
  71. $this->assign('catname',$cateData['catname']);
  72. $this->assign('seo_title',$seo_title);
  73. $this->assign('seo_keywords',$seo_keywords);
  74. $this->assign('seo_desc',$seo_desc);
  75. }else{
  76. $param['sid'] = 0;
  77. $param['pid'] = 0;
  78. }
  79. // echo $seo_title;die();
  80. if($param['pid']){
  81. $sonlist = Db::name('category')->where('parent_id',$param['pid'])->select();
  82. }else{
  83. $sonlist = Db::name('category')->where('parent_id','gt',0)->order('list_order')->limit(20)->select();
  84. }
  85. $param['pageType'] = 1;
  86. $result = JiamengService::getList($param);
  87. $page = $result->render();
  88. // 参数
  89. $touziarr = config('params.touziLevels');
  90. $areaList = config('params.areaList');
  91. $cateList = CategoryService::getCates();
  92. // 获取最新品牌
  93. $brandNews = JiamengService::getNewList(10);
  94. //加盟排行
  95. $paihang = JiamengService::getHotList(18);
  96. $result = $result? $result->toArray() : [];
  97. $lists = isset($result['data'])? $result['data'] : [];
  98. foreach ($lists as &$item){
  99. $touziLevel = isset($item['touzi_level']) ? $item['touzi_level'] : '-1';
  100. $item['touzi_level_name'] = isset($touziarr[$touziLevel]) ? $touziarr[$touziLevel] : '';
  101. $areaId = isset($item['area_id']) && $item['area_id']>0? intval($item['area_id']) : '-1';
  102. $item['area_name'] = isset($areaList[$areaId]) ? $areaList[$areaId] : '';
  103. }
  104. // 友情链接
  105. $links = [];
  106. if($enname){
  107. $links = LinkService::getList(['catname'=> $enname], 50);
  108. }
  109. //通过传入的参数获取中文
  110. $this->assign('dtite',$page);
  111. // var_dump($param);die();
  112. $this->assign('page',$page);
  113. $this->assign('data',$result);
  114. $this->assign('lists', $lists);
  115. $this->assign('paihang',$paihang);
  116. $this->assign('param',$param);
  117. $this->assign('brandNews',$brandNews);
  118. $this->assign('touziarr',$touziarr);
  119. $this->assign('areaList',$areaList);
  120. $this->assign('cateList',$cateList);
  121. $this->assign('sonlist',$sonlist);
  122. $this->assign('links',$links);
  123. return $this->fetch('list');
  124. }
  125. /**
  126. * 搜索
  127. * @return mixed
  128. * @throws \think\db\exception\DataNotFoundException
  129. * @throws \think\db\exception\ModelNotFoundException
  130. * @throws \think\exception\DbException
  131. */
  132. public function search(){
  133. $param = $this->request->param();
  134. $result = JiamengService::getList($param);
  135. $page = $result->render();
  136. // 参数
  137. $touziarr = config('params.touziLevels');
  138. $areaList = config('params.areaList');
  139. $cateList = CategoryService::getCates();
  140. // 获取最新品牌
  141. $brandNews = JiamengService::getNewList(10);
  142. //加盟排行
  143. $paihang = JiamengService::getHotList(18);
  144. $param = [
  145. 'kw'=> isset($param['kw'])? trim($param['kw']) : '',
  146. 'enname'=> isset($param['enname'])? trim($param['enname']) : '',
  147. 'catid'=> isset($param['catid'])? intval($param['catid']) : 0,
  148. 'pcid'=> isset($param['pcid'])? intval($param['pcid']) : 0,
  149. 'lv'=> isset($param['lv'])? intval($param['lv']) : '-1',
  150. 'aid'=> isset($param['aid'])? intval($param['aid']) : 0,
  151. ];
  152. $result = $result? $result->toArray() : [];
  153. $lists = isset($result['data'])? $result['data'] : [];
  154. foreach ($lists as &$item){
  155. $touziLevel = isset($item['touzi_level']) ? $item['touzi_level'] : '-1';
  156. $areaId = isset($item['area_id']) ? $item['area_id'] : '-1';
  157. $item['touzi_level_name'] = isset($touziarr[$touziLevel]) ? $touziarr[$touziLevel] : '';
  158. $item['area_name'] = isset($areaList[$areaId]) && $item['area_id']>0? $areaList[$areaId] : '';
  159. }
  160. $enname = isset($param['enname'])? trim($param['enname']) : '';
  161. if($enname){
  162. $pcatid = Db::name('category')->where('enname', $enname)->value('id');
  163. }
  164. $pcid = isset($param['pcid']) ? intval($param['pcid']) : 0;
  165. $pcid = $pcid>0? $pcid : $pcatid;
  166. if($pcid){
  167. $cateData = Db::name('category')->where('id', $pcid)->find();
  168. $enname = isset($cateData['enname'])? $cateData['enname'] : '';
  169. $param['sid'] = $cateData['parent_id']? $cateData['id'] : 0;
  170. $param['pid'] = $cateData['parent_id']? $cateData['parent_id'] : $cateData['id'];
  171. $seo_title = str_replace('|',$cateData['catname'],$cateData['seo_title']);
  172. $seo_keywords = str_replace('|',$cateData['catname'],$cateData['seo_keywords']);
  173. $seo_desc = str_replace('|',$cateData['catname'],$cateData['seo_desc']);
  174. $this->assign('seo_title',$seo_title);
  175. $this->assign('seo_keywords',$seo_keywords);
  176. $this->assign('seo_desc',$seo_desc);
  177. }else{
  178. $param['sid'] = 0;
  179. $param['pid'] = 0;
  180. }
  181. if($param['pid']){
  182. $sonlist = Db::name('category')->where('parent_id',$param['pid'])->select();
  183. }else{
  184. $sonlist = Db::name('category')->where('parent_id','gt',0)->order('list_order')->limit(20)->select();
  185. }
  186. // 友情链接
  187. $links = [];
  188. if($enname){
  189. $links = LinkService::getList(['catname'=> $enname], 50);
  190. }
  191. $this->assign('page',$page);
  192. $this->assign('data',$result);
  193. $this->assign('lists', $lists);
  194. $this->assign('paihang',$paihang);
  195. $this->assign('param',$param);
  196. $this->assign('brandNews',$brandNews);
  197. $this->assign('touziarr',$touziarr);
  198. $this->assign('areaList',$areaList);
  199. $this->assign('cateList',$cateList);
  200. $this->assign('sonlist',$sonlist);
  201. $this->assign('links',$links);
  202. return $this->fetch();
  203. }
  204. /**
  205. * 详情
  206. * @return mixed
  207. * @throws \think\db\exception\DataNotFoundException
  208. * @throws \think\db\exception\ModelNotFoundException
  209. * @throws \think\exception\DbException
  210. */
  211. public function show(){
  212. $param = $this->request->param();
  213. isset($param['id']) or $this->error('需要id');
  214. $cacheKey = "cache:jiameng:show:id_".intval($param['id']);
  215. $datas = RedisService::get($cacheKey);
  216. $info = isset($datas['info'])? $datas['info'] : [];
  217. $touziarr = config('params.touziLevels');
  218. if(empty($info) || empty($datas)){
  219. $info = Db::name('jiameng')
  220. ->where('id',$param['id'])
  221. ->where('status', 1)
  222. ->find();
  223. if(empty($info)){
  224. header("Location:".url('/404'));
  225. exit;
  226. }
  227. //内容
  228. $content = Db::name('jiameng_data')->where('id',$param['id'])->find();
  229. $info['content'] = $content['content'];
  230. $info['youshi'] = $content['youshi'];
  231. $info['tiaojian'] = $content['tiaojian'];
  232. $info['liucheng'] = $content['liucheng'];
  233. $jmSupport = [];
  234. $supports = config('params.supports');
  235. $support = isset($info['jm_support']) && $info['jm_support']? explode(',', $info['jm_support']) : [];
  236. foreach ($support as $val){
  237. $name = isset($supports[$val])? $supports[$val] : '';
  238. if($name){
  239. $jmSupport[] = $name;
  240. }
  241. }
  242. unset($supports[0]);
  243. $info['jm_support'] = $jmSupport? $jmSupport : $supports;
  244. $areaList = config('params.areaList');
  245. $areaId = isset($info['area_id']) && $info['area_id']? intval($info['area_id']) : '-1';
  246. $area = isset($areaList[$areaId])? $areaList[$areaId] : '不限';
  247. $info['area'] = $info['area']? $info['area'] : $area;
  248. $catinfo = Db::name('category')->where('id',$info['catid'])->find();
  249. $parinfo = Db::name('category')->where('id',$catinfo['parent_id'])->find();
  250. //热门行业
  251. $hot_cate = Db::name('category')->where('parent_id',$parinfo['id'])->order('list_order')->limit(12)->select();
  252. //排行
  253. $paihang = Db::name('jiameng')->field('id,title,logo,touzi_level,mendian,hits')->where('catid',$info['catid'])->where('status', 1)->order('hits desc')->limit(5)->select();
  254. //动态
  255. $about_news = Db::name('news')->field('id,title,thumb,create_time')->where(['ncatid'=>1,'status'=> 1])->order('id desc')->limit(6)->select();
  256. $brand_news = Db::name('news')->field('id,title,thumb,create_time')->where(['catid'=>$info['catid'],'status'=> 1])->order('id desc')->limit(6)->select();
  257. //热门加盟
  258. $hot_jm = Db::name('jiameng')->field('id,title,hits')->where('catid',$info['catid'])->where('status', 1)->order('hits desc')->limit(20)->select();
  259. //最新加盟
  260. $zx_jm = $brand8 = JiamengService::getNewList(20);
  261. //精选加盟
  262. $jx_jm = Db::name('jiameng')
  263. ->field('id,title')
  264. ->where('catid',$info['catid'])
  265. ->where('status', 1)
  266. ->orderRaw('rand()')->limit(20)->select();
  267. $datas = [
  268. 'info'=> $info,
  269. 'catinfo'=> $catinfo,
  270. 'hot_jm'=> $hot_jm,
  271. 'zx_jm'=> $zx_jm,
  272. 'jx_jm'=> $jx_jm,
  273. 'about_news'=> $about_news,
  274. 'brand_news'=> $brand_news,
  275. 'paihang'=> $paihang,
  276. 'hot_cate'=> $hot_cate,
  277. 'parinfo'=> $parinfo,
  278. ];
  279. // 缓存
  280. RedisService::set($cacheKey, $datas, 2*3600);
  281. }else{
  282. $catinfo = isset($datas['catinfo'])? $datas['catinfo'] : [];
  283. $hot_jm = isset($datas['hot_jm'])? $datas['hot_jm'] : [];
  284. $zx_jm = isset($datas['zx_jm'])? $datas['zx_jm'] : [];
  285. $jx_jm = isset($datas['jx_jm'])? $datas['jx_jm'] : [];
  286. $about_news = isset($datas['about_news'])? $datas['about_news'] : [];
  287. $brand_news = isset($datas['brand_news'])? $datas['brand_news'] : [];
  288. $paihang = isset($datas['paihang'])? $datas['paihang'] : [];
  289. $hot_cate = isset($datas['hot_cate'])? $datas['hot_cate'] : [];
  290. $parinfo = isset($datas['parinfo'])? $datas['parinfo'] : [];
  291. }
  292. //seo
  293. $seo_title = str_replace('|',$info['title'],$catinfo['seo_title']);
  294. $seo_keywords = str_replace('|',$info['title'],$catinfo['seo_keywords']);
  295. $seo_desc = trim(strip_tags($info['content']));
  296. $seo_desc = mb_substr($seo_desc,0,200,'utf8');
  297. $this->assign('seo_title',$seo_title);
  298. $this->assign('seo_keywords',$seo_keywords);
  299. $this->assign('seo_desc',$seo_desc);
  300. $this->assign('hot_jm',$hot_jm);
  301. $this->assign('zx_jm',$zx_jm);
  302. $this->assign('jx_jm',$jx_jm);
  303. $this->assign('about_news',$about_news);
  304. $this->assign('brand_news',$brand_news);
  305. $this->assign('paihang',$paihang);
  306. $this->assign('hot_cate',$hot_cate);
  307. $this->assign('touziarr',$touziarr);
  308. $this->assign('catinfo',$catinfo);
  309. $this->assign('parinfo',$parinfo);
  310. $this->assign('info',$info);
  311. return $this->fetch();
  312. }
  313. public function message(){
  314. $param = $this->request->param();
  315. $orignUrl = $this->request->header('origin');
  316. // isset($param['name'])&&$param['name']!='' or $this->error('请填写姓名');
  317. isset($param['mobile'])&&$param['mobile']!='' or $this->error('请填写手机号');
  318. $param['create_time'] = time();
  319. $param['ip'] = get_client_ip();
  320. $param['address'] = IpService::getAddress(get_client_ip());
  321. $todaytime = strtotime(date('Y-m-d'));
  322. if(strlen($param['content'])>300){
  323. $this->error('字符长度不超过300个');
  324. exit;
  325. }
  326. if(isset($param['tzed']) && $param['tzed']<=0){
  327. $this->error('请选择投资额度');
  328. exit;
  329. }
  330. $param['content'] = strFilter($param['content']);
  331. $param['name'] = strFilter($param['name']);
  332. $param['mobile'] = strFilter($param['mobile']);
  333. $param['tzed'] = strFilter($param['tzed']);
  334. $param['area'] = strFilter($param['area']);
  335. $param['wechat'] = strFilter($param['wechat']);
  336. $param['type'] = 1;
  337. $param['source_url'] = $orignUrl;
  338. // print_r($param);exit;
  339. //判断是否已超过10次 今天这个ip是否留言过
  340. /* $sum = MessageService::getTodyCount(['ip'=> $param['ip'],'type'=> 1]);
  341. if($sum>0){
  342. $this->error('今日留言已超过1次,明天再来吧!');
  343. }
  344. //判断手机号本周内是否留过
  345. $sum = MessageService::getWeekCount(['mobile'=> $param['mobile'],'type'=> 1]);
  346. if($sum>0){
  347. $this->error('您的手机号在本周内已预留过,下周再来吧!');
  348. }*/
  349. $week_time=time()-604800;
  350. $res_mobile=Db::name('message')->where('mobile',$param['mobile'])->where('create_time','>',$week_time)->find();
  351. if($res_mobile)
  352. {
  353. $this->error('手机号码一个周内只能留一次');
  354. }
  355. $ip=get_client_ip();
  356. $start_time=strtotime(date('Y-m-d') );
  357. $ip_count=Db::name('message')->where('ip',$ip)->where('create_time','>',$start_time)->count();
  358. if($ip_count>1)
  359. {
  360. $this->error('同一个ip一天只可以留言2次');
  361. }
  362. $res = Db::name('message')->insert($param);
  363. if($res){
  364. $this->success('咨询成功');
  365. }else{
  366. $this->error('咨询失败');
  367. }
  368. }
  369. }
  370. ?>