这是对之前搭建DeDeCMS内容管理系移动站静态化的一个重新梳理,同时也可以用这个方法稍加修改搭建出MIP站点。教程的编写是基于@hscd521的分享文章修改,感谢他的分享。

事先了解:

1、根据这个教程可以达到什么的功能?

答:可以在根目录指定一个子目录生成对应模板的网页,从而搭建与PC站点数据同步的移动静态站点。

2、这个教程可以用来搭建MIP站点吗?

答:这个教程是另一篇《DeDeCMS(织梦)内容管理系统MIP改造教程》的准备工作,在浏览完以后,请按照《DeDeCMS(织梦)内容管理系统MIP改造教程》的教程,继续操作。

言归正传,现在开始:

第一步:编写所需要的DeDeCMS(织梦)内容管理系统更新操作的类文件。

需要编写的文件有5个,分布是:

  1. dede/makehtml_all_m.php
  2. dede/makehtml_archives_action_m.php
  3. dede/makehtml_list_action_m.php
  4. include/arc.archives_m.class.php
  5. include/arc.listview_m.class.php

注:如果还要增加一个MIP目录,则需要增加5个文件,分别是:

  1. dede/makehtml_all_mip.php
  2. dede/makehtml_archives_action_mip.php
  3. dede/makehtml_list_action_mip.php
  4. include/arc.archives_mip.class.php
  5. include/arc.listview_mip.class.php

可能有的网友看到这里就问了不会PHP怎么办,其实这几个文件都是根据原版的文件稍加修改的。参考关系见下文:

(1)dede/makehtml_all_*.php文件修改教程:

原版代码:

<?php
/**
 * 生成所有页面
 *
 * @version        $Id: makehtml_all.php 1 8:48 2010年7月13日Z tianya $
 * @package        DedeCMS.Administrator
 * @copyright      Copyright (c) 2007 - 2010, DesDev, Inc.
 * @license        http://help.dedecms.com/usersguide/license.html
 * @link           http://www.dedecms.com
 */
require_once(dirname(__FILE__)."/config.php");
require_once(DEDEINC."/channelunit.func.php");
$action = (empty($action) ? '' : $action);

if($action=='')
{
    require_once(DEDEADMIN."/templets/makehtml_all.htm");
    exit();
}
else if($action=='make')
{
    //step = 1 更新主页、step = 2 更新内容、step = 3 更新栏目
    if(empty($step)) $step = 1;

    //更新文档前优化数据
    /*-------------------
    function _1_OptimizeData1()
    ---------------------*/
    if($step==1)
    {
        $starttime = GetMkTime($starttime);
        $mkvalue = ($uptype=='time' ? $starttime : $startid);
        OptimizeData($dsql);
        ShowMsg("完成数据优化,现在开始更新文档!","makehtml_all.php?action=make&step=2&uptype=$uptype&mkvalue=$mkvalue");
        exit();
    }
    //更新文档
    /*-------------------
    function _2_MakeArchives()
    ---------------------*/
    else if($step==2)
    {
        include_once(DEDEADMIN."/makehtml_archives_action.php");
        exit();
    }
    //更新主页
    /*-------------------------
    function _3_MakeHomePage()
    -------------------*/
    if($step==3)
    {
        include_once(DEDEINC."/arc.partview.class.php");
        $pv = new PartView();
        $row = $pv->dsql->GetOne("SELECT * FROM `#@__homepageset` ");
		$templet = str_replace("{style}", $cfg_df_style,$row['templet']);
		$homeFile = DEDEADMIN.'/'.$row['position'];
		$homeFile = str_replace("\\", '/', $homeFile);
		$homeFile = preg_replace("#\/{1,}#" ,'/', $homeFile);
		if($row['showmod'] == 1)
		{
			$pv->SetTemplet($cfg_basedir.$cfg_templets_dir.'/'.$templet);
			$pv->SaveToHtml($homeFile);
			$pv->Close();
		} else {
			if (file_exists($homeFile)) @unlink($homeFile);
		}
        ShowMsg("完成更新所有文档,现在开始更新栏目页!","makehtml_all.php?action=make&step=4&uptype=$uptype&mkvalue=$mkvalue");
        exit();
    }
    //更新栏目
    /*-------------------
    function _4_MakeCatalog()
    --------------------*/
    else if($step==4)
    {
        $mkvalue = intval($mkvalue);
        $typeidsok = $typeids = array();
        $adminID = $cuserLogin->getUserID();
        $mkcachefile = DEDEDATA."/mkall_cache_{$adminID}.php";
        if($uptype=='all' || empty($mkvalue))
        {
            ShowMsg("不需要进行初处理,现更新所有栏目!", "makehtml_list_action.php?gotype=mkallct");
            exit();
        }
        else
        {
            if($uptype=='time')
            {
                $query = "SELECT  DISTINCT typeid From `#@__arctiny` WHERE senddate >=".GetMkTime($mkvalue)." AND arcrank>-1";
            }
            else
            {
                $query = "SELECT DISTINCT typeid From `#@__arctiny` WHERE id>=$mkvalue AND arcrank>-1";
            }
            $dsql->SetQuery($query);
            $dsql->Execute();
            while($row = $dsql->GetArray())
            {
                $typeids[$row['typeid']] = 1;
            }

            foreach($typeids as $k=>$v)
            {
                $vs = array();
                $vs = GetParentIds($k);
                if( !isset($typeidsok[$k]) )
                {
                    $typeidsok[$k] = 1;
                }
                foreach($vs as $k=>$v)
                {
                    if(!isset($typeidsok[$v]))
                    {
                        $typeidsok[$v] = 1;
                    }
                }
            }
        }
        $fp = fopen($mkcachefile,'w') or die("无法写入缓存文件:{$mkcachefile} 所以无法更新栏目!");
        if(count($typeidsok)>0)
        {
            fwrite($fp,"<"."?php\r\n");
            $i = -1;
            foreach($typeidsok as $k=>$t)
            {
                if($k!='')
                {
                    $i++;
                    fwrite($fp, "\$idArray[$i]={$k};\r\n");
                }
            }
            fwrite($fp,"?".">");
            fclose($fp);
            ShowMsg("完成栏目缓存处理,现转向更新栏目!","makehtml_list_action.php?gotype=mkall");
            exit();
        }
        else
        {
            fclose($fp);
            ShowMsg("没有可更新的栏目,现在作最后数据优化!","makehtml_all.php?action=make&step=10");
            exit();
        }
    }
    //成功状态
    /*-------------------
    function _10_MakeAllOK()
    --------------------*/
    else if($step==10)
    {
        $adminID = $cuserLogin->getUserID();
        $mkcachefile = DEDEDATA."/mkall_cache_{$adminID}.php";
        @unlink($mkcachefile);
        OptimizeData($dsql);
        ShowMsg("完成所有文件的更新!","javascript:;");
        exit();
    }//make step

} //action=='make'

/**
 *  优化数据
 *
 * @access    public
 * @param     object  $dsql  数据库对象
 * @return    void
 */
function OptimizeData($dsql)
{
    global $cfg_dbprefix;
    $tptables = array("{$cfg_dbprefix}archives","{$cfg_dbprefix}arctiny");
    $dsql->SetQuery("SELECT maintable,addtable FROM `#@__channeltype` ");
    $dsql->Execute();
    while($row = $dsql->GetObject())
    {
        $addtable = str_replace('#@__',$cfg_dbprefix,$row->addtable);
        if($addtable!='' && !in_array($addtable,$tptables)) $tptables[] = $addtable;
    }
    $tptable = '';
    foreach($tptables as $t) $tptable .= ($tptable=='' ? "`{$t}`" : ",`{$t}`" );
    $dsql->ExecuteNoneQuery(" OPTIMIZE TABLE $tptable; ");
}

新增文件的代码

<?php
/**
 * 生成所有页面
 *
 * @version        $Id: makehtml_all.php 1 8:48 2010年7月13日Z tianya $
 * @package        DedeCMS.Administrator
 * @copyright      Copyright (c) 2007 - 2010, DesDev, Inc.
 * @license        http://help.dedecms.com/usersguide/license.html
 * @link           http://www.dedecms.com
 */
require_once(dirname(__FILE__)."/config.php");
require_once(DEDEINC."/channelunit.func.php");
$action = (empty($action) ? '' : $action);

if($action=='')
{
    require_once(DEDEADMIN."/templets/makehtml_all_*.htm");
    exit();
}
else if($action=='make')
{
    //step = 1 更新主页、step = 2 更新内容、step = 3 更新栏目
    if(empty($step)) $step = 1;

    //更新文档前优化数据
    /*-------------------
    function _1_OptimizeData1()
    ---------------------*/
    if($step==1)
    {
        $starttime = GetMkTime($starttime);
        $mkvalue = ($uptype=='time' ? $starttime : $startid);
        OptimizeData($dsql);
        ShowMsg("完成数据优化,现在开始更新文档!","makehtml_all_*.php?action=make&step=2&uptype=$uptype&mkvalue=$mkvalue");
        exit();
    }
    //更新文档
    /*-------------------
    function _2_MakeArchives()
    ---------------------*/
    else if($step==2)
    {
        include_once(DEDEADMIN."/makehtml_archives_action_*.php");
        exit();
    }
    //更新主页
    /*-------------------------
    function _3_MakeHomePage()
    -------------------*/
    if($step==3)
    {
        include_once(DEDEINC."/arc.partview.class.php");
        $pv = new PartView();
        $row = $pv->dsql->GetOne("SELECT * FROM `#@__homepageset` ");
		$templet = str_replace("{style}", $cfg_df_style,$row['templet']);
		$homeFile = DEDEADMIN.'/'.str_replace("../", '../m/',$row['position']);
		$homeFile = str_replace("\\", '/', $homeFile);
		$homeFile = preg_replace("#\/{1,}#" ,'/', $homeFile);
		if($row['showmod'] == 1)
		{
			$pv->SetTemplet($cfg_basedir.$cfg_templets_dir.'/'.$cfg_df_style.'/'.basename($templet,'.htm').'_*.htm');
			$pv->SaveToHtml($homeFile);
			$pv->Close();
		} else {
			if (file_exists($homeFile)) @unlink($homeFile);
		}
        ShowMsg("完成更新所有文档,现在开始更新栏目页!","makehtml_all_*.php?action=make&step=4&uptype=$uptype&mkvalue=$mkvalue");
        exit();
    }
    //更新栏目
    /*-------------------
    function _4_MakeCatalog()
    --------------------*/
    else if($step==4)
    {
        $mkvalue = intval($mkvalue);
        $typeidsok = $typeids = array();
        $adminID = $cuserLogin->getUserID();
        $mkcachefile = DEDEDATA."/mkall_cache_{$adminID}.php";
        if($uptype=='all' || empty($mkvalue))
        {
            ShowMsg("不需要进行初处理,现更新所有栏目!", "makehtml_list_action_*.php?gotype=mkallct");
            exit();
        }
        else
        {
            if($uptype=='time')
            {
                $query = "SELECT  DISTINCT typeid From `#@__arctiny` WHERE senddate >=".GetMkTime($mkvalue)." AND arcrank>-1";
            }
            else
            {
                $query = "SELECT DISTINCT typeid From `#@__arctiny` WHERE id>=$mkvalue AND arcrank>-1";
            }
            $dsql->SetQuery($query);
            $dsql->Execute();
            while($row = $dsql->GetArray())
            {
                $typeids[$row['typeid']] = 1;
            }

            foreach($typeids as $k=>$v)
            {
                $vs = array();
                $vs = GetParentIds($k);
                if( !isset($typeidsok[$k]) )
                {
                    $typeidsok[$k] = 1;
                }
                foreach($vs as $k=>$v)
                {
                    if(!isset($typeidsok[$v]))
                    {
                        $typeidsok[$v] = 1;
                    }
                }
            }
        }
        $fp = fopen($mkcachefile,'w') or die("无法写入缓存文件:{$mkcachefile} 所以无法更新栏目!");
        if(count($typeidsok)>0)
        {
            fwrite($fp,"<"."?php\r\n");
            $i = -1;
            foreach($typeidsok as $k=>$t)
            {
                if($k!='')
                {
                    $i++;
                    fwrite($fp, "\$idArray[$i]={$k};\r\n");
                }
            }
            fwrite($fp,"?".">");
            fclose($fp);
            ShowMsg("完成栏目缓存处理,现转向更新栏目!","makehtml_list_action_*.php?gotype=mkall");
            exit();
        }
        else
        {
            fclose($fp);
            ShowMsg("没有可更新的栏目,现在作最后数据优化!","makehtml_all_*.php?action=make&step=10");
            exit();
        }
    }
    //成功状态
    /*-------------------
    function _10_MakeAllOK()
    --------------------*/
    else if($step==10)
    {
        $adminID = $cuserLogin->getUserID();
        $mkcachefile = DEDEDATA."/mkall_cache_{$adminID}.php";
        @unlink($mkcachefile);
        OptimizeData($dsql);
        ShowMsg("完成所有文件的更新!","javascript:;");
        exit();
    }//make step

} //action=='make'

/**
 *  优化数据
 *
 * @access    public
 * @param     object  $dsql  数据库对象
 * @return    void
 */
function OptimizeData($dsql)
{
    global $cfg_dbprefix;
    $tptables = array("{$cfg_dbprefix}archives","{$cfg_dbprefix}arctiny");
    $dsql->SetQuery("SELECT maintable,addtable FROM `#@__channeltype` ");
    $dsql->Execute();
    while($row = $dsql->GetObject())
    {
        $addtable = str_replace('#@__',$cfg_dbprefix,$row->addtable);
        if($addtable!='' && !in_array($addtable,$tptables)) $tptables[] = $addtable;
    }
    $tptable = '';
    foreach($tptables as $t) $tptable .= ($tptable=='' ? "`{$t}`" : ",`{$t}`" );
    $dsql->ExecuteNoneQuery(" OPTIMIZE TABLE $tptable; ");
} 

特别说明:代码中的*为自定义字母,如果要生成移动静态化时:*=m 如果要生成MIP页面是:*=mip,其他依次类推