dede织梦批量导入关键词
在后台替换对应的文件件即可.
注意:如果你的关键字长度超过16个字符的话,需要更改 dede 中 keywords 表中的keyword 字段字符长度
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
* author Abner
* Update time 2017-01-07
*/
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);
} } } //清空关键字表里的所有数据
else if ( $dopost == 'delAll')
{
$dsql->ExecuteNoneQuery('TRUNCATE TABLE `#@__keywords`') ? ShowMsg("你已成功清除所有的关键词!!", $ENV_GOBACK_URL ) : ShowMsg("清除关键词失败",-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 delSel()
{ 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;
} } function delAll ()
{
if( confirm( '你确定要清空所有的关键词,清除以后不可恢复!!' ) )
{
location.href="article_keywords_main.php?dopost=delAll";
}
} </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> </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" />
<input class="coolbg np" name="n1" type="button" id="n1" value="分析系统内的关键字" onClick="location='article_keywords_make.php';" style="width:130px" />
<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)"/} />
禁用
<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">
<input type="button" name="dl1" class="coolbg np" value="反选" onClick="selAll()" />
<input type="button" name="dl2" class="coolbg np" value="保存更改" onClick="this.form.submit();" />
</td> <td height="28" align="center" >
<input type="button" value="清空所有关键词" onClick="delAll()" />
<input type="button" name="dl1" class="coolbg np" value="删除全选" onClick="delSel()" />
</td> </tr>
</form>
<tr align="center" bgcolor="#F9FCEF">
<td height="28" colspan="6">
{dede:pagelist listsize=3/}
</td>
</tr>
</table>
</div>
</body>
</html>
dede织梦批量导入关键词的更多相关文章
- DEDE织梦常用的调用方法
DEDE织梦常用的调用常规调用: 网站名称调用:<title>{dede:global.cfg_webname/}</title> 网站关键词调用:<meta name= ...
- dede织梦后台页面及功能修改精简操作方法
有很多使用织梦程序的站长往往都不喜欢使用默认的后台,但对于很多小白站长其实也不太懂程序的功能,而且如果显示或者开了过多的功能只会给自己带来困扰,所以小白站长都喜欢一些傻瓜式的后台操作界面.那么,ded ...
- 关于将dede织梦data目录迁移出web目录
关于将dede织梦data目录迁移出web目录织梦官方提供了一个教程,但是如果你是按照他们提供的教程做的话会出现很多问题.比如验证码问题,图片显示问题等等一大堆.织梦官方这种是很不负责任的,因为那个教 ...
- dede织梦栏目页和文章页中获取当前栏目名称方法
一般情况下,在dede织梦系统中列表页.栏目页和文章页中获取当前所在栏目名称只需要代码:{dede:type}[field:typename]{/dede:type}即可,不需要定义ID,默认的就是当 ...
- 如何有效防止DEDE织梦系统被挂木马安全设置(仅供参考)
尊敬的客户,您好! 感谢广大客户对我司工作的信任和支持! 我司在最近的一个多月内陆续发现多起因 DedeCMS 安全漏洞造成网站被上传恶意脚本的事件,入侵者可利用恶意脚本对外发送大量 ...
- dede织梦如何去除网站底部的版权信息
dede织梦如何删除版权powered by?在织梦中,特别是在仿站之中,经常会在首页的底部出现powered by,这是dedecms织梦系统底部自带的官方链接power by等字样,很多新用户想去 ...
- dede织梦5.7的安全防护设置
dede安全是一直令人堪忧的,但是其用来建网站很方便,如果我们使用dede来建站,一定要做好安全防护工作. 下面总结一下dede织梦5.7的安全防护设置 1.更改管理员名称和密码,尽可能设置的复杂一下 ...
- 如何解决DEDE织梦友情链接字数限制与链接个数限制的问题?
如何解决DEDE织梦友情链接字数限制与链接个数限制的问题!织梦网站非常适合网站搭建以及网站优化,而友情链接是做优化必不可少的模块,我们经常搭建织梦网站发现织梦系统的友情链接模板有时候会限制字数不显示以 ...
- dede织梦5.7上传图片302以及Error #2038问题解决
dede织梦5.7上传图片302以及Error #2038问题解决 三月 19, 2012 · Posted in DEDE二次开发, PHP Number of View: 1388 在后台图片集 ...
随机推荐
- 基于Cesium1.26地图API下的GeoServer2.9.0服务器跨域设置
遇到的问题: 最近基于Cesium来做3D模型的地图开发,在访问自己发布的WMS服务之后,遇到了GeoServer跨域问题. 调用这个WMS服务的时候,浏览器(我用Chrome)开发者工具报错: 控制 ...
- 通过Wireshark抓包进行Cookie劫持
首先在目标A机器上运行Wireshark并开启浏览器,开启前关闭其他占用网络的软件,这里我拿51CTO.com做测试. 正常登陆51CTO用户中心,此时使用 http.cookie and http. ...
- [转] IIS配置文件的XML格式不正确 applicationHost.config崩溃 恢复解决办法
IIS配置文件的XML格式不正确 applicationHost.config崩溃 恢复解决办法 源文件:http://www.cnblogs.com/yuejin/p/3385584.html ...
- iOS之获取经纬度并通过反向地理编码获取详细地址
_locationManager = [[CLLocationManager alloc] init]; //期望的经度 _locationManager.desiredAccuracy = kCLL ...
- 【译】Spring 4 @Profile注解示例
前言 译文链接:http://websystique.com/spring/spring-profile-example/ 本文将探索Spring中的@Profile注解,可以实现不同环境(开发.测试 ...
- iOS系列 基础篇 05 视图鼻祖 - UIView
iOS系列 基础篇 05 视图鼻祖 - UIView 目录: UIView“家族” 应用界面的构建层次 视图分类 最后 在Cocoa和Cocoa Touch框架中,“根”类时NSObject类.同样, ...
- T-SQL 查询XML
我们经常在SQL Server列中存一些XML来作为配置文件或者是保存特殊信息,那么如何将其展开并查询它或将其呈现为关系数据? 其实在T-SQL 下可以很容易的实现. 示例xml <catalo ...
- 华为手机浏览器不支持PUT提交方式的解决方案
最近所在技术团队在开发webapp项目,前端angularjs+后端.Net MVC API,API登录接口定义为PUT提交方式,在做兼容测试时发现UC.safari.微信浏览器下都可以登录,但在华为 ...
- Oracle中如何实现Mysql的两表关联update操作
在看<MySQL 5.1参考手册>的时候,发现MySQL提供了一种两表关联update操作.原文如下: UPDATE items,month SET items.price=month.p ...
- SPI基础知识
Serial Peripheral Interface 是摩托罗拉公司提出的一种总线协议,主要应用在EEPROM,FLASH,实时时钟,A/D转换,以及数字信号处理和数字信号解码器中 是一种高速,全双 ...