You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

275 lines
11 KiB

7 years ago
  1. <?php
  2. namespace App\Http\Controllers\Home;
  3. use App\Http\Controllers\Home\CommonController;
  4. use Illuminate\Support\Facades\DB;
  5. class IndexController extends CommonController
  6. {
  7. public function __construct()
  8. {
  9. parent::__construct();
  10. }
  11. //首页
  12. public function index()
  13. {
  14. //商品列表
  15. $where['status'] = 0;
  16. $data['goods_list'] = object_to_array(DB::table('goods')->where($where)->select('id','title','price','litpic','description','shipping_fee','market_price','goods_number','sale')->take(30)->orderBy('pubdate','desc')->get());
  17. $data['goods_type_list'] = object_to_array(DB::table('goods_type')->where(['pid'=>0,'status'=>1])->select('id','name')->take(30)->orderBy('listorder','asc')->get());
  18. $data['slide_list'] = object_to_array(DB::table('slide')->where(['group_id'=>0,'type'=>0,'is_show'=>0])->take(30)->orderBy('listorder','asc')->get());
  19. $data['ztad_list'] = object_to_array(DB::table('slide')->where(['group_id'=>1,'type'=>0,'is_show'=>0])->take(30)->orderBy('listorder','asc')->get());
  20. return view('home.index.index',$data);
  21. }
  22. //列表页
  23. public function category($cat, $page=0)
  24. {
  25. $pagenow = $page;
  26. if(empty($cat) || !preg_match('/[0-9]+/',$cat)){return redirect()->route('page404');}
  27. if(cache("catid$cat")){$post = cache("catid$cat");}else{$post = object_to_array(DB::table('arctype')->where('id', $cat)->first(), 1);if(empty($post)){return redirect()->route('page404');} cache(["catid$cat"=>$post], \Carbon\Carbon::now()->addMinutes(2592000));}
  28. $data['post'] = $post;
  29. $subcat="";$sql="";
  30. $post2 = object_to_array(DB::table('arctype')->select('id')->where('pid', $cat)->get());
  31. if(!empty($post2)){foreach($post2 as $row){$subcat=$subcat."typeid=".$row["id"]." or ";}}
  32. $subcat=$subcat."typeid=".$cat;
  33. $sql=$subcat." or typeid2 in (".$cat.")";//echo $subcat2;exit;
  34. $data['sql'] = $sql;
  35. $counts = DB::table("article")->whereRaw($sql)->count();
  36. if($counts>sysconfig('CMS_MAXARC')){$counts=sysconfig('CMS_MAXARC');dd($counts);}
  37. $pagesize = sysconfig('CMS_PAGESIZE');$page=0;
  38. if($counts % $pagesize){//取总数据量除以每页数的余数
  39. $pages = intval($counts/$pagesize) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一,如果没有余数,则页数等于总数据量除以每页数的结果
  40. }else{$pages = $counts/$pagesize;}
  41. if(!empty($pagenow)){if($pagenow==1 || $pagenow>$pages){return redirect()->route('page404');}$page = $pagenow-1;$nextpage=$pagenow+1;$previouspage=$pagenow-1;}else{$page = 0;$nextpage=2;$previouspage=0;}
  42. $data['page'] = $page;
  43. $data['pages'] = $pages;
  44. $data['counts'] = $counts;
  45. $start = $page*$pagesize;
  46. $data['posts'] = arclist(array("sql"=>$sql, "limit"=>"$start,$pagesize")); //获取列表
  47. $data['pagenav'] = get_listnav(array("counts"=>$counts,"pagesize"=>$pagesize,"pagenow"=>$page+1,"catid"=>$cat)); //获取分页列表
  48. if($post['templist']=='category2'){if(!empty($pagenow)){return redirect()->route('page404');}}
  49. return view('home.index.'.$post['templist'], $data);
  50. }
  51. //文章详情页
  52. public function detail($id)
  53. {
  54. if(empty($id) || !preg_match('/[0-9]+/',$id)){return redirect()->route('page404');}
  55. if(cache("detailid$id")){$post = cache("detailid$id");}else{$post = object_to_array(DB::table('article')->where('id', $id)->first(), 1);if(empty($post)){return redirect()->route('page404');}$post['name'] = DB::table('arctype')->where('id', $post['typeid'])->value('name');cache(["detailid$id"=>$post], \Carbon\Carbon::now()->addMinutes(2592000));}
  56. if($post)
  57. {
  58. $cat = $post['typeid'];
  59. $post['body'] = ReplaceKeyword($post['body']);
  60. if(!empty($post['writer'])){$post['writertitle']=$post['title'].' '.$post['writer'];}
  61. $data['post'] = $post;
  62. $data['pre'] = get_article_prenext(array('aid'=>$post["id"],'typeid'=>$post["typeid"],'type'=>"pre"));
  63. }
  64. else
  65. {
  66. return redirect()->route('page404');
  67. }
  68. if(cache("catid$cat")){$post=cache("catid$cat");}else{$post = object_to_array(DB::table('arctype')->where('id', $cat)->first(), 1);cache(["catid$cat"=>$post], \Carbon\Carbon::now()->addMinutes(2592000));}
  69. return view('home.index.'.$post['temparticle'], $data);
  70. }
  71. //标签详情页,共有3种显示方式,1正常列表,2列表显示文章,3显示描述
  72. public function tag($tag, $page=0)
  73. {
  74. $pagenow = $page;
  75. if(empty($tag) || !preg_match('/[0-9]+/',$tag)){return redirect()->route('page404');}
  76. $post = object_to_array(DB::table('tagindex')->where('id',$tag)->first(), 1);
  77. $data['post'] = $post;
  78. $counts=DB::table("taglist")->where('tid',$tag)->count('aid');
  79. if($counts>sysconfig('CMS_MAXARC')){$counts=sysconfig('CMS_MAXARC');}
  80. $pagesize=sysconfig('CMS_PAGESIZE');$page=0;
  81. if($counts % $pagesize){//取总数据量除以每页数的余数
  82. $pages = intval($counts/$pagesize) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一,如果没有余数,则页数等于总数据量除以每页数的结果
  83. }else{$pages = $counts/$pagesize;}
  84. if(!empty($pagenow)){if($pagenow==1 || $pagenow>$pages){return redirect()->route('page404');}$page = $pagenow-1;$nextpage=$pagenow+1;$previouspage=$pagenow-1;}else{$page = 0;$nextpage=2;$previouspage=0;}
  85. $data['page'] = $page;
  86. $data['pages'] = $pages;
  87. $data['counts'] = $counts;
  88. $start=$page*$pagesize;
  89. $posts=object_to_array(DB::table("taglist")->where('tid',$tag)->orderBy('aid', 'desc')->skip($start)->take($pagesize)->get());
  90. foreach($posts as $row)
  91. {
  92. $aid[] = $row["aid"];
  93. }
  94. $aid = isset($aid)?implode(',',$aid):"";
  95. if($aid!="")
  96. {
  97. if($post['template']=='tag2')
  98. {
  99. $data['posts'] = arclist(array("sql"=>"id in ($aid)","orderby"=>['id', 'desc'],"row"=>"$pagesize","field"=>"title,body")); //获取列表
  100. }
  101. else
  102. {
  103. $data['posts'] = arclist(array("sql"=>"id in ($aid)","orderby"=>['id', 'desc'],"row"=>"$pagesize")); //获取列表
  104. }
  105. }
  106. else
  107. {
  108. $data['posts'] = ''; //获取列表
  109. }
  110. $data['pagenav'] = get_listnav(array("counts"=>$counts,"pagesize"=>$pagesize,"pagenow"=>$page+1,"catid"=>$tag,"urltype"=>"tag")); //获取分页列表
  111. if($post['template']=='tag2' || $post['template']=='tag3'){if(!empty($pagenow)){return redirect()->route('page404');}}
  112. return view('home.index.'.$post['template'], $data);
  113. }
  114. //标签页
  115. public function tags()
  116. {
  117. return view('home.index.tags');
  118. }
  119. //搜索页
  120. public function search($keyword)
  121. {
  122. if(empty($keyword))
  123. {
  124. echo '请输入正确的关键词';exit;
  125. }
  126. if(strstr($keyword,"&")) exit;
  127. $data['posts']= object_to_array(DB::table("article")->where("title", "like", "%$keyword%")->orderBy('id', 'desc')->take(30)->get());
  128. $data['keyword']= $keyword;
  129. return view('home.index.search', $data);
  130. }
  131. //单页面
  132. public function page($id)
  133. {
  134. $data = [];
  135. if(!empty($id) && preg_match('/[a-z0-9]+/',$id))
  136. {
  137. $map['filename']=$id;
  138. if(cache("pageid$id")){$post=cache("pageid$id");}else{$post = object_to_array(DB::table('page')->where($map)->first(), 1);cache("pageid$id", $post, 2592000);cache(["pageid$id"=>$post], \Carbon\Carbon::now()->addMinutes(2592000));}
  139. if($post)
  140. {
  141. $data['post'] = $post;
  142. }
  143. else
  144. {
  145. return redirect()->route('page404');
  146. }
  147. }
  148. else
  149. {
  150. return redirect()->route('page404');
  151. }
  152. $data['posts'] = object_to_array(DB::table('page')->orderBy(\DB::raw('rand()'))->take(5)->get());
  153. return view('home.index.'.$post['template'], $data);
  154. }
  155. //商品列表页
  156. public function goodstype($cat, $page=0)
  157. {
  158. $pagenow = $page;
  159. if(empty($cat) || !preg_match('/[0-9]+/',$cat)){return redirect()->route('page404');}
  160. $post = object_to_array(DB::table('goods_type')->where('id', $cat)->first(), 1);if(empty($post)){return redirect()->route('page404');}
  161. $data['post'] = $post;
  162. $subcat="";
  163. $post2 = object_to_array(DB::table('goods_type')->select('id')->where('pid', $cat)->get());
  164. if(!empty($post2)){foreach($post2 as $row){$subcat=$subcat."typeid=".$row["id"]." or ";}}
  165. $subcat=$subcat."typeid=".$cat;
  166. $data['sql'] = $subcat;
  167. $counts = DB::table("goods")->whereRaw($subcat)->count();
  168. if($counts>sysconfig('CMS_MAXARC')){$counts=sysconfig('CMS_MAXARC');dd($counts);}
  169. $pagesize = sysconfig('CMS_PAGESIZE');$page=0;
  170. if($counts % $pagesize){//取总数据量除以每页数的余数
  171. $pages = intval($counts/$pagesize) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一,如果没有余数,则页数等于总数据量除以每页数的结果
  172. }else{$pages = $counts/$pagesize;}
  173. if(!empty($pagenow)){if($pagenow==1 || $pagenow>$pages){return redirect()->route('page404');}$page = $pagenow-1;$nextpage=$pagenow+1;$previouspage=$pagenow-1;}else{$page = 0;$nextpage=2;$previouspage=0;}
  174. $data['page'] = $page;
  175. $data['pages'] = $pages;
  176. $data['counts'] = $counts;
  177. $start = $page*$pagesize;
  178. $data['posts'] = arclist(array("table"=>"goods","sql"=>$subcat, "limit"=>"$start,$pagesize")); //获取列表
  179. $data['pagenav'] = get_listnav(array("counts"=>$counts,"pagesize"=>$pagesize,"pagenow"=>$page+1,"catid"=>$cat,"urltype"=>"goods")); //获取分页列表
  180. if($post['templist']=='category2'){if(!empty($pagenow)){return redirect()->route('page404');}}
  181. return view('home.index.'.$post['templist'], $data);
  182. }
  183. //商品详情页
  184. public function goods($id)
  185. {
  186. if(empty($id) || !preg_match('/[0-9]+/',$id)){return redirect()->route('page404');}
  187. $post = object_to_array(DB::table('goods')->where('id', $id)->first(), 1);if(empty($post)){return redirect()->route('page404');}$post['name'] = DB::table('goods_type')->where('id', $post['typeid'])->value('name');
  188. if($post)
  189. {
  190. $cat = $post['typeid'];
  191. if(!empty($post['writer'])){$post['writertitle']=$post['title'].' '.$post['writer'];}
  192. $data['post'] = $post;
  193. $data['pre'] = get_article_prenext(array('aid'=>$post["id"],'typeid'=>$post["typeid"],'type'=>"pre"));
  194. }
  195. else
  196. {
  197. return redirect()->route('page404');
  198. }
  199. $post = object_to_array(DB::table('goods_type')->where('id', $cat)->first(), 1);
  200. return view('home.index.goods', $data);
  201. }
  202. //sitemap页面
  203. public function sitemap()
  204. {
  205. return view('home.index.sitemap');
  206. }
  207. //404页面
  208. public function page404()
  209. {
  210. return view('home.404');
  211. }
  212. //测试页面
  213. public function test()
  214. {return view('home.index.test');
  215. //return base_path('resources/org');
  216. //$qrcode = new \SimpleSoftwareIO\QrCode\BaconQrCodeGenerator;
  217. //return $qrcode->size(500)->generate('Make a qrcode without Laravel!');
  218. //return '<img src="data:image/png;base64,'.base64_encode(\QrCode::format('png')->encoding('UTF-8')->size(200)->generate('http://www.72p.org/')).'">';
  219. //set_exception_handler('myException');
  220. //return uniqid();
  221. //return \App\Common\Helper::formatPrice(1.2346);
  222. }
  223. }