dedecms后台按照栏目分类导出文章到excel表格,这个怎么实现呢,求大侠们帮助下
在网络上有很多可以免费下载的DEDECMS模板,下载之后如何安装是很多新手的共同问题。
1、下载一个模板之后要判断一下模板文件是否齐全。htm文件中是否包括首页、列表页和文章内容页等;htm文件用到的css文件是否包括;模板安装包中是否包括网站用到的背景;
2、建设网站栏目。在安装调试一个模板之前必须事先建好网站的相关栏目,这样才能做好调试。栏目的建设可以参考模板的样例网站进行建设。
3、根据建好的网站栏目修改模板中调用的相关栏目ID。在htm文件中找到如下标签
{dede:arclist row=’8′ titlelen=’36′ typeid=’56′ orderby=’rand’ }
{/dede:arclist}
将其中的 typeid调整为自己网站的栏目ID。
4、调整htm文件和css文件中用到的的路径,根据自身网站的存放路径进行调整。
5、修改模板文件htm中的固定链接。在模板中存在一些固定链接,可以根据你自己的网站进行适当调整。
6、上传模板文件。将模板中的文件目录上传到服务器的/templets目录下,上传之前需要保存好原来目录下的文件。这个是默认的上传方法,如果模板本身有特殊要求,可以根据模板本身的要求上传。
7、在后台生成首页、栏目页和内容页,根据效果对调试修改相关模板。
8、default目录文件说明
indexhtm(首页模板)
headhtm(网页头部模板)
footerhtm(网页底部模板)
list_htm(列表页模板)
article_htm(内容页模板)
taghtm(标签模板)
taglisthtm(标签列表模板)
searchhtm(搜索页模板)
以上简单描述了DEDECMS模板安装的一般思路,不同的模板安装方法也存在不同,希望上面的描述能为你安装dedecms模板时提供一些帮助。
首先在dede后台开启伪静态(开启的方法在系统参数-核心设置)
第一步 首先栏目和文章最好设置成动态浏览 这样才不会生成静态html文件
第二步 设置重写规则 在系统目录下加一个 htaccess文件 内容为:
复制代码
代码如下:
RewriteEngine On
RewriteRule ^plus/list-([0-9]+)html$ /plus/listphptid=$1
RewriteRule ^plus/list-([0-9]+)-([0-9]+)-([0-9]+)html$ /plus/listphptid=$1&totalresult=$2&PageNo=$3
RewriteRule ^plus/view-([0-9]+)-1html$ /plus/viewphparcID=$1
RewriteRule ^plus/view-([0-9]+)-([0-9]+)html$ /plus/viewphpaid=$1&pageno=$2
iis文件写法
复制代码
代码如下:
#首页伪静态规则,如果不使用动态首页,请勿必删除这一行,否则打开首页会出现死循环
RewriteRule ^()/indexhtml $1/indexphp [I]
#列表页伪静态规则
RewriteRule ^()/category/list-([0-9]+)html $1/plus/listphptid=$2 [I]
RewriteRule ^()/category/list-([0-9]+)-([0-9]+)-([0-9]+)html $1/plus/listphptid=$2&TotalResult=$3&PageNo=$4 [I]
#文章页伪静态规则
RewriteRule ^()/archives/view-([0-9]+)-([0-9]+)html $1/plus/viewphparcID=$2&pageno=$3 [I]
#搜索伪静态规则
RewriteRule ^()/searchhtml(:()) $1/searchphp$2 [I]
#TAG标签伪静态规则
RewriteRule ^()/tagshtml $1/tagsphp [I]
RewriteRule ^()/tags/()(:()) $1/tagsphp/$2 [I]
RewriteRule ^()/tags/()/(:()) $1/tagsphp/$2/ [I]
RewriteRule ^()/tags/()/([0-9])(:()) $1/tagsphp/$2/$3 [I]
RewriteRule ^()/tags/()/([0-9])/(:()) $1/tagsphp/$2/$3/ [I]
如果你的系统支持url重写,到这里就可以用伪静态访问了
第三步更改重写的URL
如果用默认的设置, 访问的URL是:
复制代码
代码如下:
http://wwwXXXXcom/plus/view-131-1html
这样的形色, 我们是可以更改这种样式的
找到文件/include/helpers/channelunithelperphp打开
可以看到有这样的语句
复制代码
代码如下:
return $GLOBALS["cfg_plus_dir"]"/view-"$aid'-1html';
这就是文章的url形色
$reurl = $GLOBALS['cfg_phpurl']"/listphptid="$typeid;
这是列表的重写url
可以使url更短一点,完成可以写成:
复制代码
代码如下:
return "/view-"$aid'-1html';
和
$reurl = "/list-"$typeid"html";
这时重写规则也要更新
复制代码
代码如下:
RewriteEngine On
RewriteRule ^list-([0-9]+)html$ /plus/listphptid=$1
RewriteRule ^list-([0-9]+)-([0-9]+)-([0-9]+)html$ /plus/listphptid=$1&totalresult=$2&PageNo=$3
RewriteRule ^view-([0-9]+)-1html$ /plus/viewphparcID=$1
RewriteRule ^view-([0-9]+)-([0-9]+)html$ /plus/viewphpaid=$1&pageno=$2
更进一步,还可以把view换成自己的任何词语,这也要把include/arcarchivesclassphp文件中的view也一样替换。
发布选项: 生成HTML 仅动态浏览 发文章的时候选一下也不多事。为了以后升级 尽量减少修改文件。
以下这没有试,大家按需要测试吧~~
修改数据库
将所有文档设置为“仅动态”,可以进入数据库管理中,执行下面命令:
复制代码
代码如下:
update dede_archives set ismake=-1
并将ismake的默认值设置为 -1即动态。
将所有栏目设置为“使用动态页”,可以进入数据库管理中,执行下面命令:
复制代码
代码如下:
update dede_arctype set isdefault=-1
DedeCmsTAG标签伪静态
DedeCms默认的TAG标签URL,形如/tagsphp/dedecms57/,非常之难看。打开/include/taglib/taglibphp,找到lib_tag()函数下的:
复制代码
代码如下:
$row['link'] = $cfg_cmsurl"/tagsphp/"urlencode($row['keyword'])"/";
替换为
$row['link'] = $cfg_cmsurl"/tags/"urlencode($row['keyword'])"/";
修改分页代码
我们需要修改include/arctaglistclassphp,将分页函数替换为:
复制代码
代码如下:
/ 获取动态的分页列表
@access public
@param int $list_len 列表宽度
@param string $listitem 列表样式
@return string
/
function GetPageListDM($list_len,$listitem="info,index,end,pre,next,pageno")
{
$prepage="";
$nextpage="";
$prepagenum = $this->PageNo - 1;
$nextpagenum = $this->PageNo + 1;
if($list_len == "" || preg_match("/[^0-9]/", $list_len))
{
$list_len = 3;
}
$totalpage = $this->TotalPage;
if($totalpage <= 1 && $this->TotalResult > 0)
{
return "<span class="pageinfo">共1页/"$this->TotalResult"条</span>";
}
if($this->TotalResult == 0)
{
return "<span class="pageinfo">共0页/"$this->TotalResult"条</span>";
}
$maininfo = "<span class="pageinfo">共{$totalpage}页/"$this->TotalResult"条</span>rn";
$purl = $this->GetCurUrl();
$basename = basename($purl);
$tmpname = explode('', $basename);
$purl = str_replace($basename, '', $purl)urlencode($this->Tag);
//var_dump($purl);exit;
//$purl = "/"urlencode($this->Tag);
//获得上一页和下一页的链接
if($this->PageNo != 1)
{
$prepage="<li><a href='"$purl"-$prepagenum'html>上一页</a></li>rn";
$indexpage="<li><a href='"$purl"-1html'>首页</a></li>rn";
}
else
{
$indexpage="<li><a>首页</a></li>rn";
}
if($this->PageNo!=$totalpage && $totalpage>1)
{
$nextpage="<li><a href='"$purl"-$nextpagenumhtml'>下一页</a></li>rn";
$endpage="<li><a href='"$purl"-$totalpagehtml'>末页</a></li>rn";
}
else
{
$endpage="<li><a>末页</a></li>rn";
}
//获得数字链接
$listdd="";
$total_list = $list_len 2 + 1;
if($this->PageNo >= $total_list)
{
$j = $this->PageNo - $list_len;
$total_list = $this->PageNo + $list_len;
if($total_list > $totalpage)
{
$total_list = $totalpage;
}
}
else
{
$j=1;
if($total_list > $totalpage)
{
$total_list = $totalpage;
}
}
for($j; $j<=$total_list; $j++)
{
if($j == $this->PageNo)
{
$listdd= "<li class="thisclass"><a>$j</a></li>rn";
}
else
{
$listdd="<li><a href='"$purl"-$jhtml'>"$j"</a></li>rn";
}
}
$plist = '';
if(preg_match('/info/i', $listitem))
{
$plist = $maininfo' ';
}
if(preg_match('/index/i', $listitem))
{
$plist = $indexpage' ';
}
if(preg_match('/pre/i', $listitem))
{
$plist = $prepage' ';
}
if(preg_match('/pageno/i', $listitem))
{
$plist = $listdd' ';
}
if(preg_match('/next/i', $listitem))
{
$plist = $nextpage' ';
}
if(preg_match('/end/i', $listitem))
{
$plist = $endpage' ';
}
return $plist;
}
$name=$_POST['user_name'];
$pwd=md5($_POST['user_pwd']);
$phone=$_POST['user_phone'];
$email=$_POST['user_email'];
$query="call pro_reg('$name','$pwd','$phone','$email')";
$result=$pdo->prepare($query);
if($result->execute())
{
第一步:进入网站后台进行设置
1、首先登录网站管理后台 选择 系统-系统基本参数-核心设置>找到关键词替换(是/否)一栏 选择 是
2、然后在 系统-系统基本参数-其他选项 中 找到 文档内容同一关键词替换次数(0为全部替换): 后面写个 1或者2,这个随便自己写
3 在后台的 采集- 文档关键词维护一栏 对关键词 加上需要的链接!
这时有个小问题需要解决下 经过以上的几个步骤 只能实现 在关键词 一栏中填写的关键词 才会有链接! 而内容出现的并没链接 所以 我们需要通过下一步来实现 内容页出现链接
第二步:打开/include/arcarchivesclassphp进行代码替换,
找到下面代码
foreach($kws as $k) { $k = trim($k); if($k!=”") { if($i > $maxkey) { break; } $myrow = $this->dsql->GetOne(“select from dede_keywords where keyword=’$k’ And rpurl<>” “); if(is_array($myrow)) { $karr[] = $k; $GLOBALS['replaced'][$k] = 0; $kaarr[] = “<a href=’{$myrow['rpurl']}’><u>$k</u></a>”; } $i++; } }
替换为:
global $dsql; $query=”SELECT FROM dede_keywords WHERE rpurl<>” ORDER BY rank DESC”; $dsql->SetQuery($query); $dsql->Execute(); while($row = $dsql->GetArray()) { $key = trim($row['keyword']); $key_url=trim($row['rpurl']); $karr[] = $key; $kaarr[] = “<a href=’$key_url’ target=’_blank’><u>$key</u></a>”; }
这样我们就设置好了,但是我们一般尽量设置核心关键词,不要次数过多,不然可能导致优化过度
0条评论