* Date: 2018-4-3 */ namespace app\admin\controller; use think\Page; use think\Db; class Custom extends Base { // 模型标识 public $nid = ''; // 模型ID public $channeltype = 0; // 模型附加表 public $table = ''; /* * 初始化操作 */ public function _initialize() { parent::_initialize(); $this->archives_db = Db::name('archives'); $this->channeltype = input('param.channel/d', 0); $channeltypeRow = Db::name('channeltype')->field('nid,table')->where(['id'=>['eq',$this->channeltype]])->find(); if (empty($this->channeltype) || empty($channeltypeRow)) { $this->error('自定义模型ID丢失,打开失败!'); } $this->nid = $channeltypeRow['nid']; $this->table = $channeltypeRow['table']; $this->assign('nid', $this->nid); $this->assign('table', $this->table); $this->assign('channeltype', $this->channeltype); // 返回页面 $paramTypeid = input('param.typeid/d', 0); $this->callback_url = url('Custom/index', ['lang' => $this->admin_lang, 'channel'=>$this->channeltype, 'typeid' => $paramTypeid]); $this->assign('callback_url', $this->callback_url); } //列表 public function index() { $assign_data = $condition = []; // 获取到所有GET参数 $param = input('param.'); $typeid = input('typeid/d', 0); // 搜索、筛选查询条件处理 foreach (['keywords', 'typeid', 'flag', 'is_release','province_id','city_id','area_id'] as $key) { if ($key == 'typeid' && empty($param['typeid'])) { $typeids = Db::name('arctype')->where('current_channel', $this->channeltype)->column('id'); $condition['a.typeid'] = array('IN', $typeids); } if (isset($param[$key]) && $param[$key] !== '') { if ($key == 'keywords') { $keywords = $param[$key]; $condition['a.title'] = array('LIKE', "%{$param[$key]}%"); } else if ($key == 'typeid') { $typeid = $param[$key]; $hasRow = model('Arctype')->getHasChildren($typeid); $typeids = get_arr_column($hasRow, 'id'); // 权限控制 by 小虎哥 $admin_info = session('admin_info'); if (0 < intval($admin_info['role_id'])) { $auth_role_info = $admin_info['auth_role_info']; if (!empty($typeid) && !empty($auth_role_info) && !empty($auth_role_info['permission']['arctype'])) { $typeids = array_intersect($typeids, $auth_role_info['permission']['arctype']); } } $condition['a.typeid'] = array('IN', $typeids); } else if ($key == 'flag') { if ('is_release' == $param[$key]) { $condition['a.users_id'] = array('gt', 0); } else { $FlagNew = $param[$key]; $condition['a.'.$param[$key]] = array('eq', 1); } } else if (in_array($key, ['province_id','city_id','area_id'])) { if (!empty($param['area_id'])) { $condition['a.area_id'] = $param['area_id']; } else if (!empty($param['city_id'])) { $condition['a.city_id'] = $param['city_id']; } else if (!empty($param['province_id'])) { $condition['a.province_id'] = $param['province_id']; } } else { $condition['a.'.$key] = array('eq', $param[$key]); } } } // 权限控制 by 小虎哥 $admin_info = session('admin_info'); if (0 < intval($admin_info['role_id'])) { $auth_role_info = $admin_info['auth_role_info']; if (!empty($auth_role_info) && isset($auth_role_info['only_oneself']) && 1 == $auth_role_info['only_oneself']) { $condition['a.admin_id'] = $admin_info['admin_id']; } } // 时间检索条件 $begin = strtotime(input('add_time_begin')); $end = strtotime(input('add_time_end')); if ($begin > 0 && $end > 0) { $condition['a.add_time'] = array('between', "$begin, $end"); } else if ($begin > 0) { $condition['a.add_time'] = array('egt', $begin); } else if ($end > 0) { $condition['a.add_time'] = array('elt', $end); } // 必要条件 $condition['a.channel'] = array('eq', $this->channeltype); $condition['a.lang'] = array('eq', $this->admin_lang); $condition['a.is_del'] = array('eq', 0); $conditionNew = "(a.users_id = 0 OR (a.users_id > 0 AND a.arcrank >= 0))"; // 自定义排序 $orderby = input('param.orderby/s'); $orderway = input('param.orderway/s'); if (!empty($orderby) && !empty($orderway)) { $orderby = "a.{$orderby} {$orderway}, a.aid desc"; } else { $orderby = "a.aid desc"; } // 数据查询,搜索出主键ID的值 $SqlQuery = $this->archives_db->alias('a')->where($condition)->where($conditionNew)->fetchSql()->count('aid'); $count = Db::name('sql_cache_table')->where(['sql_md5'=>md5($SqlQuery)])->getField('sql_result'); $count = ($count < 0) ? 0 : $count; if (empty($count)) { $count = $this->archives_db->alias('a')->where($condition)->where($conditionNew)->count('aid'); /*添加查询执行语句到mysql缓存表*/ $SqlCacheTable = [ 'sql_name' => '|' . $this->table . '|' . $this->channeltype . '|', 'sql_result' => $count, 'sql_md5' => md5($SqlQuery), 'sql_query' => $SqlQuery, 'add_time' => getTime(), 'update_time' => getTime(), ]; if (!empty($FlagNew)) $SqlCacheTable['sql_name'] = $SqlCacheTable['sql_name'] . $FlagNew . '|'; if (!empty($typeid)) $SqlCacheTable['sql_name'] = $SqlCacheTable['sql_name'] . $typeid . '|'; if (!empty($keywords)) $SqlCacheTable['sql_name'] = '|custom|keywords|'; Db::name('sql_cache_table')->insertGetId($SqlCacheTable); /*END*/ } $Page = new Page($count, config('paginate.list_rows')); $list = []; if (!empty($count)) { $limit = $count > config('paginate.list_rows') ? $Page->firstRow.','.$Page->listRows : $count; $list = $this->archives_db ->field("a.aid") ->alias('a') ->where($condition) ->where($conditionNew) ->order($orderby) ->limit($limit) ->getAllWithIndex('aid'); if (!empty($list)) { $aids = array_keys($list); $fields = "b.*, a.*, a.aid as aid"; $row = $this->archives_db ->field($fields) ->alias('a') ->join('__ARCTYPE__ b', 'a.typeid = b.id', 'LEFT') ->where('a.aid', 'in', $aids) ->getAllWithIndex('aid'); foreach ($list as $key => $val) { $row[$val['aid']]['arcurl'] = get_arcurl($row[$val['aid']]); $row[$val['aid']]['litpic'] = handle_subdir_pic($row[$val['aid']]['litpic']); $list[$key] = $row[$val['aid']]; } } } $show = $Page->show(); $assign_data['page'] = $show; $assign_data['list'] = $list; $assign_data['pager'] = $Page; $assign_data['typeid'] = $typeid; $assign_data['tab'] = input('param.tab/d', 3);// 选项卡 $assign_data['archives_flags'] = model('ArchivesFlag')->getList();// 文档属性 $assign_data['arctype_info'] = $typeid > 0 ? Db::name('arctype')->field('typename')->find($typeid) : [];// 当前栏目信息 $this->assign($assign_data); return $this->fetch(); } /** * 添加 */ public function add() { $admin_info = session('admin_info'); $auth_role_info = $admin_info['auth_role_info']; $this->assign('auth_role_info', $auth_role_info); $this->assign('admin_info', $admin_info); if (IS_POST) { $post = input('post.'); model('Archives')->editor_auto_210607($post); /* 处理TAG标签 */ if (!empty($post['tags_new'])) { $post['tags'] = !empty($post['tags']) ? $post['tags'] . ',' . $post['tags_new'] : $post['tags_new']; unset($post['tags_new']); } $post['tags'] = explode(',', $post['tags']); $post['tags'] = array_unique($post['tags']); $post['tags'] = implode(',', $post['tags']); /* END */ /*获取第一个html类型的内容,作为文档的内容来截取SEO描述*/ $contentField = Db::name('channelfield')->where([ 'channel_id' => $this->channeltype, 'dtype' => 'htmltext', ])->getField('name'); $content = empty($post['addonFieldExt'][$contentField]) ? '' : htmlspecialchars_decode($post['addonFieldExt'][$contentField]); /*--end*/ // 根据标题自动提取相关的关键字 $seo_keywords = $post['seo_keywords']; if (!empty($seo_keywords)) { $seo_keywords = str_replace(',', ',', $seo_keywords); } else { // $seo_keywords = get_split_word($post['title'], $content); } // 自动获取内容第一张图片作为封面图 $is_remote = !empty($post['is_remote']) ? $post['is_remote'] : 0; $litpic = ''; if ($is_remote == 1) { $litpic = $post['litpic_remote']; } else { $litpic = $post['litpic_local']; } if (empty($litpic)) { $litpic = get_html_first_imgurl($content); } $post['litpic'] = $litpic; /*是否有封面图*/ if (empty($post['litpic'])) { $is_litpic = 0; // 无封面图 } else { $is_litpic = 1; // 有封面图 } // SEO描述 $seo_description = ''; if (empty($post['seo_description']) && !empty($content)) { $seo_description = @msubstr(checkStrHtml($content), 0, config('global.arc_seo_description_length'), false); } else { $seo_description = $post['seo_description']; } // 外部链接跳转 $jumplinks = ''; $is_jump = isset($post['is_jump']) ? $post['is_jump'] : 0; if (intval($is_jump) > 0) { $jumplinks = $post['jumplinks']; } // 模板文件,如果文档模板名与栏目指定的一致,默认就为空。让它跟随栏目的指定而变 if ($post['type_tempview'] == $post['tempview']) { unset($post['type_tempview']); unset($post['tempview']); } //处理自定义文件名,仅由字母数字下划线和短横杆组成,大写强制转换为小写 $htmlfilename = trim($post['htmlfilename']); if (!empty($htmlfilename)) { $htmlfilename = preg_replace("/[^\x{4e00}-\x{9fa5}\w\-]+/u", "-", $htmlfilename); // $htmlfilename = strtolower($htmlfilename); //判断是否存在相同的自定义文件名 $map = [ 'htmlfilename' => $htmlfilename, 'lang' => $this->admin_lang, ]; if (!empty($post['typeid'])) { $map['typeid'] = array('eq', $post['typeid']); } $filenameCount = Db::name('archives')->where($map)->count(); if (!empty($filenameCount)) { $this->error("同栏目下,自定义文件名已存在!"); } else if (preg_match('/^(\d+)$/i', $htmlfilename)) { $this->error("自定义文件名不能纯数字,会与文档ID冲突!"); } } else { // 处理外贸链接 if (is_dir('./weapp/Waimao/')) { $waimaoLogic = new \weapp\Waimao\logic\WaimaoLogic; $waimaoLogic->get_new_htmlfilename($htmlfilename, $post, 'add', $this->globalConfig); } } $post['htmlfilename'] = $htmlfilename; //做自动通过审核判断 if ($admin_info['role_id'] > 0 && $auth_role_info['check_oneself'] < 1) { $post['arcrank'] = -1; } // 副栏目 if (isset($post['stypeid'])) { $post['stypeid'] = preg_replace('/([^\d\,\,]+)/i', ',', $post['stypeid']); $post['stypeid'] = str_replace(',', ',', $post['stypeid']); $post['stypeid'] = trim($post['stypeid'], ','); $post['stypeid'] = str_replace(",{$post['typeid']},", ',', ",{$post['stypeid']},"); $post['stypeid'] = trim($post['stypeid'], ','); } //查询排序 等级 $sort_order = Db::name('archives')->where('aid','=',(int)$post['level_group_name'])->value('sort_order'); //var_dump($post['addonFieldExt']);die; $ext = ''; //获取文档文件后缀 if(!empty($post['addonFieldExt']['down_eyou_remote'])){ $file = explode('.',$post['addonFieldExt']['down_eyou_remote']); $ext = end($file); }else{ //$ext = ''; } if(!empty($post['addonFieldExt']['down_eyou_local'])){ $file = explode('.',$post['addonFieldExt']['down_eyou_local']); $ext = end($file); }else{ //$ext = ''; } // --存储数据 $newData = array( 'typeid'=> empty($post['typeid']) ? 0 : $post['typeid'], 'channel' => $this->channeltype, 'is_b' => empty($post['is_b']) ? 0 : $post['is_b'], 'is_head' => empty($post['is_head']) ? 0 : $post['is_head'], 'is_special' => empty($post['is_special']) ? 0 : $post['is_special'], 'is_recom' => empty($post['is_recom']) ? 0 : $post['is_recom'], 'is_roll' => empty($post['is_roll']) ? 0 : $post['is_roll'], 'is_slide' => empty($post['is_slide']) ? 0 : $post['is_slide'], 'is_diyattr' => empty($post['is_diyattr']) ? 0 : $post['is_diyattr'], 'editor_remote_img_local'=> empty($post['editor_remote_img_local']) ? 0 : $post['editor_remote_img_local'], 'editor_img_clear_link' => empty($post['editor_img_clear_link']) ? 0 : $post['editor_img_clear_link'], 'is_jump' => $is_jump, 'is_litpic' => $is_litpic, 'jumplinks' => $jumplinks, 'origin' => empty($post['origin']) ? '网络' : $post['origin'], 'seo_keywords' => $seo_keywords, 'seo_description' => $seo_description, 'admin_id' => session('admin_info.admin_id'), 'lang' => $this->admin_lang, 'sort_order' => 100, 'crossed_price' => empty($post['crossed_price']) ? 0 : floatval($post['crossed_price']), 'add_time' => strtotime($post['add_time']), 'update_time' => strtotime($post['add_time']), 'product_id' => (int)$post['product_id'], //增加 'lunwen_id' => (int)$post['lunwen_id'], //增加 'level_group_id' => (int)$post['level_group_id'], 'level_id' => (int)$post['level_group_name'], 'level' => (int)$sort_order, 'product_tag_id' => (int)$post['product_tag_id'], 'area_tag_id' => (int)$post['area_tag_id'], 'ext' => $ext ); $data = array_merge($post, $newData); $aid = $this->archives_db->insertGetId($data); $_POST['aid'] = $aid; if ($aid) { // ---------后置操作 model('Custom')->afterSave($aid, $data, 'add', $this->table); // 添加查询执行语句到mysql缓存表 model('SqlCacheTable')->InsertSqlCacheTable(); // ---------end adminLog('新增数据:'.$data['title']); //新增序列号 (论文期刊和论文模板) //只考虑新增场景 其他的用api修复 if((int)$newData['typeid'] === 116 || (int)$newData['typeid'] === 123 || (int)$newData['typeid'] === 127 || (int)$newData['typeid'] === 128){ $last = Db::name('seo_number')->where([ "type" => 4, "tid" => (int)$post['typeid'], 'topid' => 0, 'parentid' => 0, 'area_id' => 0, ])->order('number desc')->find(); if(empty($last['number'])){ $num = 1; }else{ $num = (int)$last['number'] + 1; } $in_data = [ "type" => 4, //产品类型 "aid" => $aid, //实际的ID "tid" => (int)$post['typeid'], //属于哪个栏目的 'is_del' => 0, 'is_kan' => 0, // 0正常 1审核 'status' => 1, 'area_id' => 0, 'topid' => 0, 'parentid' => 0, 'number' => $num ]; Db::name('seo_number')->insert($in_data); }else if((int)$newData['typeid'] === 371){ $last = Db::name('seo_number')->where([ "type" => 10, "tid" => (int)$post['typeid'], 'topid' => 0, 'parentid' => 0, 'area_id' => 0, ])->order('number desc')->find(); if(empty($last['number'])){ $num = 1; }else{ $num = (int)$last['number'] + 1; } $in_data = [ "type" => 10, //产品类型 "aid" => $aid, //实际的ID "tid" => (int)$post['typeid'], //属于哪个栏目的 'is_del' => 0, 'is_kan' => 0, // 0正常 1审核 'status' => 1, 'area_id' => 0, 'topid' => 0, 'parentid' => 0, 'number' => $num ]; Db::name('seo_number')->insert($in_data); //更新主记录 冗余 Db::name('archives') ->where(['aid'=>$aid]) ->update(['number'=>$num]); }else if((int)$newData['typeid'] === 126 || (int)$newData['typeid'] === 825 || (int)$newData['typeid'] === 826){ //资料文档 $last = Db::name('seo_number')->where([ "type" => 5, "tid" => (int)$post['typeid'], 'topid' => 0, 'parentid' => 0, 'area_id' => (int)$post['province_id'], //如果是0的话 后续也不能改 ])->order('number desc')->find(); if(empty($last['number'])){ $num = 1; }else{ $num = (int)$last['number'] + 1; } $in_data = [ "type" => 5, //产品类型 "aid" => $aid, //实际的ID "tid" => (int)$post['typeid'], //属于哪个栏目的 'is_del' => 0, 'is_kan' => 0, // 0正常 1审核 'status' => 1, 'area_id' => (int)$post['province_id'], 'topid' => 0, 'parentid' => 0, 'number' => $num ]; Db::name('seo_number')->insert($in_data); }else if((int)$newData['typeid'] === 120 || (int)$newData['typeid'] === 118 || (int)$newData['typeid'] === 122 || (int)$newData['typeid'] === 11100000 || (int)$newData['typeid'] === 133 || (int)$newData['typeid'] === 132 || (int)$newData['typeid'] === 131 || (int)$newData['typeid'] === 306){ //案例 申报 职称相关问题 常见问题汇总 历年真题题库 答辩问题汇总 防骗指南 职称补贴 $last = Db::name('seo_number')->where([ "type" => 2, "tid" => (int)$post['typeid'], 'topid' => 0, 'parentid' => 0, 'area_id' => 0, ])->order('number desc')->find(); if(empty($last['number'])){ $num = 1; }else{ $num = (int)$last['number'] + 1; } $in_data = [ "type" => 2, //文章类型 "aid" => $aid, //实际的ID "tid" => (int)$post['typeid'], //属于哪个栏目的 'is_del' => 0, 'is_kan' => 0, // 0正常 1审核 'status' => 1, 'area_id' => 0, 'topid' => 0, 'parentid' => 0, 'number' => $num ]; Db::name('seo_number')->insert($in_data); }else if((int)$newData['typeid'] === 115 || (int)$newData['typeid'] === 117 || (int)$newData['typeid'] === 111){ //政策资讯 //评审攻略 //常见问题 $where6 = [ "type" => 2, "tid" => (int)$post['typeid'], 'topid' => 0, 'parentid' => 0, 'area_id' => (int)$post['province_id'], //如果是0的话 后续也不能改 'city_id' => (int)$post['city_id'], //如果是0的话 后续也不能改 ]; /*if((int)$post['city_id'] > 0){ $where6['city_id'] = (int)$post['city_id']; }*/ //攻略和政策资讯 $last = Db::name('seo_number')->where($where6)->order('number desc')->find(); if(empty($last['number'])){ $num = 1; }else{ $num = (int)$last['number'] + 1; } $in_data = [ "type" => 2, //产品类型 "aid" => $aid, //实际的ID "tid" => (int)$post['typeid'], //属于哪个栏目的 'is_del' => 0, 'is_kan' => 0, // 0正常 1审核 'status' => 1, 'area_id' => (int)$post['province_id'], 'city_id' => (int)$post['city_id'], 'topid' => 0, 'parentid' => 0, 'number' => $num ]; Db::name('seo_number')->insert($in_data); }else if((int)$newData['typeid'] === 1231 || (int)$newData['typeid'] === 1233 || (int)$newData['typeid'] === 1234){ //新闻资讯 //业绩材料 //一键测评 $where6 = [ "type" => 2, "tid" => (int)$post['typeid'], 'topid' => 0, 'parentid' => 0, 'area_id' => 0, //(int)$post['province_id'] //如果是0的话 后续也不能改 'city_id' => 0, //(int)$post['city_id'] //如果是0的话 后续也不能改 ]; /*if((int)$post['city_id'] > 0){ $where6['city_id'] = (int)$post['city_id']; }*/ //攻略和政策资讯 $last = Db::name('seo_number')->where($where6)->order('number desc')->find(); if(empty($last['number'])){ $num = 1; }else{ $num = (int)$last['number'] + 1; } $in_data = [ "type" => 2, //产品类型 "aid" => $aid, //实际的ID "tid" => (int)$post['typeid'], //属于哪个栏目的 'is_del' => 0, 'is_kan' => 0, // 0正常 1审核 'status' => 1, 'area_id' => 0, //(int)$post['province_id'] 'city_id' => 0, //(int)$post['city_id'] 'topid' => 0, 'parentid' => 0, 'number' => $num ]; Db::name('seo_number')->insert($in_data); }else if((int)$newData['typeid'] === 1232){ //评审政策 //按区域 $where6 = [ "type" => 2, "tid" => (int)$post['typeid'], 'topid' => 0, 'parentid' => 0, 'area_id' => (int)$post['area_tag_id'], //(int)$post['province_id'] //如果是0的话 后续也不能改 'city_id' => 0, //(int)$post['city_id'] //如果是0的话 后续也不能改 ]; /*if((int)$post['city_id'] > 0){ $where6['city_id'] = (int)$post['city_id']; }*/ //攻略和政策资讯 $last = Db::name('seo_number')->where($where6)->order('number desc')->find(); if(empty($last['number'])){ $num = 1; }else{ $num = (int)$last['number'] + 1; } $in_data = [ "type" => 2, //产品类型 "aid" => $aid, //实际的ID "tid" => (int)$post['typeid'], //属于哪个栏目的 'is_del' => 0, 'is_kan' => 0, // 0正常 1审核 'status' => 1, 'area_id' => (int)$post['area_tag_id'], //(int)$post['province_id'] 'city_id' => 0, //(int)$post['city_id'] 'topid' => 0, 'parentid' => 0, 'number' => $num ]; Db::name('seo_number')->insert($in_data); }else{ //其他 } // 生成静态页面代码 $successData = [ 'aid' => $aid, 'tid' => $post['typeid'], ]; $this->success("操作成功!", null, $successData); } $this->error("操作失败!"); } $typeid = input('param.typeid/d', 0); $assign_data['typeid'] = $typeid; // 栏目ID //列出产品 $list = Db::name('arctype_cat') ->where('parent_id','=',$typeid) ->where('type','=','产品') ->where('is_del','=',0) ->order('id asc') ->select(); //var_dump($list); $this->assign('pro_list',$list); //列出职称级别 $level_group_list = Db::name('arctype') ->field('id,parent_id,typename') ->where('parent_id','=',53) ->where('is_del','=',0) ->order('id asc') ->select(); //var_dump($list); $this->assign('level_group_list',$level_group_list); //列出 $level_group_name = Db::name('archives') ->field('aid,typeid,title') ->where('typeid','=',$level_group_list[0]['id']) ->where('is_del','=',0) ->order('sort_order asc,aid asc') ->select(); $this->assign('level_group_name',$level_group_name); $product_id = input('param.product_id/d', 0); //var_dump($product_id); $assign_data['product_id'] = $product_id; //关联产品ID 默认都是0 //var_dump($typeid); if((int)$typeid === 126 || (int)$typeid === 825 || (int)$typeid === 826){ //列出职称标签 $product_tag = Db::name('archives') ->field('aid,typeid,title') ->where('typeid','=',58) ->where('is_del','=',0) ->order('sort_order asc,aid asc') ->select(); }else{ //列出职称标签 $cat = Db::name('arctype')->where(['parent_id'=>369,'article_id'=>$typeid])->find(); if(empty($cat)){ $cat_id = 371; }else{ $cat_id = $cat['id']; } $product_tag = Db::name('archives') ->field('aid,typeid,title') ->where('typeid','=',$cat_id) ->where('is_del','=',0) ->order('sort_order asc,aid asc') ->select(); } $this->assign('product_tag',$product_tag); //调用区域信息 $product_area = Db::name('citysite')->where(['level'=>1])->select(); $this->assign('product_area_data',$product_area); // 栏目信息 $arctypeInfo = Db::name('arctype')->find($typeid); $topid = $arctypeInfo['topid']; $assign_data['topid'] = $topid; //查询区域id $catid = $arctypeInfo['area_id']; if((int)$catid === 0){ $catid = input('param.catid/d', 0); } $assign_data['catid'] = $catid; //var_dump($catid); /*允许发布文档列表的栏目*/ //加入区域 $arctype_html = allow_release_arctype($typeid, array($this->channeltype),true,[],false,$catid); $assign_data['arctype_html'] = $arctype_html; /*--end*/ // 阅读权限 $arcrank_list = get_arcrank_list(); $assign_data['arcrank_list'] = $arcrank_list; /*获取可显示的系统字段*/ $condition['ifcontrol'] = 0; $condition['channel_id'] = $this->channeltype; $channelfield_row = Db::name('channelfield')->where($condition)->field('name,ifeditable')->getAllWithIndex('name'); $assign_data['channelfield_row'] = $channelfield_row; /*--end*/ /*模板列表*/ $archivesLogic = new \app\admin\logic\ArchivesLogic; $templateList = $archivesLogic->getTemplateList($this->nid); $this->assign('templateList', $templateList); /*--end*/ /*默认模板文件*/ $tempview = 'view_'.$this->nid.'.'.config('template.view_suffix'); !empty($arctypeInfo['tempview']) && $tempview = $arctypeInfo['tempview']; $this->assign('tempview', $tempview); /*--end*/ // 文档默认浏览量 $globalConfig = tpCache('global'); if (isset($globalConfig['other_arcclick']) && 0 <= $globalConfig['other_arcclick']) { $arcclick_arr = explode("|", $globalConfig['other_arcclick']); if (count($arcclick_arr) > 1) { $assign_data['rand_arcclick'] = mt_rand($arcclick_arr[0], $arcclick_arr[1]); } else { $assign_data['rand_arcclick'] = intval($arcclick_arr[0]); } }else{ $arcclick_config['other_arcclick'] = '500|1000'; tpCache('other', $arcclick_config); $assign_data['rand_arcclick'] = mt_rand(500, 1000); } // URL模式 $tpcache = config('tpcache'); $assign_data['seo_pseudo'] = !empty($tpcache['seo_pseudo']) ? $tpcache['seo_pseudo'] : 1; /*文档属性*/ $assign_data['archives_flags'] = model('ArchivesFlag')->getList(); $channelRow = Db::name('channeltype')->where('id', $this->channeltype)->find(); $assign_data['channelRow'] = $channelRow; // 来源列表 $system_originlist = tpSetting('system.system_originlist'); $system_originlist = json_decode($system_originlist, true); $system_originlist = !empty($system_originlist) ? $system_originlist : []; $assign_data['system_originlist_0'] = !empty($system_originlist) ? $system_originlist[0] : ""; $assign_data['system_originlist_str'] = implode(PHP_EOL, $system_originlist); // 多站点,当用站点域名访问后台,发布文档自动选择当前所属区域 model('Citysite')->auto_location_select($assign_data); $this->assign($assign_data); return $this->fetch(); } /** * 编辑 */ public function edit() { $admin_info = session('admin_info'); $auth_role_info = $admin_info['auth_role_info']; $this->assign('auth_role_info', $auth_role_info); $this->assign('admin_info', $admin_info); if (IS_POST) { $post = input('post.'); model('Archives')->editor_auto_210607($post); $post['aid'] = intval($post['aid']); $typeid = input('post.typeid/d', 0); /* 处理TAG标签 */ if (!empty($post['tags_new'])) { $post['tags'] = !empty($post['tags']) ? $post['tags'] . ',' . $post['tags_new'] : $post['tags_new']; unset($post['tags_new']); } $post['tags'] = explode(',', $post['tags']); $post['tags'] = array_unique($post['tags']); $post['tags'] = implode(',', $post['tags']); /* END */ /*获取第一个html类型的内容,作为文档的内容来截取SEO描述*/ $contentField = Db::name('channelfield')->where([ 'channel_id' => $this->channeltype, 'dtype' => 'htmltext', ])->getField('name'); $content = empty($post['addonFieldExt'][$contentField]) ? '' : htmlspecialchars_decode($post['addonFieldExt'][$contentField]); /*--end*/ // 根据标题自动提取相关的关键字 $seo_keywords = $post['seo_keywords']; if (!empty($seo_keywords)) { $seo_keywords = str_replace(',', ',', $seo_keywords); } else { // $seo_keywords = get_split_word($post['title'], $content); } // 自动获取内容第一张图片作为封面图 $is_remote = !empty($post['is_remote']) ? $post['is_remote'] : 0; $litpic = ''; if ($is_remote == 1) { $litpic = $post['litpic_remote']; } else { $litpic = $post['litpic_local']; } if (empty($litpic)) { $litpic = get_html_first_imgurl($content); } $post['litpic'] = $litpic; /*是否有封面图*/ if (empty($post['litpic'])) { $is_litpic = 0; // 无封面图 } else { $is_litpic = !empty($post['is_litpic']) ? $post['is_litpic'] : 0; // 有封面图 } // 勾选后SEO描述将随正文内容更新 $basic_update_seo_description = empty($post['basic_update_seo_description']) ? 0 : 1; if (is_language()) { $langRow = \think\Db::name('language')->order('id asc') ->cache(true, EYOUCMS_CACHE_TIME, 'language') ->select(); foreach ($langRow as $key => $val) { tpCache('basic', ['basic_update_seo_description'=>$basic_update_seo_description], $val['mark']); } } else { tpCache('basic', ['basic_update_seo_description'=>$basic_update_seo_description]); } /*--end*/ // SEO描述 $seo_description = ''; if (!empty($basic_update_seo_description) || empty($post['seo_description'])) { $seo_description = @msubstr(checkStrHtml($content), 0, config('global.arc_seo_description_length'), false); } else { $seo_description = $post['seo_description']; } // --外部链接 $jumplinks = ''; $is_jump = isset($post['is_jump']) ? $post['is_jump'] : 0; if (intval($is_jump) > 0) { $jumplinks = $post['jumplinks']; } // 模板文件,如果文档模板名与栏目指定的一致,默认就为空。让它跟随栏目的指定而变 if ($post['type_tempview'] == $post['tempview']) { unset($post['type_tempview']); unset($post['tempview']); } // 同步栏目切换模型之后的文档模型 $channel = Db::name('arctype')->where(['id'=>$typeid])->getField('current_channel'); //处理自定义文件名,仅由字母数字下划线和短横杆组成,大写强制转换为小写 $htmlfilename = trim($post['htmlfilename']); if (!empty($htmlfilename)) { $htmlfilename = preg_replace("/[^\x{4e00}-\x{9fa5}\w\-]+/u", "-", $htmlfilename); // $htmlfilename = strtolower($htmlfilename); //判断是否存在相同的自定义文件名 $map = [ 'aid' => ['NEQ', $post['aid']], 'htmlfilename' => $htmlfilename, 'lang' => $this->admin_lang, ]; if (!empty($post['typeid'])) { $map['typeid'] = array('eq', $post['typeid']); } $filenameCount = Db::name('archives')->where($map)->count(); if (!empty($filenameCount)) { $this->error("同栏目下,自定义文件名已存在!"); } else if (preg_match('/^(\d+)$/i', $htmlfilename)) { $this->error("自定义文件名不能纯数字,会与文档ID冲突!"); } } else { // 处理外贸链接 if (is_dir('./weapp/Waimao/')) { $waimaoLogic = new \weapp\Waimao\logic\WaimaoLogic; $waimaoLogic->get_new_htmlfilename($htmlfilename, $post, 'edit', $this->globalConfig); } } $post['htmlfilename'] = $htmlfilename; //做未通过审核文档不允许修改文档状态操作 if ($admin_info['role_id'] > 0 && $auth_role_info['check_oneself'] < 1) { $old_archives_arcrank = Db::name('archives')->where(['aid' => $post['aid']])->getField("arcrank"); if ($old_archives_arcrank < 0) { unset($post['arcrank']); } } // 副栏目 if (isset($post['stypeid'])) { $post['stypeid'] = preg_replace('/([^\d\,\,]+)/i', ',', $post['stypeid']); $post['stypeid'] = str_replace(',', ',', $post['stypeid']); $post['stypeid'] = trim($post['stypeid'], ','); $post['stypeid'] = str_replace(",{$typeid},", ',', ",{$post['stypeid']},"); $post['stypeid'] = trim($post['stypeid'], ','); } //查询排序 等级 $sort_order = Db::name('archives')->where('aid','=',(int)$post['level_group_name'])->value('sort_order'); $ext = ''; //获取文档文件后缀 if(!empty($post['addonFieldExt']['down_eyou_remote'])){ $file = explode('.',$post['addonFieldExt']['down_eyou_remote']); $ext = end($file); }else{ //$ext = ''; } if(!empty($post['addonFieldExt']['down_eyou_local'])){ $file = explode('.',$post['addonFieldExt']['down_eyou_local']); $ext = end($file); }else{ //$ext = ''; } //var_dump($post['addonFieldExt']); //var_dump($ext);die; // --存储数据 $newData = array( 'typeid'=> $typeid, 'channel' => $channel, 'is_b' => empty($post['is_b']) ? 0 : $post['is_b'], 'is_head' => empty($post['is_head']) ? 0 : $post['is_head'], 'is_special' => empty($post['is_special']) ? 0 : $post['is_special'], 'is_recom' => empty($post['is_recom']) ? 0 : $post['is_recom'], 'is_roll' => empty($post['is_roll']) ? 0 : $post['is_roll'], 'is_slide' => empty($post['is_slide']) ? 0 : $post['is_slide'], 'is_diyattr' => empty($post['is_diyattr']) ? 0 : $post['is_diyattr'], 'editor_remote_img_local'=> empty($post['editor_remote_img_local']) ? 0 : $post['editor_remote_img_local'], 'editor_img_clear_link' => empty($post['editor_img_clear_link']) ? 0 : $post['editor_img_clear_link'], 'is_jump' => $is_jump, 'is_litpic' => $is_litpic, 'jumplinks' => $jumplinks, 'seo_keywords' => $seo_keywords, 'seo_description' => $seo_description, 'crossed_price' => empty($post['crossed_price']) ? 0 : floatval($post['crossed_price']), 'add_time' => strtotime($post['add_time']), 'update_time' => getTime(), 'product_id' => (int)$post['product_id'], //增加 'lunwen_id' => (int)$post['lunwen_id'], //增加 'level_group_id' => (int)$post['level_group_id'], 'level_id' => (int)$post['level_group_name'], 'level' => (int)$sort_order, 'product_tag_id' => (int)$post['product_tag_id'], 'area_tag_id' => (int)$post['area_tag_id'], 'ext' => $ext ); $data = array_merge($post, $newData); if((int)$typeid === 126 || (int)$typeid === 825 || (int)$typeid === 826){ //资料文档的时候 //不更新 区域信息 unset($data['province_id']); unset($data['city_id']); unset($data['area_id']); } if((int)$typeid === 117 || (int)$typeid === 115 || (int)$typeid === 111){ //评审攻略和政策资讯 增加常见问题 //不更新 区域信息 unset($data['province_id']); unset($data['city_id']); unset($data['area_id']); } $arctype_par = Db::name('arctype')->field('id,parent_id')->where('id','=',$typeid)->find(); if((int)$arctype_par['parent_id'] === 369){ //文章标签 //不更新 区域信息 unset($data['province_id']); unset($data['city_id']); unset($data['area_id']); } //var_dump($post['addonFieldExt']);die; $r = Db::name('archives')->where([ 'aid' => $data['aid'], 'lang' => $this->admin_lang, ])->update($data); if ($r) { // ---------后置操作 model('Custom')->afterSave($data['aid'], $data, 'edit', $this->table); // ---------end adminLog('编辑文章:'.$data['title']); $numinfo = [ //'is_del' => $data['is_del'], 'is_kan' => $data['arcrank'], //'status' => $data['status'], ]; //文档aid 对应 序列号aid Db::name('seo_number')->where('aid','=',$data['aid'])->update($numinfo); // 生成静态页面代码 $successData = [ 'aid' => $data['aid'], 'tid' => $typeid, ]; $this->success("操作成功!", null, $successData); } $this->error("操作失败!"); } $assign_data = array(); $id = input('id/d'); $info = model('Custom')->getInfo($id, null, false); if (empty($info)) { $this->error('数据不存在,请联系管理员!'); exit; } /*兼容采集没有归属栏目的文档*/ if (empty($info['channel'])) { $channelRow = Db::name('channeltype')->field('id as channel') ->where('id',$this->channeltype) ->find(); $info = array_merge($info, $channelRow); } /*--end*/ $typeid = $info['typeid']; $assign_data['typeid'] = $typeid; //查找产品 $list = Db::name('arctype_cat') ->where('parent_id','=',$typeid) ->where('type','=','产品') ->where('is_del','=',0) ->order('id asc') ->select(); //var_dump($list); $this->assign('pro_list',$list); //列出职称级别 $level_group_list = Db::name('arctype') ->field('id,parent_id,typename') ->where('parent_id','=',53) ->where('is_del','=',0) ->order('id asc') ->select(); //var_dump($list); $this->assign('level_group_list',$level_group_list); //列出 if((int)$info['level_group_id'] === 0){ $level_group_id = $level_group_list[0]['id']; }else{ $level_group_id = (int)$info['level_group_id']; } $level_group_name = Db::name('archives') ->field('aid,typeid,title') ->where('typeid','=',$level_group_id) ->where('is_del','=',0) ->order('sort_order asc,aid asc') ->select(); $this->assign('level_group_name',$level_group_name); if((int)$typeid === 126 || (int)$typeid === 825 || (int)$typeid === 826){ //列出职称标签 $product_tag = Db::name('archives') ->field('aid,typeid,title') ->where('typeid','=',58) ->where('is_del','=',0) ->order('sort_order asc,aid asc') ->select(); }else{ //列出职称标签 $cat = Db::name('arctype')->where(['parent_id'=>369,'article_id'=>$typeid])->find(); if(empty($cat)){ $cat_id = 371; }else{ $cat_id = $cat['id']; } $product_tag = Db::name('archives') ->field('aid,typeid,title') ->where('typeid','=',$cat_id) ->where('is_del','=',0) ->order('sort_order asc,aid asc') ->select(); } $this->assign('product_tag',$product_tag); //调用区域信息 $product_area = Db::name('citysite')->where(['level'=>1])->select(); $this->assign('product_area_data',$product_area); // 副栏目 $stypeid_arr = []; if (!empty($info['stypeid'])) { $info['stypeid'] = trim($info['stypeid'], ','); $stypeid_arr = Db::name('arctype')->field('id,typename')->where(['id'=>['IN', $info['stypeid']],'is_del'=>0])->select(); } $assign_data['stypeid_arr'] = $stypeid_arr; // 栏目信息 $arctypeInfo = Db::name('arctype')->find($typeid); $topid = $arctypeInfo['topid']; $assign_data['topid'] = $topid; $info['channel'] = $arctypeInfo['current_channel']; if (is_http_url($info['litpic'])) { $info['is_remote'] = 1; $info['litpic_remote'] = handle_subdir_pic($info['litpic']); } else { $info['is_remote'] = 0; $info['litpic_local'] = handle_subdir_pic($info['litpic']); } // SEO描述 // if (!empty($info['seo_description'])) { // $info['seo_description'] = @msubstr(checkStrHtml($info['seo_description']), 0, config('global.arc_seo_description_length'), false); // } $assign_data['field'] = $info; /*允许发布文档列表的栏目,文档所在模型以栏目所在模型为主,兼容切换模型之后的数据编辑*/ $arctype_html = allow_release_arctype($typeid, array($info['channel'])); $assign_data['arctype_html'] = $arctype_html; /*--end*/ /*获取可显示的系统字段*/ $condition['ifcontrol'] = 0; $condition['channel_id'] = $this->channeltype; $channelfield_row = Db::name('channelfield')->where($condition)->field('name,ifeditable')->getAllWithIndex('name'); $assign_data['channelfield_row'] = $channelfield_row; /*--end*/ // 阅读权限 $arcrank_list = get_arcrank_list(); $assign_data['arcrank_list'] = $arcrank_list; /*模板列表*/ $archivesLogic = new \app\admin\logic\ArchivesLogic; $templateList = $archivesLogic->getTemplateList($this->nid); $this->assign('templateList', $templateList); /*--end*/ /*默认模板文件*/ $tempview = $info['tempview']; empty($tempview) && $tempview = $arctypeInfo['tempview']; $this->assign('tempview', $tempview); /*--end*/ // URL模式 $tpcache = config('tpcache'); $assign_data['seo_pseudo'] = !empty($tpcache['seo_pseudo']) ? $tpcache['seo_pseudo'] : 1; /*文档属性*/ $assign_data['archives_flags'] = model('ArchivesFlag')->getList(); $channelRow = Db::name('channeltype')->where('id', $this->channeltype)->find(); $assign_data['channelRow'] = $channelRow; // 来源列表 $system_originlist = tpSetting('system.system_originlist'); $system_originlist = json_decode($system_originlist, true); $system_originlist = !empty($system_originlist) ? $system_originlist : []; $assign_data['system_originlist_str'] = implode(PHP_EOL, $system_originlist); $this->assign($assign_data); return $this->fetch(); } /** * 删除 */ public function del() { $archivesLogic = new \app\admin\logic\ArchivesLogic; $archivesLogic->del([], 0, 'custom'); } //帮助 public function help() { $system_originlist = tpSetting('system.system_originlist'); $system_originlist = json_decode($system_originlist, true); $system_originlist = !empty($system_originlist) ? $system_originlist : []; $assign_data['system_originlist_str'] = implode(PHP_EOL, $system_originlist); $this->channeltype = input('param.channel/d', 0); $assign_data['channel'] = $this->channeltype ; $this->assign($assign_data); return $this->fetch(); } }