Orchardcms 如何通过代码将新的Orchard模块设置为主页

Orchardcms 如何通过代码将新的Orchard模块设置为主页,orchardcms,Orchardcms,我对乌节很陌生 为了学习orchard模块开发,我遵循文档并尝试创建一个商业模块 该模块由产品部件和具有产品部件的产品类型组成 在启用模块期间,它将为该模块创建管理和主菜单,分别为“Commerce”和“Shop” 我的问题是 如何在启用模块期间使此模块成为主页。换句话说,我要的是索引方法 模块的HomeController句柄主url 如何使前端的商店菜单位于主菜单之后或将此模块注册到主菜单 我附上源代码,请从以下链接下载 如果您的模块将被其他人使用,那么最好制作一个可以添加到任何层(例如

我对乌节很陌生

为了学习orchard模块开发,我遵循文档并尝试创建一个商业模块

该模块由产品部件和具有产品部件的产品类型组成

在启用模块期间,它将为该模块创建管理和主菜单,分别为“Commerce”和“Shop”

我的问题是

  • 如何在启用模块期间使此模块成为主页。换句话说,我要的是索引方法 模块的HomeController句柄主url
  • 如何使前端的商店菜单位于主菜单之后或将此模块注册到主菜单
我附上源代码,请从以下链接下载


如果您的模块将被其他人使用,那么最好制作一个可以添加到任何层(例如主页层)的小部件。这样,每个用户都可以决定模块在何处发挥作用。 如果您仅为自己使用此模块,则可以覆盖默认路由(标准mvc功能)。 看看我的ExtendedRegistration模块(Routes.cs),看看它是如何完成的

这里我覆盖了标准的帐户/注册URL。不应该有任何东西阻止您覆盖默认HomeController

public class Routes : IRouteProvider
    {

        public void GetRoutes(ICollection<RouteDescriptor> routes)
        {
            foreach (var routeDescriptor in GetRoutes())
            {
                routes.Add(routeDescriptor);
            }
        }

        public IEnumerable<RouteDescriptor> GetRoutes()
        {
            return new[] {

                    new RouteDescriptor {
                    Priority = 19,
                    Route = new Route(
                        "Users/Account/Register",
                        new RouteValueDictionary {
                            {"area", "itWORKS.ExtendedRegistration"},
                            {"controller", "Account"},
                            {"action", "Register"}
                        },
                        new RouteValueDictionary(),
                        new RouteValueDictionary {
                            {"area", "itWORKS.ExtendedRegistration"}
                        },
                        new MvcRouteHandler())
                }
            };
        }
    }
公共类路由:IRouteProvider
{
公共路线(ICollection路线)
{
foreach(GetRoutes()中的var routedDescriptor)
{
routes.Add(RoutedDescriptor);
}
}
公共IEnumerable GetRoutes()
{
返回新的[]{
新路由描述符{
优先级=19,
路线=新路线(
“用户/帐户/注册”,
新RouteValueDictionary{
{“区域”、“itWORKS.ExtendedRegistration”},
{“控制器”、“帐户”},
{“动作”、“寄存器”}
},
新建RouteValueDictionary(),
新RouteValueDictionary{
{“区域”,“itWORKS.ExtendedRegistration”}
},
新的MvcRouteHandler())
}
};
}
}

要接管主页,标准的Orchard方法是实现IHomePageProvider。

在模块中创建作为migrations.cs一部分的页面时,可以告诉自动路由部分将创建页面的别名设置为主页:

        //create a page page
        var homepage = _contentManager.Create("Page");
        homepage.As<TitlePart>().Title = "My Home";            
        _contentManager.Publish(homepage);

        var homePageArp = homepage.As<AutoroutePart>();
        homePageArp.DisplayAlias = String.Empty;            
        _autorouteService.PublishAlias(homePageArp);
//创建一个页面
var homepage=_contentManager.Create(“页面”);
homepage.As().Title=“我的家”;
_contentManager.Publish(主页);
var homePageArp=homepage.As();
homePageArp.DisplayAlias=String.Empty;
_autorouteService.PublishAlias(homePageArp);
这假设您从一个干净的Orchard实例出发,没有任何以前的主页;如果你有一个现有的主页,你将不得不重新生成这些网页的别名作为你的模块的一部分。这是如何作为Orchard.Autoroute项目(在Publish Alias方法中)中的AutoroutePartHandler的一部分完成的:

//重新生成上一主页的别名
var currentHomePages=\u orchardServices.ContentManager.Query()。其中(x=>x.DisplayAlias==“”)。List();
foreach(当前主页中的当前变量){
如果(当前!=null){
current.CustomPattern=String.Empty;//强制重新生成
current.DisplayAlias=\u autorouteService.Value.GenerateAlias(当前);
}
_autorouteService.Value.PublishAlias(当前);
}
_autorouteService.Value.PublishAlias(部分);

如果您深入研究autoroute项目的驱动程序和处理程序,您将了解到许多内部信息;当您在管理UI中勾选“设置为主页”框时,它会将路径设置为“/”,然后该路径被拾取,触发旧主页重新连接,清除“/”路径为String.Empty,然后发布该空白别名,从而为您提供一个新主页


(从Orchard 1.6开始有效)

+1回答问题的第一部分。@bertrand有一个非常有用的简洁答案!非常感谢你的回答。然而,对于实现IHomeProvider的类以及将该类放在何处,我需要遵循一些类名约定。IHomePageProvider已经不存在了(至少在Orchard 1.6中是这样)——请查看别名/自动路由部分。
            // regenerate the alias for the previous home page
            var currentHomePages = _orchardServices.ContentManager.Query<AutoroutePart, AutoroutePartRecord>().Where(x => x.DisplayAlias == "").List();
            foreach (var current in currentHomePages) {
                if (current != null) {
                    current.CustomPattern = String.Empty; // force the regeneration
                    current.DisplayAlias = _autorouteService.Value.GenerateAlias(current);
                }
                _autorouteService.Value.PublishAlias(current);
            }


        _autorouteService.Value.PublishAlias(part);