zoukankan      html  css  js  c++  java
  • 织梦dedecms默认网站地图sitemap.html优化

    网站地图对于网站优化很重要,搜索引擎就是靠网站地图去收录网站页面,本文主要讲解优化织梦自带的网站地图功能。
        织梦自带的网站地图使用方法:织梦后台——生成——HTML更新——更新网站地图,可以在data目录下生成sitemap.html 。
    缺点很明显:
    1、生成的地图太简单,sitemap.html里面只有网站栏目列表,没有网站文章列表
    2、sitemap.html生成的位置在data文件夹中,而data文件夹一般情况下为了安全是禁止访问的。
     
    所以我们优化的工作就是让sitemap.html生成文章列表,并且生成在网站根目录。
     
        以DEDECMS5.7为例:网站地图的模板sitemap.htm 在/templets/plus/目录里,就算在sitemap.htm中添加了织梦文章列表相关标签,也不能调用文章列表。
     
        这是因为makehtml_map.php不能解析织梦的相关调用标签,我们可以稍作修改。让他实现调用任意标签。
       备注:makehtml_map.php所在位置“根目录/dede/makehtml_map.php”
     
    修改makehtml_map.php如下:
     
    (1)把
    require_once(DEDEINC."/dedetag.class.php");
    改成
    require_once(DEDEINC."/arc.partview.class.php");
    (2)把
    $dtp = new DedeTagParse();
    $dtp->LoadTemplet($tmpfile);
    $dtp->SaveTo($cfg_basedir.$murl);
    改成
    $dtp = new PartView();
    $GLOBALS['_arclistEnv'] = 'index';
    $dtp->SetTemplet($tmpfile);
    $dtp->SaveToHtml($cfg_basedir.$murl);
    (3)把
    $dtp->Clear();
    注释掉
    //$dtp->Clear();
     
    更新:
    (4)26行 把
        $murl = $cfg_cmspath."/data/sitemap.html";
        $tmpfile = $cfg_basedir.$cfg_templets_dir."/plus/sitemap.htm";
    改成
        $murl = $cfg_cmspath."/sitemap.html";
        $tmpfile = $cfg_basedir.$cfg_templets_dir."/".$cfg_df_style."/sitemap.htm";
    都改好之后就可以解析dedecms所有的标签了,包括文章列表标签。
     
    要解释的是最后:
    $cfg_basedir.$cfg_templets_dir."/plus/sitemap.htm"; 
    改成
    $cfg_basedir.$cfg_templets_dir."/".$cfg_df_style."/sitemap.htm";
     
        更 改的用途是:原来网站地图模板的路径是固定在/plus/目录中的,即sitemap.htm的位置为“根目录/templets/plus /sitemap.htm”,更改之后sitemap.htm的位置改成网站模版所在目录,这样我们在自己的模版文件夹中新建个sitemap.htm文 件任意编辑成自己喜欢的网站地图模板就可以了。
     
        懒鸟飞测试后发现,用这种方法做的网站地图有个小问题,就是文章列表没有分页效果,所以需要设置的文章显示数量多一点。懒鸟飞提供了个简单的模板,新建一个网站地图模板sitemap.htm ,模板中添加下面的代码:
    <html>
    <head>
    <title>网站地图/{dede:global.cfg_webname/}</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
    <body>
    <a href="{dede:global.cfg_indexurl/}">返回首页</a>
    <br />
    ----------------------栏目列表----------------------
    {dede:global name='maplist'/}
    ----------------------文章列表----------------------
    <ul>
    {dede:arclist typeid='' orderby=’pubdate’ row='999999' }
    <li><a href="[field:arcurl/]">[field:title/]</a></li>
    {/dede:arclist}
    </ul>
    </body>
    </html> 
     
        之后把sitemap.htm放到自己的模板文件夹中,再点击后台——生成——更新网站地图。查看:http://你的域名/sitemap.html ,就可以看到自己的sitemap.html了。
  • 相关阅读:
    ZMQ和MessagePack的简单使用(转)
    easyui datagrid列中使用tooltip
    在bat中执行sql,并配置windows计划任务,并隐藏命令窗口 (转)
    前端基于jquery的UI框架
    菜鸟学步之 爆破AspriseOCR 4.0
    C# 图片识别(支持21种语言) (转)
    IIS Web服务扩展中没有Asp.net 2.0
    遭遇sql server 2005 启动包未能正确加载需要重新安装错误,重装.NET FRAMEWORK经历分析
    利用Aspose.Cells完成easyUI中DataGrid数据的Excel导出功能
    JS Replace() 高级用法(转)
  • 原文地址:https://www.cnblogs.com/haihua85/p/8681680.html
Copyright © 2011-2022 走看看