C#-ASP.NET网站地图,有多重要?

我已经完成了我的网站,或者是这样想.我没有站点地图,但由于奇迹,我错过了站点地图的整个概念,甚至都不知道这是一回事.我想我的CS老师大声喊叫.

我一直在阅读它,动态生成站点地图似乎相当复杂,这是必须要做的,因为我的页面基本上只是一个大型数据库,您可以在其中使用参数进行搜索.

这对Google搜索引擎的相关性有多重要?例如,如果有人在Google上搜索我的网站,例如“ www.mySite.com食物”.如果我在数据库中有一个名为“食品”的类别,并且确实有人在我的网站上使用搜索,他们会找到一个食品类别,但是Google会知道吗? Google是否会找到“ www.mySite.com/Find?Result=food”?

编辑:使用可以在ASP.NET中创建的Web.Sitemap甚至是正确的还是我应该使用一个名为sitemap.txt的文件?

解决方法:

网站地图类型

有3种不同的“站点地图”.

>带有链接的页面,可通过向用户提供站点结构的完整轮廓来帮助他们.有时但并非总是遵循网站层次结构.而且,它通常仅限于网站的主要类别.详细页面通常不会列出.
> ASP.NET中的一个系统,可帮助构建菜单,面包屑跟踪以及网站的其他导航功能.这由默认情况下使用.sitemap XML文件的提供程序驱动.
> XML文档,该文档提供到网站页面的链接以及有关页面的最新更新时间,更新的重要性等信息,以帮助在搜索引擎中为网站建立索引.

一个简短的历史

如果您查看历史记录,它将使解析此信息的混乱程度降低.上面的列表按时间顺序排列. “站点地图”最初是一个术语,旨在提供链接到网站主要部分的用户页面. Microsoft决定再次使用术语“站点地图”来指代其ASP.NET 2.0导航系统.几年后,主要的搜索引擎联手提供了XML规范,用于提供有关站点的URL信息,不幸的是,它们再次重载了“站点地图”一词来描述它们.

这段历史的后果之一是ASP.NET没有对XML站点地图的内置支持,这听起来像您是在根据自己的问题进行尝试.这主要是因为自ASP.NET 2.0以来,Microsoft的实现并未发生太大变化,并且它是在该规范实现之前编写的.因此,使用Microsoft的ASP.NET导航系统对生成XML网站地图不利.

SEO注意事项

但是请注意,所有这三个项目对于SEO都很重要.

>用户站点地图有助于为搜索引擎建立索引,因为它提供了指向需要索引的主要区域的内部站点链接.
>菜单和痕迹对于将所有内容页面相互链接很重要,这有助于确定站点不同部分之间的相关性.
> XML站点地图可为搜索引擎提供直接的URL信息,并有助于减少站点上搜索引擎的流量,并有助于确保没有重要的URL被搜索引擎考虑用于索引.

因此,尽管严格地说,所有这些都是可选的,但您可能需要将它们考虑在内.

SEO首先要提供良好的内容,然后执行所需的步骤,以便可以访问内容.上面的每个步骤都应被视为SEO的一项进步,如果您确实在乎搜索引擎的位置,则应尽一切可能,包括所有这三个步骤.

XML Sitemap推荐

实际上,对于50,000页以下的小型网站,XML sitemap specification非常简单.因此,将它们组合在一起通常不需要太多的工作.您可能要考虑自己做.

大多数开放源代码实现的伸缩性都不高,因为它们都将整个数据集一次加载到内存中以生成XML而不是流式传输.而且,大多数情况并不能真正说明您可能在多个表中包含动态数据的事实,这些数据都构成了网站的URL.他们通常由您来提供分页.大多数现有的实现也不提供Google提供的specialized content types.

我最近创建了可完成所有这些功能的an implementation.它尚未正式发布,目前是MvcSiteMapProvider项目的一部分.我们计划将XML网站地图功能分离到不同的程序集(和单独的NuGet程序包)中,以便可以在不引用MVC的情况下使用它,但是现在MVC是必需的(除非您希望获取所有相关类型并进行编译)自己放入一个单独的DLL中).带有MVC的ASP.NET项目仍然可以正常运行,因此,对于大多数项目而言,这并不是什么大问题.

目前没有任何文档,但是我创建了一个quick post,展示了如何在MVC中进行连接,包括一个演示应用程序.

对于ASP.NET,您可以使用MVC实现(如果安装了MvcSiteMapProvider,则无论如何它将MVC安装到您的项目中),也可以只使用ASP.NET页.

在第二种情况下,配置看起来很相似,但有一些例外.

>您不需要使用XmlSitemapFeedRouteRegistrar类.
>您(当然)不需要使用Controller,可以将其替换为ASP.NET页面,如下所示:

XmlSitemap.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="XmlSitemap.aspx.cs" Inherits="XmlSitemap" %>

XmlSitemap.aspx.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using MvcSiteMapProvider.IO;
using MvcSiteMapProvider.Xml.Sitemap;
using MvcSiteMapProvider.Xml.Sitemap.Configuration;

public partial class XmlSitemap : System.Web.UI.Page
{
    private HttpContextBase HttpContext
    {
        get { return new HttpContextWrapper(System.Web.HttpContext.Current); }
    }

    private int PageNumber
    {
        get
        {
            var pageString = HttpContext.Request.QueryString["page"];
            if (!string.IsNullOrEmpty(pageString))
            {
                int page;
                if (int.TryParse(pageString, out page))
                {
                    return page;
                }
            }
            return 0;
        }
    }

    private string FeedName
    {
        get
        {
            var feedName = HttpContext.Request.QueryString["feedName"];
            if (!string.IsNullOrEmpty(feedName))
            {
                return feedName;
            }
            return "default";
        }
    }

    protected void Page_Load(object sender, EventArgs e)
    {
        // Build feeds for XML sitemap
        var xmlSitemapFeedStrategy = new XmlSitemapFeedStrategyBuilder()
            .SetupPageNameTempates(templates => templates
                .WithDefaultFeedRoot("XmlSitemap.aspx?feedName={feedName}&page={page}")
                .WithDefaultFeedPaged("XmlSitemap.aspx?feedName={feedName}&page={page}")
                .WithNamedFeedRoot("XmlSitemap.aspx?feedName={feedName}&page={page}")
                .WithNamedFeedPaged("XmlSitemap.aspx?feedName={feedName}&page={page}"))
            .AddDefaultFeed()
            .AddNamedFeed("google", feed => feed.WithContent(c => c.Image().Video()))

            // Optional - add news feed (will be at ~/XmlSitemap.aspx?feedName=news)
            .AddNamedFeed("news", feed => feed.WithContent(c => c.News()))

            // Optional - add mobile feed (will be at ~/XmlSitemap.aspx?feedName=mobile)
            .AddNamedFeed("mobile", feed => feed.WithContent(c => c.Mobile()).WithMaximumPageSize(10000))
            .Create();

        var xmlSitemapFeed = xmlSitemapFeedStrategy.GetFeed(this.FeedName);

        if (xmlSitemapFeed != null)
        {
            var outputCompressor = new HttpResponseStreamCompressor();
            var response = HttpContext.Response;

            response.Clear();

            // Output content type
            response.ContentType = "text/xml";

            using (var stream = outputCompressor.Compress(HttpContext))
            {
                if (!xmlSitemapFeed.WritePage(this.PageNumber, stream))
                {
                    response.Clear();
                    //Return 404 not found
                    response.StatusCode = (int)System.Net.HttpStatusCode.NotFound;
                    response.StatusDescription = "Page Not Found";
                }
            }

            response.End();
        }
    }
}

上面的配置实际上创建了4个不同的XML网站地图供稿,主要是为了遵守这些特殊类型的规范.

>默认-/XmlSitemap.aspx-可与任何搜索引擎一起使用的站点地图.根据XML sitemap specification,此网址必须位于robots.txt文件中.
> Google-/XmlSitemap.aspx?feedName=google-此站点地图包含与Default相同的URL,但还包括图像和视频专用内容.由于编码错误的搜寻器在遇到Google的任何特殊类型时可能会崩溃,因此我将它们分成了不同的供稿.您需要通过其网站站长工具将该网址手动提交给Google.
>新闻-/XmlSitemap.aspx?feedName=news-这用于Google的新闻站点地图功能,需要提交per their specifications.
>移动-/XmlSitemap.aspx?feedname=mobile-这是针对Google的移动站点地图功能,需要提交per their specifications.

请注意,也可以在ASP.NET中使用路由使这些URL更美观.您只需要确保在指定名称模板的上方(与通过路由生成URL的方式相同),即可将{feedName}和{page}的占位符放在URL中的适当位置.

请注意,根据XML网站地图规范,XML网站地图不能包含其虚拟目录上方的目录的任何URL.因此,最好确保您的路由不包含任何/字符(这意味着它适用于整个站点,而不是子目录).

上一篇:CodeGo.net>如何在sitecore中获取媒体项目的详细信息?


下一篇:免费搜索引擎提交(登录)入口大全