versionFrom | meta.Title | meta.Description |
---|---|---|
9.0.0 |
Umbraco Request Context |
The UmbracoContext is a helpful service provided on each request to the website |
The UmbracoContext is the simplified way to work with the current request on your website.
You can use UmbracoContext to access the content and media cache. Other useful properties are the original and cleaned URLs of the current request. You can also check if the current request is running in "preview" mode.
If you are using Views or Partial View Macros you can reference the UmbracoContext with the syntax: @UmbracoContext
If you need an UmbracoContext
in your own controllers, you need to inject an IUmbracoContextAccessor
.
The following is an example of how to get access to the UmbracoContext
in a controller:
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using Microsoft.AspNetCore.Mvc;
using Umbraco.Cms.Core.Web;
using Umbraco.Cms.Web.Common.Controllers;
using Umbraco.Cms.Web.Common.PublishedModels;
using Umbraco.Extensions;
namespace Umbraco.Docs.Samples.Web.Controllers.Api;
public class PeopleController : UmbracoApiController
{
private readonly IUmbracoContextAccessor _umbracoContextAccessor;
public PeopleController(IUmbracoContextAccessor umbracoContextAccessor)
{
_umbracoContextAccessor = umbracoContextAccessor;
}
[HttpGet]
public ActionResult<IEnumerable<string>> GetAll()
{
if (_umbracoContextAccessor.TryGetUmbracoContext(out IUmbracoContext? context) == false)
{
return this.Problem("unable to get content");
}
if (context.Content == null)
{
return this.Problem("Content Cache is null");
}
var personContentType = context.Content.GetContentType(Person.ModelTypeAlias);
Debug.Assert(context.Content.HasContent());
var personNodes = (context.Content.GetAtRoot()
.First()
.FirstChild<People>()
.Children<Person>() ?? Array.Empty<Person>())
.Select(p => p.Name);
return personContentType == null
? this.Problem("Person Content Type is null")
: Ok(personNodes);
}
}
UmbracoContext is registered with a scoped lifetime. See the Microsoft documentation for more information. A service scope is created for each request, which means you can resolve an instance directly in a controller.