Last active
May 12, 2025 12:33
-
-
Save fabiosussetto/c534d84cbbf7ab60b025 to your computer and use it in GitHub Desktop.
Enable Django toolbar for JSON responses
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
class NonHtmlDebugToolbarMiddleware(object): | |
""" | |
The Django Debug Toolbar usually only works for views that return HTML. | |
This middleware wraps any JSON response in HTML if the request | |
has a 'debug' query parameter (e.g. http://localhost/foo?debug) | |
""" | |
@staticmethod | |
def process_response(request, response): | |
if request.GET.get('debug'): | |
if response['Content-Type'] == 'application/json': | |
content = json.dumps(json.loads(response.content), sort_keys=True, indent=2) | |
response = HttpResponse(u'<html><body><pre>{}</pre></body></html>'.format(content)) | |
return response |
Dears ,
By default Django Debug Toolbar needs html content to display upon , good news is that DRF comes with browsable api build in , by default renderers classes in Django is JSON & Browsable API , i totally sure you modify renders classes attributes as per viewset or generic function and override defaults , so add it again and it will works fine
from rest_framework.renderers import BrowsableAPIRenderer
them add it as
renderer_classes = [ .... ,BrowsableAPIRenderer]
with viewsets or generic views
Here's an updated version that works with Django 4.2.
import json
from django.http import HttpResponse
class NonHtmlDebugToolbarMiddleware(object):
"""
The Django Debug Toolbar usually only works for views that return HTML.
This middleware wraps any JSON response in HTML if the request
has a 'debug' query parameter (e.g. http://localhost/foo?debug)
adapted from:
https://gist.github.com/fabiosussetto/c534d84cbbf7ab60b025
"""
def __init__(self, get_response):
self.get_response = get_response
def __call__(self, request):
response = self.get_response(request)
if request.GET.get('debug', None) is not None:
if response['Content-Type'] == 'application/json':
content = json.dumps(json.loads(response.content), sort_keys=True, indent=2)
response = HttpResponse(u'<html><body><pre>{}</pre></body></html>'.format(content))
return response
@arbuckle Thanks for the updated version.
I added syntax highlighting and "if django debug toolbar is enabled" detection to make it even more useful. The updated version can be found here: https://gist.github.com/ulgens/73fe671d54eff80edb54a30e255c6a5f
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
I believe this doesn't work anymore due to django changing the way middlewares should be structured :)