MVC 4 を使用して、ブログに SEO に適したルートを探しています。いくつかのスタックオーバーフローの記事を調べて、アドバイスを利用しようとしましたが、まだ適切に機能させることができません。
私がやろうとしているのは、誰かがブログ投稿の 1 つをクリックすると、ルートが表示されることです: blog/{blogCategory}/{blogTitle}、たとえば「blog/cleaning/how-to-remove-stains」。私は何か重要なものを見逃しています。コントローラー、ビュー、ルートを含めました。2 つの質問があります。
blogTitle (「スペインの雨」) をコントローラーに渡すと、ハイフンとスペースが含まれるのはなぜですか? タイトルを取得して関数を実行して URL フレンドリーにし、ルートに表示されるように戻したいと考えています。
ルートが部分的にしか機能しないのはなぜですか? blog/{blogCategory}/{blogTitle} を表示する代わりに、blog/{blogCategory}?querystrings を表示します。以下の例を参照してください: blog/uncategorized/the%20-rain%20in%20-spain%20-falls%20-mainly%20on %20the%20-plains?id=2. (注: uncategorized はカテゴリの 1 つです)
ルート構成:
public class RouteConfig
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.Canonicalize().NoWww().Pattern("([a-z0-9])([A-Z])", "$1-$2").Lowercase().NoTrailingSlash();
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
"Blog",
"Blog/{blogCategory}/{blogTitle}",
new { controller = "Blog", action = "Details" }
).RouteHandler = new Spotless_Interiors.Models._GlobalClasses.HyphenatedRouteHandler();
// Original route map
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
).RouteHandler = new Spotless_Interiors.Models._GlobalClasses.HyphenatedRouteHandler();
}
}
見る:
@model Spotless_Interiors.Models.MultiModels
@{
ViewBag.Title = "Blog";
ViewBag.Separator = " | ";
ViewBag.Path = Request.Path;
}
@section menuLeft {
@Html.Partial("_BlogMenu")
}
@Html.Partial("_TitleBlockPartial", Model.Company)
@if (User.Identity.IsAuthenticated) {
<div class="blog-links">
@Html.ActionLink("Create New", "Create", "Blog", new { DT_Stamp = @DateTime.Now })
@ViewBag.Separator
<a href="@Url.Action("Meta-Tag-Editor", "Dashboard", new { pageName = (string)ViewBag.pageName, path = (string)ViewBag.Path })" >MetaTag</a>
<hr />
</div>
}
<div id="blog">
@foreach (var item in Model.PagedPosts)
{
<h1>@Html.ActionLink(item.Title, "Details", new { id = item.PostID, blogCategory = item.Category.CategoryName, blogTitle = item.Title }, new { @class ="blog-title" }) </h1>
<div class="full-width">
<div class="blog-category">
<h2>@Html.DisplayFor(modelItem => item.Category.CategoryName) | @Html.DisplayFor(modelItem => item.DT_Stamp)</h2>
</div>
<div class="blog-links">
@Html.ActionLink("Read More >>", "Details", new { id = item.PostID, blogCategory = item.Category.CategoryName, blogTitle = item.Title }, new { @class ="blog-links" })
</div>
</div>
<div class="full-width">
</div>
@Html.Raw(Server.HtmlDecode(item.TruncatedBody.Replace("<img ", "<img style = 'width:100px' ")))
<div class="ribbon" style="clear:both"></div>
}
</div>
コントローラ:
// GET: /Blog/Details
public ActionResult Details(int id = 0, string blogCategory = "", string blogTitle = "")
{
pageName = "Blog Details";
ViewBag.pageName = pageName;
var multiModels = _globalClasses.Standard(ViewBag.pageName, Request.Path);
///multiModels.Post = db.Posts.First(i => i.PostID == id);
multiModels.Post = db.Posts.First(i => i.PostID == id);
multiModels.PostComments = db.PostComments.Where(i => i.PostPostID == id).ToList();
blogTitle = _globalClasses.UrlFriendly(blogTitle);
if (multiModels.Post == null)
{
return HttpNotFound();
}
return View(multiModels);
}