dedecms增加自定义文件名功能

织梦教程 强烈建议 2024-02-06 13:27 147 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'; ";   7、测试发文章,生成html,大功告成。

时间:(2024-02-06 13:27:00)
本站资源均来自互联网或会员发布,如果不小心侵犯了您的权益请与我们联系。我们将立即删除!谢谢!