• How to create UrlSlug in Asp.Net MVC


    转自:http://www.ehsanghanbari.com/Post/20/how-to-create-urlslug-in-aspnet-mvc

    UrlSlug Is a way of generating a valid Url, and using the title of an article to generate a URL. UrlSlug is very important in CEO because google likes to index the meaningful Urls at the first and then it refers to other Urls. Spouse you wanna to create the this Url:

    1. MyWebSite.com/Blog/Post/2013/4/14/how-to-create-url-slug-in-aspnet-mvc

    create the model class :

    public class Blog 
    { 
            public int Id { get; set; } 
            public string Title { get; set; } 
            public string Body { get; set; } 
            public string PostSlug { get; set; } 
            public DateTime CreationTime { get; set; } 
    }

    Now to creating the UrlSlud you have to call a function, you can create it as an extension method like this:

    public static class SlugGeneratorHelper 
    { 
        public static string GenerateSlug(
    this string phrase, int maxLength = 100) 
        { 
            string str = phrase.ToLower(); 
            str = Regex.Replace(str, @"[^a-z0-9s-]", ""); 
            str = Regex.Replace(str, @"[s-]+", " ").Trim(); 
            str = str.Substring(0, str.Length <= maxLength ? 
    str.Length : maxLength).Trim(); 
            str = Regex.Replace(str, @"s", "-"); 
            return str; 
        } 
    }

    Now it's time to use this extension method, create the CreatePost action and use the GenerateSlug

    public ActionResult CreatePost()
            {
                    return View("CreatePost");
            }
     
            [HttpPost]
            public ActionResult CreatePost(Blog blog)
            {
                if (ModelState.IsValid)
                {
                    _blogService.CreateBlogPost(blog);
                     blog.PostSlug = blog.Title.GenerateSlug();
                }
                return View("CreatePost");
            }

    You craeted the postSlug, now about how to use and show it in URL look at the action below

    public ActionResult Post(int year, int month, int day, string postSlug) 
            { 
                var post = _blogService.GetBlogPostByDate(year,month,day,postSlug); 
                return View("Post", post); 
            }

    GetBlogPostByDate is a method that you can define in your repository to get the post by year, month , day and postSlug ; something like this:

    public Blog GetBlogPostByDate (int year, int month, int day,string postSlug) 
            { 
                var query = 
                    _dbContextConfiguration.Blog.Where( 
                        p => p.CreationTime.Year == year && p.CreationTime.Month == month && p.CreationTime.Day == day&&p.PostSlug==postSlug); 
    
                return query.Single(); 
            }

    Finally register this route in your global.

    asax
    
     routes.MapRoute("BlogRoute", 
                                "Post/{year}/{month}/{day}/{postSlug}", 
                                new 
                                    { 
                                        controller = "Blog", 
                                        action = "Post", 
                                        year = UrlParameter.Optional, 
                                        month = UrlParameter.Optional, 
                                        day = UrlParameter.Optional, 
                                        newsSlug = "" 
                                    }, 
                                      new[] { "SampleProject.Web.Mvc.UI.Controllers" });

    You have done, test it!

  • 相关阅读:
    关于Mobx中装饰器语法的环境配置
    关于Java单例模式中懒汉式和饿汉式的两种类创建方法
    Java学习笔记之异常处理
    create-react-app脚手架的安装和目录结构介绍
    关于win10下JDK环境变量的配置以及关于JDK的一些说明
    关于Android studio的安装和配置问题
    关于通过ServletContext获取数据出现的http500的错误的解决方案
    关于form表单提交到Servlet的时候出现tomcat启动错误的解决方法
    Android网络编程系列之Volley总结
    Android网络编程系列之HTTP协议原理总结
  • 原文地址:https://www.cnblogs.com/msdynax/p/3746560.html
Copyright © 2020-2023  润新知