如何在尊重路由配置的同时解决Kentico Cloud中的内容项链接?

问题描述 投票:2回答:1

ASP.NET Core 2.2网站显示来自Kentico Cloud CMS的数据。某些项目包含富文本字段。这些字段可能包含指向其他内容项的链接。这些链接应该由网站解析为URL。

这个docs建议通过实现IContentLinkUrlResolver接口来完成。但是,为了我们网站的目的,样本太虚拟了。我们的解析器需要知道请求的上下文(比如当前的UI文化,因为站点是多语言环境)和路由定义,因为这是唯一定义URL应该如何的地方。

事实上,解析器需要能够调用Url.Action,因为它可以在视图中。

网址解析器应该尊重路线和当前的ui文化。它的逻辑预计如下:

if (the linked content item type is Page)
{
    Url.Action("Page", "Home", new [] { codename = content item’s codename });
}
else if (the linked content item type is PageFont)
{
    Url.Action("Font", "Home", new [] { codename = content item’s codename });
}
else
{
    throw an error about an unsupported content type.
}

规则定义为:

var localizationOptions = app.ApplicationServices.GetService<IOptions<RequestLocalizationOptions>>();

app.UseRouter(routes =>
{
    routes.MapMiddlewareRoute("{culture=en-US}/{*mvcRoute}", subApp =>
    {
        subApp.UseRequestLocalization(localizationOptions.Value);

        subApp.UseMvc(mvcRoutes =>
        {
            mvcRoutes.MapRoute(
                name: "areas",
                template: "{culture=en-US}/{area:exists}/{controller=Home}/{action=Index}/{id?}");

            mvcRoutes.MapRoute(
                name: "sitemap",
                defaults: new { controller = "Sitemap", action = "Index" },
                template: "sitemap.xml");

            mvcRoutes.MapRoute(
                name: "font",
                defaults: new { controller = "Home", action = "Font" },
                template: "{culture=en-US}/font/{codename}");

            mvcRoutes.MapRoute(
                name: "page",
                defaults: new { controller = "Home", action = "Page" },
                template: "{culture=en-US}/{codename}");

            mvcRoutes.MapRoute(
                name: "default",
                template: "{culture=en-US}/{controller=Home}/{action=Index}/{id?}");
        });
    });
});

如何解决关于站点配置中的路由的链接?

c# asp.net-core kentico kentico-cloud
1个回答
5
投票

这应该能够在视图中解析类似于Url.Action的URL:

Startup.cs

services
    .TryAddSingleton<IActionContextAccessor, ActionContextAccessor>();

services
    .AddSingleton<IContentLinkUrlResolver, RoutesContentLinkUrlResolver>()
    .AddDeliveryClient( ... )
;

RoutesContentLinkUrlResolver.cs

private readonly IUrlHelperFactory urlHelperFactory;
private readonly IActionContextAccessor actionContextAccessor;

public RoutesContentLinkUrlResolver(IUrlHelperFactory urlHelperFactory, IActionContextAccessor actionContextAccessor)
{
    this.urlHelperFactory = urlHelperFactory;
    this.actionContextAccessor = actionContextAccessor;
}

public string ResolveLinkUrl(ContentLink link)
{
    IUrlHelper Url = urlHelperFactory.GetUrlHelper(actionContextAccessor.ActionContext);

    switch (link.ContentTypeCodename)
    {
        case "Page":
            return Url.Action("Page", "Home", new { codename = link.Codename });
    }
}

尽可能晚地检索IUrlHelper的实例,以确保它具有最新的运行时值。 IUrlHelperFactory的默认实现使用缓存来提高性能:UrlHelperFactory line 44

© www.soinside.com 2019 - 2024. All rights reserved.