JiamengController.php 14 KB

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