If you plan on using a Sitefinity CMS page as a custom error page, you must take care of setting the proper response status code. By default, Sitefinity CMS will return status code 200 for any page that it resolves successfully. For example, if you are handling error status code 404 (resource does not exist) when serving your custom error page you should return status 404, to ensure compliance with SEO best practices.
To configure your Sitefinity CMS MVC custom error pages to return the desired status code, follow the instructions described in this article.
When you use a Sitefinity CMS MVC page, the MVC widgets on the page are rendered in a temporary HttpContext. Not all properties from that temporary context propagate to the current HttpContext (System.Web.HttpContext.Current). The Response.Status and Response.StatusCode set from the controllers action will not be set to the page context by default. You can copy the Response.Status and Response.StatusCode from your controllers action to the page current HttpContext via replacing the FeatherActionInvoker or via implementing a custom ActionFilterAttribute.
HttpContext
System.Web.HttpContext.Current
Response.Status
Response.StatusCode
To copy the Response.Status and Response.StatusCode from your controllers action to the page current HttpContext, you must replace the default FeatherActionInvoker and override the RestoreHttpContext method where you can plug the logic for setting the necessary properties. Follow the instructions below to achieve the desired functionality:
FeatherActionInvoker
FeatherActionInvoker.
RestoreHttpContext
Response.StatusDescription
Global.asax
As a result, you can use MVC controllers where you set a response status code, and this status code will propagate to the current HttpContext. Refer to the sample below for an example of MVC controller that returns 404 response status:
As an alternative to replacing the FeatherActionInvoker, you can create a custom ActionFilterAttribute where you copy the Response.Status and Response.StatusCode from your controllers action to the page current HttpContext. Follow the instructions below:
ActionFilterAttribute
OnActionExecuted
IPagePreRenderCompleteEvent.
As a result, you use your custom ActionFilterAttribute to decorate MVC controllers where you set a response status code, and this status code will propagate to the current HttpContext. Refer to the sample below for an example of MVC controller that returns 404 response status:
Back To Top
To submit feedback, please update your cookie settings and allow the usage of Functional cookies.
Your feedback about this content is important