找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1663|回复: 0
打印 上一主题 下一主题

dedecms增加自定义文件名功能

[复制链接]

2652

主题

2652

帖子

7872

积分

论坛元老

Rank: 8Rank: 8

积分
7872
跳转到指定楼层
楼主
发表于 2018-2-13 20:41:42 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

关键字描述:功能 文件 定义 增加   " pagename“字段
为了更好地实现SEO功能,为了广大的DEDE爱好者不再大伤脑筋,这两天抽了点时间把此功能弄出来跟大家分享。
以下修改能实现DEDE自定义网页文件名的功能,例如:
zi-ding-yi.html/zidingyi.html/defined-pagename.html/自定义某某某.html 等
(反正你填什么就是什么,除了短横杠连词符号 -,最好别乱填其它特殊符号特别是单、双引号、空格等,以免出错)。
如果你不填自定义文件名,则默认为文章的aid,如:
138.html/65.html 等。
以下皆以文章模型为例作修改。强烈建议初学者在对文件进行修改前备份之。
以下为针对 DEDE V5 的修改:
=====================================================================
1、在 后台 频道管理 -> 修改栏目(或者增加栏目) -> 高级选项 -> 文章命名规则:
把 {typedir}/{Y}{M}/{D}-{aid}.html 修改成 {typedir}/{aa}.html
({aa} 用来接收自定义文件名。因个人不大喜欢年月日之类的,所以把{Y}、{M}、{D}、{aid}等都去掉了,你喜欢的话,自己加上即可)
2、修改数据库表 dede_archives 增加 pagename 字段 varchar 100 (100够用了,如果不够用,自己改大(255之内)即可)
在 后台 -> 功能菜单 -> SQL命令运行器 中输入:
alter table dede_archives add column pagename varchar(100);
按确定执行即可。
3、增加对 {aa} 的处理:
修改文件:include/inc_channel_unit_functions.php
把大约73行的:
$articleRule = str_replace("{cc}",dd2char($m.$d.$aid.$y),$articleRule);
改为:
$articleRule = str_replace("{aa}",GetPagename($aid),$articleRule);
(因为{cc}实在没什么用,扔掉得了)
4、针对上面 GetPagename($aid) 的处理:
修改文件: include/inc_functions.php
在文件最后面 ?> 前加入以下函数:
//获取自定义文件名的函数,检测如果输入了自定义文件名则文件名为所输入的,否则默认为文章的aid
function GetPagename($dd){
$sql = "select pagename from dede_archives where id = '$dd'";
$dsql = new DedeSql(false);
$row = $dsql->GetOne($sql);
$pagename = $row["pagename"];
if($pagename!=""){
$pagename = $pagename;
}else{
$pagename = $dd;
}
return $pagename;
}
5、修改文章添加和修改页面,在里面加入 pagename 的 input
(1)修改文件:dede/templets/article_add.htm
在:
[tr]
[td]
Tag标签:

(用空格或','分开)

[/td]
[/tr]
前加上:

[tr]
[td]
自定义文件名:

[/td]
[/tr]

(2)修改文件:dede/templets/article_edit.htm
在:
[tr]
[td]
Tag标签:
" />
" />
(用空格或','分开)

[/td]
[/tr]
前加上:

[tr]
[td]
自定义文件名:" />

[/td]
[/tr]

6、修改文章添加和修改的处理页面,对 form 里提交的 pagename 进行处理
(1)修改文件: dede/action/article_add_action.php
 A、在 $title = cn_substr($title,80); 下面增加一行 $pagename = trim($pagename);
 B、在下面增加以下红色部分(看准颜色)。
//加入数据库的SQL语句
//----------------------------------
$inQuery = "INSERT INTO `{$cts['maintable']}`(
ID,typeid,typeid2,sortrank,iscommend,ismake,channel,
arcrank,click,money,title,shorttitle,color,writer,source,reader,litpic,
pubdate,senddate,arcatt,adminID,memberID,description,keywords,templet,redirecturl,likeid,pagename)
VALUES ('$arcID','$typeid','$typeid2','$sortrank','$iscommend','$ismake','$channelid',
'$arcrank','0','$money','$title','$shorttitle','$color','$writer','$source','$reader','$litpic',
'$pubdate','$senddate','$arcatt','$adminID','0','$description','$keywords','$templet','$redirecturl','$likeid','$pagename');";
(2)修改文件: dede/action/article_eidt_action.php
 A、在 $title = cn_substr($title,80); 下面增加一行 $pagename = trim($pagename);
 B、在下面增加以下红色部分(看准颜色)。
//更新数据库的SQL语句
//----------------------------------
$inQuery = "
update `{$aTables['maintable']}` set
typeid='$typeid',
typeid2='$typeid2',
sortrank='$sortrank',
redirecturl='$redirecturl',
iscommend='$iscommend',
ismake='$ismake',
arcrank='$arcrank',
money='$money',
title='$title',
color='$color',
writer='$writer',
source='$source',
reader='$reader',
litpic='$litpic',
pubdate='$pubdate',
description='$description',
keywords='$keywords',
templet='$templet',
shorttitle='$shorttitle',
arcatt='$arcatt',
likeid='$likeid',
pagename = '$pagename'
where ID='$ID'; ";
7、测试发文章,生成html,大功告成。
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

用户反馈
客户端