Replacing 404 errors with 410 Sitecore 7.2
Clash Royale CLAN TAG#URR8PPP
up vote
1
down vote
favorite
This may be a little broad so I'd appreciate any pointers.
Is there a way to replace the typical 404 response with 410 for pages that have been deleted? Obviously I'd like to keep 404 responses for genuine 404's.
Thanks.
pipelines error-handling
New contributor
add a comment |Â
up vote
1
down vote
favorite
This may be a little broad so I'd appreciate any pointers.
Is there a way to replace the typical 404 response with 410 for pages that have been deleted? Obviously I'd like to keep 404 responses for genuine 404's.
Thanks.
pipelines error-handling
New contributor
add a comment |Â
up vote
1
down vote
favorite
up vote
1
down vote
favorite
This may be a little broad so I'd appreciate any pointers.
Is there a way to replace the typical 404 response with 410 for pages that have been deleted? Obviously I'd like to keep 404 responses for genuine 404's.
Thanks.
pipelines error-handling
New contributor
This may be a little broad so I'd appreciate any pointers.
Is there a way to replace the typical 404 response with 410 for pages that have been deleted? Obviously I'd like to keep 404 responses for genuine 404's.
Thanks.
pipelines error-handling
pipelines error-handling
New contributor
New contributor
edited 22 mins ago
Dan Sinclair
537314
537314
New contributor
asked 3 hours ago
Sean T
1085
1085
New contributor
New contributor
add a comment |Â
add a comment |Â
1 Answer
1
active
oldest
votes
up vote
5
down vote
accepted
You certainly could, but it requires a couple moving parts:
Track the pages when they are deleted so you can look them up later
To know whether a requested URL used to exist or not, you'll need to track pages as they're deleted so you can check that list later.
You'll need an item:deleted
event handler:
public class PageDeletionLogger
public void ItemDeleted(object sender, EventArgs args)
(And you'll need this handy template checking method [beware: it's recursive]):
public static class TemplateExtensions
public static bool IsDerived([NotNull]this Template template, [NotNull]ID templateId)
And you'll need to patch it into config:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<events>
<event name="item:deleted">
<handler type="Custom.Events.PageDeletionLogger,Custom" method="ItemDeleted" />
</event>
</events>
</sitecore>
</configuration>
Look them up as part of the HttpRequestBegin
pipeline
Then, when incoming requests are processed, you'll need to look them up in your list of deleted pages and see whether they should get a 410 or 404.
public class DeletedPageResolver : HttpRequestProcessor
public override void Process(HttpRequestArgs args)
// If we resolved a context item, get out
if (Sitecore.Context.Item != null)
return;
var listOfDeletedPageUrls = // TODO: Get the list of deleted page URLs
if (listOfDeletedPageUrls.Contains(args.Context.Request.RawUrl))
// TODO: Set your 410 HTTP status code
And, of course, you'll need to patch that into config, too:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<pipelines>
<httpRequestBegin>
<processor type="Custom.Processors.HttpRequestBegin.DeletedPageResolver, Custom" patch:after="processor[@type='Sitecore.Pipelines.HttpRequest.ItemResolver, Sitecore.Kernel']"/>
</httpRequestBegin>
</pipelines>
</sitecore>
</configuration>
Disclaimer
I've not worked with the 410 status code before, so it's possible you'll need to do more to avoid having the page redirect to an error page (e.g. resolve the Sitecore.Context.Item
to a page that has the 410 error content you want to display).
Superb, thanks a lot - this is far more than I had hoped for.
â Sean T
2 hours ago
add a comment |Â
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
5
down vote
accepted
You certainly could, but it requires a couple moving parts:
Track the pages when they are deleted so you can look them up later
To know whether a requested URL used to exist or not, you'll need to track pages as they're deleted so you can check that list later.
You'll need an item:deleted
event handler:
public class PageDeletionLogger
public void ItemDeleted(object sender, EventArgs args)
(And you'll need this handy template checking method [beware: it's recursive]):
public static class TemplateExtensions
public static bool IsDerived([NotNull]this Template template, [NotNull]ID templateId)
And you'll need to patch it into config:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<events>
<event name="item:deleted">
<handler type="Custom.Events.PageDeletionLogger,Custom" method="ItemDeleted" />
</event>
</events>
</sitecore>
</configuration>
Look them up as part of the HttpRequestBegin
pipeline
Then, when incoming requests are processed, you'll need to look them up in your list of deleted pages and see whether they should get a 410 or 404.
public class DeletedPageResolver : HttpRequestProcessor
public override void Process(HttpRequestArgs args)
// If we resolved a context item, get out
if (Sitecore.Context.Item != null)
return;
var listOfDeletedPageUrls = // TODO: Get the list of deleted page URLs
if (listOfDeletedPageUrls.Contains(args.Context.Request.RawUrl))
// TODO: Set your 410 HTTP status code
And, of course, you'll need to patch that into config, too:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<pipelines>
<httpRequestBegin>
<processor type="Custom.Processors.HttpRequestBegin.DeletedPageResolver, Custom" patch:after="processor[@type='Sitecore.Pipelines.HttpRequest.ItemResolver, Sitecore.Kernel']"/>
</httpRequestBegin>
</pipelines>
</sitecore>
</configuration>
Disclaimer
I've not worked with the 410 status code before, so it's possible you'll need to do more to avoid having the page redirect to an error page (e.g. resolve the Sitecore.Context.Item
to a page that has the 410 error content you want to display).
Superb, thanks a lot - this is far more than I had hoped for.
â Sean T
2 hours ago
add a comment |Â
up vote
5
down vote
accepted
You certainly could, but it requires a couple moving parts:
Track the pages when they are deleted so you can look them up later
To know whether a requested URL used to exist or not, you'll need to track pages as they're deleted so you can check that list later.
You'll need an item:deleted
event handler:
public class PageDeletionLogger
public void ItemDeleted(object sender, EventArgs args)
(And you'll need this handy template checking method [beware: it's recursive]):
public static class TemplateExtensions
public static bool IsDerived([NotNull]this Template template, [NotNull]ID templateId)
And you'll need to patch it into config:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<events>
<event name="item:deleted">
<handler type="Custom.Events.PageDeletionLogger,Custom" method="ItemDeleted" />
</event>
</events>
</sitecore>
</configuration>
Look them up as part of the HttpRequestBegin
pipeline
Then, when incoming requests are processed, you'll need to look them up in your list of deleted pages and see whether they should get a 410 or 404.
public class DeletedPageResolver : HttpRequestProcessor
public override void Process(HttpRequestArgs args)
// If we resolved a context item, get out
if (Sitecore.Context.Item != null)
return;
var listOfDeletedPageUrls = // TODO: Get the list of deleted page URLs
if (listOfDeletedPageUrls.Contains(args.Context.Request.RawUrl))
// TODO: Set your 410 HTTP status code
And, of course, you'll need to patch that into config, too:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<pipelines>
<httpRequestBegin>
<processor type="Custom.Processors.HttpRequestBegin.DeletedPageResolver, Custom" patch:after="processor[@type='Sitecore.Pipelines.HttpRequest.ItemResolver, Sitecore.Kernel']"/>
</httpRequestBegin>
</pipelines>
</sitecore>
</configuration>
Disclaimer
I've not worked with the 410 status code before, so it's possible you'll need to do more to avoid having the page redirect to an error page (e.g. resolve the Sitecore.Context.Item
to a page that has the 410 error content you want to display).
Superb, thanks a lot - this is far more than I had hoped for.
â Sean T
2 hours ago
add a comment |Â
up vote
5
down vote
accepted
up vote
5
down vote
accepted
You certainly could, but it requires a couple moving parts:
Track the pages when they are deleted so you can look them up later
To know whether a requested URL used to exist or not, you'll need to track pages as they're deleted so you can check that list later.
You'll need an item:deleted
event handler:
public class PageDeletionLogger
public void ItemDeleted(object sender, EventArgs args)
(And you'll need this handy template checking method [beware: it's recursive]):
public static class TemplateExtensions
public static bool IsDerived([NotNull]this Template template, [NotNull]ID templateId)
And you'll need to patch it into config:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<events>
<event name="item:deleted">
<handler type="Custom.Events.PageDeletionLogger,Custom" method="ItemDeleted" />
</event>
</events>
</sitecore>
</configuration>
Look them up as part of the HttpRequestBegin
pipeline
Then, when incoming requests are processed, you'll need to look them up in your list of deleted pages and see whether they should get a 410 or 404.
public class DeletedPageResolver : HttpRequestProcessor
public override void Process(HttpRequestArgs args)
// If we resolved a context item, get out
if (Sitecore.Context.Item != null)
return;
var listOfDeletedPageUrls = // TODO: Get the list of deleted page URLs
if (listOfDeletedPageUrls.Contains(args.Context.Request.RawUrl))
// TODO: Set your 410 HTTP status code
And, of course, you'll need to patch that into config, too:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<pipelines>
<httpRequestBegin>
<processor type="Custom.Processors.HttpRequestBegin.DeletedPageResolver, Custom" patch:after="processor[@type='Sitecore.Pipelines.HttpRequest.ItemResolver, Sitecore.Kernel']"/>
</httpRequestBegin>
</pipelines>
</sitecore>
</configuration>
Disclaimer
I've not worked with the 410 status code before, so it's possible you'll need to do more to avoid having the page redirect to an error page (e.g. resolve the Sitecore.Context.Item
to a page that has the 410 error content you want to display).
You certainly could, but it requires a couple moving parts:
Track the pages when they are deleted so you can look them up later
To know whether a requested URL used to exist or not, you'll need to track pages as they're deleted so you can check that list later.
You'll need an item:deleted
event handler:
public class PageDeletionLogger
public void ItemDeleted(object sender, EventArgs args)
(And you'll need this handy template checking method [beware: it's recursive]):
public static class TemplateExtensions
public static bool IsDerived([NotNull]this Template template, [NotNull]ID templateId)
And you'll need to patch it into config:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<events>
<event name="item:deleted">
<handler type="Custom.Events.PageDeletionLogger,Custom" method="ItemDeleted" />
</event>
</events>
</sitecore>
</configuration>
Look them up as part of the HttpRequestBegin
pipeline
Then, when incoming requests are processed, you'll need to look them up in your list of deleted pages and see whether they should get a 410 or 404.
public class DeletedPageResolver : HttpRequestProcessor
public override void Process(HttpRequestArgs args)
// If we resolved a context item, get out
if (Sitecore.Context.Item != null)
return;
var listOfDeletedPageUrls = // TODO: Get the list of deleted page URLs
if (listOfDeletedPageUrls.Contains(args.Context.Request.RawUrl))
// TODO: Set your 410 HTTP status code
And, of course, you'll need to patch that into config, too:
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/">
<sitecore>
<pipelines>
<httpRequestBegin>
<processor type="Custom.Processors.HttpRequestBegin.DeletedPageResolver, Custom" patch:after="processor[@type='Sitecore.Pipelines.HttpRequest.ItemResolver, Sitecore.Kernel']"/>
</httpRequestBegin>
</pipelines>
</sitecore>
</configuration>
Disclaimer
I've not worked with the 410 status code before, so it's possible you'll need to do more to avoid having the page redirect to an error page (e.g. resolve the Sitecore.Context.Item
to a page that has the 410 error content you want to display).
answered 2 hours ago
Dan Sinclair
537314
537314
Superb, thanks a lot - this is far more than I had hoped for.
â Sean T
2 hours ago
add a comment |Â
Superb, thanks a lot - this is far more than I had hoped for.
â Sean T
2 hours ago
Superb, thanks a lot - this is far more than I had hoped for.
â Sean T
2 hours ago
Superb, thanks a lot - this is far more than I had hoped for.
â Sean T
2 hours ago
add a comment |Â
Sean T is a new contributor. Be nice, and check out our Code of Conduct.
Sean T is a new contributor. Be nice, and check out our Code of Conduct.
Sean T is a new contributor. Be nice, and check out our Code of Conduct.
Sean T is a new contributor. Be nice, and check out our Code of Conduct.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fsitecore.stackexchange.com%2fquestions%2f14449%2freplacing-404-errors-with-410-sitecore-7-2%23new-answer', 'question_page');
);
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password