dedecms增加自定義文件名功能

字號(hào):


    以下修改能實(shí)現(xiàn)DEDE自定義網(wǎng)頁(yè)文件名的功能,例如:
    zi-ding-yi.html/zidingyi.html/defined-pagename.html/自定義某某某.html 等
    (反正你填什么就是什么,除了短橫杠連詞符號(hào) -,最好別亂填其它特殊符號(hào)特別是單、雙引號(hào)、空格等,以免出錯(cuò))。
    如果你不填自定義文件名,則默認(rèn)為文章的aid,如:
    138.html/65.html 等。
    以下皆以文章模型為例作修改。強(qiáng)烈建議初學(xué)者在對(duì)文件進(jìn)行修改前備份之。
    以下為針對(duì) DEDE V5 的修改:
    =====================================================================
    1、在 后臺(tái) 頻道管理 -> 修改欄目(或者增加欄目) -> 高級(jí)選項(xiàng) -> 文章命名規(guī)則:
    把 {typedir}/{Y}{M}/{D}-{aid}.html 修改成 {typedir}/{aa}.html
    ({aa} 用來(lái)接收自定義文件名。因個(gè)人不大喜歡年月日之類的,所以把{Y}、{M}、{D}、{aid}等都去掉了,你喜歡的話,自己加上即可)
    2、修改數(shù)據(jù)庫(kù)表 dede_archives 增加 pagename 字段 varchar 100 (100夠用了,如果不夠用,自己改大(255之內(nèi))即可)
    在 后臺(tái) -> 功能菜單 -> SQL命令運(yùn)行器 中輸入:
    alter table dede_archives add column pagename varchar(100);
    按確定執(zhí)行即可。
    3、增加對(duì) {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);
    (因?yàn)閧cc}實(shí)在沒(méi)什么用,扔掉得了)
    4、針對(duì)上面 GetPagename($aid) 的處理:
    修改文件: include/inc_functions.php
    在文件最后面 ?> 前加入以下函數(shù):
    //獲取自定義文件名的函數(shù),檢測(cè)如果輸入了自定義文件名則文件名為所輸入的,否則默認(rèn)為文章的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、修改文章添加和修改頁(yè)面,在里面加入 pagename 的 input
    (1)修改文件:dede/templets/article_add.htm
    在:
    <tr>
    <td height="24">
    <table width="800" cellspacing="0" cellpadding="0">
    <tr>
    <td width="90"> Tag標(biāo)簽:</td>
    <td>
    <input name="tag" type="text" id="tag" value="">
    (用空格或','分開(kāi))
    </td>
    </tr>
    </table>
    </td>
    </tr>
    前加上:
    <!-- 自定義文件名開(kāi)始 -->
    <tr>
    <td height="24">
    <table width="800" cellspacing="0" cellpadding="0">
    <tr>
    <td width="100"> 自定義文件名:</td>
    <td width="650"><input name="pagename" type="text" id="pagename" maxlength="100" /></td>
    </tr>
    </table>
    </td>
    </tr>
    <!-- 自定義文件名結(jié)束 -->
    (2)修改文件:dede/templets/article_edit.htm
    在:
    <tr>
    <td height="24">
    <table width="800" cellspacing="0" cellpadding="0">
    <tr>
    <td width="90"> Tag標(biāo)簽:</td>
    <td>
    <input name="oldtag" type="hidden" id="oldtag" value="<?php echo $tags; ?>" />
    <input name="tag" type="text" id="tag" value="<?php echo $tags; ?>" />
    (用空格或','分開(kāi))
    </td>
    </tr>
    </table>
    </td>
    </tr>
    前加上:
    <!-- 自定義文件名開(kāi)始 -->
    <tr>
    <td height="24">
    <table width="800" cellspacing="0" cellpadding="0">
    <tr>
    <td width="100"> 自定義文件名:</td>
    <td width="650"><input name="pagename" type="text" id="pagename" maxlength="100" value="<?php echo $arcRow["pagename"]?>" /></td>
    </tr>
    </table>
    </td>
    </tr>
    <!-- 自定義文件名結(jié)束 -->
    6、修改文章添加和修改的處理頁(yè)面,對(duì) form 里提交的 pagename 進(jìn)行處理
    (1)修改文件: dede/action/article_add_action.php
    A、在 $title = cn_substr($title,80); 下面增加一行 $pagename = trim($pagename);
    B、在下面增加以下紅色部分(看準(zhǔn)顏色)。
    //加入數(shù)據(jù)庫(kù)的SQL語(yǔ)句
    //----------------------------------
    $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、在下面增加以下紅色部分(看準(zhǔn)顏色)。
    //更新數(shù)據(jù)庫(kù)的SQL語(yǔ)句
    //----------------------------------
    $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、測(cè)試發(fā)文章,生成html,大功告成。