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.

287 lines
11 KiB

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