dede织梦批量导入关键词

在后台替换对应的文件件即可

article_keywords_main.php

<?php
/**
 * 文档关键词管理
 *
 * @version        $Id: article_keywords_main.php 1 14:12 2010年7月12日Z tianya $
 * @package        DedeCMS.Administrator
 * @copyright      Copyright (c) 2007 - 2010, DesDev, Inc.
 * @license        http://help.dedecms.com/usersguide/license.html
 * @link           http://www.dedecms.com
 */
require_once(dirname(__FILE__)."/config.php");
CheckPurview(‘sys_Keyword‘);
require_once(DEDEINC."/datalistcp.class.php");
setcookie("ENV_GOBACK_URL",$dedeNowurl,time()+3600,"/");
if(empty($dopost)) $dopost = ‘‘;

//保存批量更改
if($dopost==‘saveall‘)
{
    $ENV_GOBACK_URL = empty($_COOKIE[‘ENV_GOBACK_URL‘]) ? "article_keywords_main.php" : $_COOKIE[‘ENV_GOBACK_URL‘];
    if(!isset($aids))
    {
        ShowMsg("你没有选择要更改的内容!",$ENV_GOBACK_URL);
        exit();
    }
    foreach($aids as $aid)
    {
        $rpurl = ${‘rpurl_‘.$aid};
        $rpurlold = ${‘rpurlold_‘.$aid};
        $keyword = ${‘keyword_‘.$aid};

        //删除项目
        if(!empty(${‘isdel_‘.$aid}))
        {
            $dsql->ExecuteNoneQuery("DELETE FROM `#@__keywords` WHERE aid=‘$aid‘");
            continue;
        }

        //禁用项目
        $staold = ${‘staold_‘.$aid};
        $sta = empty(${‘isnouse_‘.$aid}) ? 1 : 0;
        if($staold!=$sta)
        {
            $query1 = "UPDATE `#@__keywords` SET sta=‘$sta‘,rpurl=‘$rpurl‘ WHERE aid=‘$aid‘ ";
            $dsql->ExecuteNoneQuery($query1);
            continue;
        }

        //更新链接网址
        if($rpurl!=$rpurlold)
        {
            $query1 = "UPDATE `#@__keywords` SET rpurl=‘$rpurl‘ WHERE aid=‘$aid‘ ";
            $dsql->ExecuteNoneQuery($query1);
        }
    }
    ShowMsg("完成指定的更改!",$ENV_GOBACK_URL);
    exit();
}
//增加关键字
else if($dopost==‘add‘)
{
    $ENV_GOBACK_URL = empty($_COOKIE[‘ENV_GOBACK_URL‘]) ? "-1" : $_COOKIE[‘ENV_GOBACK_URL‘];
    $keyword = trim($keyword);
    $rank = preg_replace("#[^0-9]#", ‘‘, $rank);
    if($keyword==‘‘)
    {
        ShowMsg("关键字不能为空!",-1);
        exit();
    }
    $row = $dsql->GetOne("SELECT * FROM `#@__keywords` WHERE keyword LIKE ‘$keyword‘");
    if(is_array($row))
    {
        ShowMsg("关键字已存在库中!","-1");
        exit();
    }
    $inquery = "INSERT INTO `#@__keywords`(keyword,rank,sta,rpurl) VALUES (‘$keyword‘,‘$rank‘,‘1‘,‘$rpurl‘);";
    $dsql->ExecuteNoneQuery($inquery);
    ShowMsg("成功增加一个关键字!",$ENV_GOBACK_URL);
    exit();
}
//文件导入式 批量添加关键词
elseif ( $dopost == ‘fileKeywords‘) {

    if ( is_uploaded_file( $filename ) )
    {
        $newFileName    = date(‘YmdHis‘, time() ) .‘.txt‘;
        $newDirPath     = $cfg_basedir . ‘/uploads/keywords‘;
        $newFilePath    =  $newDirPath .‘/‘.$newFileName;

        //目录不存在则创建
        if ( !file_exists( $newDirPath ) )
        {
            mkdir( $newDirPath, 0777, true );
        }

        move_uploaded_file( $filename, $newFilePath);

        //读取上传的文件
        $handle = fopen( $newFilePath, ‘r‘ ) or ShowMsg("上传文件读取失败",-1); 

        $keyArr = array();

        if ($handle)
        {
            while (!feof($handle))
            {
                $buffer = fgets($handle, 4096);
                $buffer = str_replace(‘,‘, ‘,‘, $buffer);
                $buffer = str_replace(array("\n"), ‘‘, $buffer);
                $buffer = trim($buffer);
                if(!empty($buffer))
                {
                    $keyArr[] = explode(‘,‘, $buffer);
                }
            }

            fclose($handle);
            @unlink( $newFilePath );
        }

        //取出数据库所有的关键词,和新添加关键词比较,如果新添加的关键字,数据中存在则过滤
        $dsql->SetQuery( "SELECT `keyword` FROM `#@__keywords` " );//将SQL查询语句格式化
        $dsql->Execute();//执行SQL操作
        //通过循环输出执行查询中的结果
        $dataKeyArr = array();
        while( $row = $dsql->GetArray() )
        {
            $dataKeyArr[] = $row[‘keyword‘];
        }
        //拼接mysql 语句
        $i = 0;
        foreach ( $keyArr as $k => $v )
        {
            $key = trim( $v[0] );
            //把读取txt文档的数据转utf-8编码
            $key =  mb_convert_encoding($key, ‘utf-8‘, ‘gbk‘);
            //如果数据库中存在该关键词,则跳出本次循环。 注意: keyword字段在数据库中长度16字符,需要更更长点
            if( in_array( $key, $dataKeyArr ) )
                continue;
            //拼接mysql语句
            $rpurl  =   trim($v[1], ‘ ‘);
            $rank   =   trim($v[2], ‘ ‘);
            $sql = "INSERT INTO `#@__keywords`  ( keyword, rank, sta, rpurl ) VALUES  ( ‘{$key}‘, {$rank}, 1, ‘{$rpurl}‘)";
            $res = $dsql->ExecuteNoneQuery2($sql);
            if( $res != -1)
                $i ++;

        }
        //如果导入的文件所有的关键词都添加过了,则停止执行;
        if( empty( $i ) )
        {
            ShowMsg("警告:你提交的关键词,早已经添加过了!!!",-1);
            die();
        }
        else
        {
            ShowMsg("你成功导入{$i}条数据",-1);
        }

    }

}

if(empty($keyword))
{
    $keyword = ‘‘;
    $addquery = ‘‘;
}
else
{
    $addquery = " WHERE keyword LIKE ‘%$keyword%‘ ";
}

$sql = "SELECT * FROM `#@__keywords` $addquery ORDER BY rank DESC";
$dlist = new DataListCP();
$dlist->pageSize = 20;
$dlist->SetParameter("keyword",$keyword);
$dlist->SetTemplate(DEDEADMIN."/templets/article_keywords_main.htm");
$dlist->SetSource($sql);
$dlist->Display();

function GetSta($sta)
{
    if($sta==1) return ‘‘;
    else return ‘ checked="1" ‘;
}

article_keywords_main.htm文件

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=<?php echo $cfg_soft_lang; ?>">
<title>关键字管理</title>
<link href="css/base.css" rel="stylesheet" type="text/css">
<link href="div.css" rel="stylesheet" type="text/css">
<style>
    .nnpp{
    border-bottom:1px solid #666666;
    border-top:1px solid #FFFFFF;
    border-left:1px solid #FFFFFF;
    border-right:1px solid #FFFFFF;
    filter:alpha(opacity=50);
 }
</style>
<script language=‘javascript‘>
function selAll()
{
    var celements = document.getElementsByName(‘aids[]‘);
    for(i=0;i<celements.length;i++)
    {
        if(!celements[i].checked) celements[i].checked = true;
        else celements[i].checked = false;
    }
}

//全选删除
function delAll()
{

  var celements = document.getElementsByClassName(‘del‘);
  for( i = 0; i < celements.length; i++ )
  {
    if(!celements[i].checked)
      celements[i].checked = true;
    else
      celements[i].checked = false;
  }

}
</script>
</head>
<body background=‘images/allbg.gif‘ leftmargin=‘8‘ topmargin=‘8‘>
<div class="main">
  <table width="98%" border="0" cellpadding="1" align=‘center‘ cellspacing="1" bgcolor="#D6D6D6">
    <tr>
      <td height="26" colspan="6" background="images/tbg.gif"><table width="96%" border="0">
          <tr>
            <form  action="article_keywords_main.php" method="POST" enctype="multipart/form-data"  >
            <td width="40%"  style="padding-left:10px;">
              <strong>关键词维护</strong>
              <strong>&nbsp;&nbsp;</strong>
                <strong><input type="file"  name="filename"></strong>
                <input type="hidden"  name="dopost"  value="fileKeywords" />
                <strong><input type="submit" value="提交"></strong>
            </td>
            </form>
            <form name=‘form1‘ action="article_keywords_main.php">
            <td width="75%" align="right">
               搜索:<input type=‘text‘ name=‘keyword‘ size=‘20‘ />
               <input type=‘submit‘ name=‘sb‘ value=‘确定‘ class="coolbg np" />
               &nbsp;
            <input class="coolbg np" name="n1" type="button" id="n1" value="分析系统内的关键字" onClick="location=‘article_keywords_make.php‘;" style="width:130px" />
            &nbsp;
            <input class="coolbg np" name="n11" type="button" id="n11" value="管理搜索的关键字" onClick="location=‘search_keywords_main.php‘;" style="width:125px" />
            </td></form>
          </tr>
        </table></td>
    </tr>
    <form name=‘form2‘ action="article_keywords_main.php">
        <input type=‘hidden‘ name=‘dopost‘ value=‘add‘ />
      <tr align="center" bgcolor="#ffffff">
        <td width="100%" height="30" colspan="6">
            <table border="0" cellspacing="0" cellpadding="0">
            <tr>
              <td width="100" align="center">新增关键字:</td>
              <td width="140"><input name="keyword" type="text" id="keyword" style="width:130px" /></td>
              <td width="60">链接网址:</td>
              <td width="140"><input name="rpurl" type="text" id="rpurl" style="width:130px" /></td>
              <td width="40">频率:</td>
              <td width="50"><input name="rank" type="text" id="rank" style="width:30px" value="30" /></td>
              <td width="80"><input type="submit" name="Submit" value="保存" class="coolbg np" /></td>
            </tr>
          </table>
          </td>
      </tr>
    </form>
    <tr align="center" bgcolor="#FBFCE2" height="26">
      <td width="8%">选择</td>
      <td width="25%">关键字</td>
      <td width="35%">链接网址</td>
      <td width="10%">频率</td>
      <td width="22%">管理</td>
    </tr>
     <form name=‘form3‘ action="article_keywords_main.php" method="post">
        <input type=‘hidden‘ name=‘dopost‘ value=‘saveall‘ />
   {dede:datalist}
    <tr align="center" bgcolor="#FFFFFF" onMouseMove="javascript:this.bgColor=‘#FCFDEE‘;" onMouseOut="javascript:this.bgColor=‘#FFFFFF‘;">
      <td height="24">
          <input name="aids[]" type="checkbox" value="{dede:field.aid/}" class="np" checked=‘1‘ />
      </td>
      <td>
          <input type=‘hidden‘ value=‘{dede:field.keyword/}‘ name=‘keyword_{dede:field.aid/}‘ />
          {dede:field.keyword/}
      </td>
      <td style="padding:5px 0;">
          <input type=‘hidden‘ value=‘{dede:field.rpurl/}‘ name=‘rpurlold_{dede:field.aid/}‘ />
          <input type=‘text‘ style=‘width:90%‘ class=‘nnpp‘ value=‘{dede:field.rpurl/}‘ name=‘rpurl_{dede:field.aid/}‘ />
      </td>
      <td>
          <input type=‘text‘ size=‘5‘ class=‘nnpp‘ value=‘{dede:field.rank/}‘ name=‘rank_{dede:field.aid/}‘ />
      </td>
      <td>
          <input type=‘hidden‘ name=‘staold_{dede:field.aid/}‘ value=‘{dede:field.sta/}‘ />
          <input type=‘checkbox‘ name=‘isnouse_{dede:field.aid/}‘ class=‘np‘ value=‘1‘{dede:field.sta function="GetSta(@me)"/} />
          禁用
          &nbsp;
          <input type=‘checkbox‘ name=‘isdel_{dede:field.aid/}‘ class=‘np del‘ value=‘1‘ />
          删除
      </td>
    </tr>
{/dede:datalist}
     <tr bgcolor="#ffffff">
      <td height="28" colspan="4">
        &nbsp;
        <input type="button" name="dl1" class="coolbg np" value="反选" onClick="selAll()" />
        &nbsp;
        <input type="button" name="dl2" class="coolbg np" value="保存更改" onClick="this.form.submit();" />
      </td>

    <td height="28" align="center" >
      &nbsp;
      <input type="button" name="dl1" class="coolbg np" value="删除全选" onClick="delAll()" />
    </td>

    </tr>
    </form>
    <tr align="center" bgcolor="#F9FCEF">
      <td height="28" colspan="6">
          {dede:pagelist listsize=3/}
      </td>
    </tr>
  </table>
</div>
</body>
</html>
时间: 2024-08-25 21:58:04

dede织梦批量导入关键词的相关文章

DEDE织梦常用的调用方法

DEDE织梦常用的调用常规调用: 网站名称调用:<title>{dede:global.cfg_webname/}</title> 网站关键词调用:<meta name="keywords" content="{dede:global.cfg_keywords/}" />网站描述调用:<meta name="description" content="{dede:global.cfg_descr

dede织梦怎样导出文章的URL和标题

如何用织梦cms批量查询并导出网站文章的url链接和标题. 工具/原料 dede织梦CMS网站后台 登陆dede织梦cms网站后台. 如图所示,点击[模板]-[全局标记] 如图,输入代码,调用链接和标题,并提交测试. {dede:arclist row="100"} [field:fulltitle/]******这里输入你的域名*******[field:arcurl/] {/dede:arclist} 程序运行完毕时就可以复制你想要的链接和标题了.

dede织梦5.7的安全防护设置

dede安全是一直令人堪忧的,但是其用来建网站很方便,如果我们使用dede来建站,一定要做好安全防护工作. 下面总结一下dede织梦5.7的安全防护设置 1.更改管理员名称和密码,尽可能设置的复杂一下,一般是大小写字母数字和特殊符号12位以上 2.强烈建议data/common.inc.php文件属性设置为644(Linux/Unix)或只读(NT): 3.管理目录改名,最好是改成MD5形式的,最好长点,我一般改成20位大小子字母数字. 4.如果是使用HTML可以把plus下的相应文件和根目录下

记一次DEDE织梦网站恢复的经历

前言:一个处于瘫痪的网站,之前使用DEDE织梦搭建,由于之前被挂马,被迫关停,好在程序有备份,数据库已经恢复并清理,DEDE系统升级之后,显示主页为空白内容. 解决过程: 1.拿到管理员用户密码之后,登陆dede后台发现,栏目信息为空白,刚开始怀疑是数据库信息被清理,后来排查发现数据库有两个栏目表,只是前缀不同,后来通过查找网上信息发现,dede可以在安装过程中进行自定义,默认是dede_开头的表,所以怀疑可能是数据库连接表错误: 2.查找dede的数据库连接配置文件data/common.in

dede织梦data目录正确迁移及引起的问题解决方法

关于将dede织梦data目录迁移出web目录织梦官方提供了一个教程,但是如果你是按照他们提供的教程做的话会出现很多问题.比如验证码问题, 图片显示问题等等一大堆.织梦官方这种是很不负责任的,因为那个教程有很大缺陷.这里跟大家提供一个完整版本的如何将dede织梦data目录正确迁移, 以及按照官方版本教程迁移出现问题的解决办法.这里先看看官方的吧,然后我再补充. 1.将data目录转移到非Web目录 我们这里举例“D:\dedecms\v57”为我们系统的根目录,我们需要将目录下的data文件夹

dede 织梦新空间上传方法

本地测试好的DEDE织梦程序怎么上传到新空间第一步:先将本地的数据库进行备份,(准备到新空间后进行数据还原).第二步:在新空间安装好dede程序,在安装时,可以将用户名和密码取为和本地环境一至的.第三步:登陆新空间,并在新空间的后台对新空间进行数据备份:(目的是将新空间的admin表备份下来), 然后将data/backup文件夹中的admin表和/include/common.inc.phpdata/common.inc.php这三个文件通过ftp回传到本地的一个文件夹中,以备后用. 第四步:

如何有效防止DEDE织梦系统被挂木马安全设置(仅供参考)

尊敬的客户,您好!     感谢广大客户对我司工作的信任和支持!      我司在最近的一个多月内陆续发现多起因 DedeCMS 安全漏洞造成网站被上传恶意脚本的事件,入侵者可利用恶意脚本对外发送大量数据包,严重占用CPU资源与服务器带宽,影响极为恶劣.为保证服务稳定,即日起一旦发现网站存在此类恶意脚本,我们将立即暂停该网站的服务直到问题修复.如果您正在使用 DedeCMS,请立即检查是否已经存在恶意脚本,并更新程序到最新版本或应用相关补丁.     迄今为止,我们发现的恶意脚本文件有    

Dede织梦系统的一键清空回收站以及批量删除所有文章方法

最近搞dede采集,提起织梦相信大家都不陌生,我在第一次搞采集的时候,由于不会写规则,并且也不是单独的采集一篇文章,而是列表里的文章一次性全部采集,等导出数据的时候,我和小伙伴都惊呆了,采集过来的新闻几乎都是缺胳膊少腿,刚开始也是一篇一篇的删,很是恼火,然而,下面这SQL语句却帮了我大忙,一次性把回收站都清空了. 希望对于和我有同样遭遇的人士有帮助,附上语句: 方法: 后台->系统->SQL命令行工具 中运行: delete dede_addonarticle,dede_archives,de

dede织梦后台如何修改?如何增加删除菜单?(

织梦后台的模板存放在dede/templets下面, 登陆首页模板login.htm, 进入首页模板index_body.htm, 左侧菜单模板index_menu2.htm. 修改左侧菜单dede/inc/inc_menu.php 这个文件. 要添加一个菜单找到dede/templets/index_menu2.htm增加: <a id='link9' class='mm'><div onClick="ShowMainMenu(9)">其他</div&g