- Author:
- jammycakes
- Posted:
- September 26, 2009
- Language:
- Python
- Version:
- 1.1
- Score:
- 1 (after 5 ratings)
A decorator that can be applied to your views to turn ObjectDoesNotExist exceptions into Http404 exceptions. This means people will see a "Page not found" error rather than an "Internal Server Error" when they are request something that does not exist in the database.
Example:
@raise_404
def show_event(request, id):
event = Event.objects.get(id)
return render_to_response('events/show_event.html', { 'event' : event })
1 2 3 4 5 6 7 8 9 10 11 | def raise_404(method):
def wrap(*args, **kwargs):
from django.core.exceptions import ObjectDoesNotExist
from django.http import Http404
try:
return method(*args, **kwargs)
except ObjectDoesNotExist, ex:
raise Http404(ex.message)
return wrap
|
More like this
- Template tag - list punctuation for a list of items by shapiromatron 1 year ago
- JSONRequestMiddleware adds a .json() method to your HttpRequests by cdcarter 1 year ago
- Serializer factory with Django Rest Framework by julio 1 year, 7 months ago
- Image compression before saving the new model / work with JPG, PNG by Schleidens 1 year, 8 months ago
- Help text hyperlinks by sa2812 1 year, 8 months ago
Comments
Pretty neat idea. This also works as a middleware:
#
The only thing to note with middleware is that if you raise Http404 exceptions at the middleware level, no subsequent processing will take place. This means that you should put the DoesNotExistTo404Middleware as the first item in your MIDDLEWARE_CLASSES setting.
It also means, for example, that if you're using separate middleware to log 404 Not Found errors, it won't pick up on any that are generated this way.
#
Surely get_object_or_404() would be a better way of acheiving this? It's a clever idea, but masking a server error as a 404 is bound to confuse someone who's trying to get their head around the code.
#
Indeed, get_object_or_404 is another alternative. However there are occasions when this is not appropriate.
For example, if you are raising the ObjectNotFoundException further down the call stack (e.g. in your model managers) it may be raised both within a view (when it is appropriate to turn this exception into a 404) or within a manage.py command (when it isn't).
Note also that this only turns ObjectNotFoundException into a 404 -- other types of exceptions will remain unchanged and will result in 500 Internal Server Error, as they should.
The ideal approach would obviously be to code it as middleware, as @mbi suggested, but as I have noted, there are other problems with that approach.
#
is good way for raise 404~
#
Please login first before commenting.