dedecms增加自定义文件名功能

织梦教程 强烈建议 2024-02-26 11:40 133 0

  为了更好地实现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

  在:

  

  

  

  

  

  

  

  

Tag标签:

  

  (用空格或','分开)

  

  

  

  前加上:

  

  

  

  

  

  

  

  

  

自定义文件名:

  

  

  

  (2)修改文件:dede/templets/article_edit.htm

  在:

  

  

  

  

  

  

  

  

Tag标签:

  

  

  (用空格或','分开)

  

  

  

  前加上:

  

  

  

  

  

  

  

  

  

自定义文件名: " />

  

  

  

  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'; ";

本站资源均来自互联网或会员发布,如果不小心侵犯了您的权益请与我们联系。我们将立即删除!谢谢!