diff --git a/django/template/defaultfilters.py b/django/template/defaultfilters.py
index 9eabb6d..dfdf817 100644
      
        
          
        
        
          
            | a | b | from pprint import pformat | 
        
        
          
            | 9 | 9 |  | 
          
            | 10 | 10 | from django.template.base import Variable, Library | 
          
            | 11 | 11 | from django.conf import settings | 
        
        
          
            | 12 |  | from django.utils import formats  | 
          
            |  | 12 | from django.utils import formats, simplejson | 
        
        
          
            | 13 | 13 | from django.utils.dateformat import format, time_format | 
          
            | 14 | 14 | from django.utils.encoding import force_unicode, iri_to_uri | 
          
            | 15 | 15 | from django.utils.html import (conditional_escape, escapejs, fix_ampersands, | 
        
        
          
            | … | … | def filesizeformat(bytes): | 
        
        
          
            | 832 | 832 | return ugettext("%s TB") % filesize_number_format(bytes / (1024 * 1024 * 1024 * 1024)) | 
          
            | 833 | 833 | return ugettext("%s PB") % filesize_number_format(bytes / (1024 * 1024 * 1024 * 1024 * 1024)) | 
          
            | 834 | 834 |  | 
        
        
          
            |  | 835 | @register.filter(is_safe=True) | 
          
            |  | 836 | def json(value): | 
          
            |  | 837 | """ | 
          
            |  | 838 | Returns the json representation of value. | 
          
            |  | 839 |  | 
          
            |  | 840 | This filter is most often used within <script> tags. Per the HTML | 
          
            |  | 841 | spec (though not XHTML) all text within <script> tags is CDATA and | 
          
            |  | 842 | therefore does not need escaping. Thus, the output is marked safe, | 
          
            |  | 843 | even though no escaping is done. | 
          
            |  | 844 |  | 
          
            |  | 845 | When using this filter outside <script> tags, you must explicitly | 
          
            |  | 846 | force_escape the output: {{ data|json|force_escape }}. | 
          
            |  | 847 | """ | 
          
            |  | 848 | return mark_safe(simplejson.dumps(value)) | 
          
            |  | 849 |  | 
        
        
          
            | 835 | 850 | @register.filter(is_safe=False) | 
          
            | 836 | 851 | def pluralize(value, arg=u's'): | 
          
            | 837 | 852 | """ | 
        
      
    
    
      
      diff --git a/docs/ref/templates/builtins.txt b/docs/ref/templates/builtins.txt
index 1499e2a..da71370 100644
      
        
          
        
        
          
            | a | b | For example:: | 
        
        
          
            | 1665 | 1665 | If ``value`` is the list ``['a', 'b', 'c']``, the output will be the string | 
          
            | 1666 | 1666 | ``"a // b // c"``. | 
          
            | 1667 | 1667 |  | 
        
        
          
            |  | 1668 | .. templatefilter:: json | 
          
            |  | 1669 |  | 
          
            |  | 1670 | json | 
          
            |  | 1671 | ^^^^ | 
          
            |  | 1672 |  | 
          
            |  | 1673 | .. versionadded:: 1.4 | 
          
            |  | 1674 |  | 
          
            |  | 1675 | Coverts a python datastructure of possibly nested dictionaries and lists into | 
          
            |  | 1676 | a json string. | 
          
            |  | 1677 |  | 
          
            |  | 1678 | For example:: | 
          
            |  | 1679 |  | 
          
            |  | 1680 | <script> | 
          
            |  | 1681 | var json_data = {{ value|json }}; | 
          
            |  | 1682 | </script> | 
          
            |  | 1683 |  | 
          
            |  | 1684 | If ``value`` is the python dictionary with nested list | 
          
            |  | 1685 | ``{'hello': ['world', 'wide']}``, the output will be the string | 
          
            |  | 1686 | ``'{"hello": ["world", "wide"]}'``. | 
          
            |  | 1687 |  | 
          
            |  | 1688 | This filter is most often used within ``<script>`` tags. Per the | 
          
            |  | 1689 | HTML spec (though not XHTML) all text within ``<script>`` tags is | 
          
            |  | 1690 | CDATA and therefore does not need escaping. Thus, the output of this filter | 
          
            |  | 1691 | is marked safe, even though no escaping is done. | 
          
            |  | 1692 |  | 
          
            |  | 1693 | When using this filter outside ``<script>`` tags, you must explicitly | 
          
            |  | 1694 | force_escape the output. For example:: | 
          
            |  | 1695 |  | 
          
            |  | 1696 | {{ value|json|force_escape }} | 
          
            |  | 1697 |  | 
        
        
          
            | 1668 | 1698 | .. templatefilter:: last | 
          
            | 1669 | 1699 |  | 
          
            | 1670 | 1700 | last | 
        
      
    
    
      
      diff --git a/tests/regressiontests/templates/filters.py b/tests/regressiontests/templates/filters.py
index 54c1267..52382a3 100644
      
        
          
        
        
          
            | a | b | def get_filter_tests(): | 
        
        
          
            | 106 | 106 | 'filter-lower01': ("{% autoescape off %}{{ a|lower }} {{ b|lower }}{% endautoescape %}", {"a": "Apple & banana", "b": mark_safe("Apple & banana")}, u"apple & banana apple & banana"), | 
          
            | 107 | 107 | 'filter-lower02': ("{{ a|lower }} {{ b|lower }}", {"a": "Apple & banana", "b": mark_safe("Apple & banana")}, u"apple & banana apple & banana"), | 
          
            | 108 | 108 |  | 
        
        
          
            |  | 109 | # json filter #17419 | 
          
            |  | 110 | 'filter-json01': ("{{ data|json }}", {"data": {"hello": ["world", "universe"]}}, u'{"hello": ["world", "universe"]}'), | 
          
            |  | 111 | 'filter-json02': ("{{ data|json }}", {"data": {"foo": "<bar>"}}, u'{"foo": "<bar>"}'), | 
          
            |  | 112 | 'filter-json03': ("{{ data|json }}", {"data": {"foo": 'ba"r'}}, u'{"foo": "ba\\"r"}'), | 
          
            |  | 113 |  | 
        
        
          
            | 109 | 114 | # The make_list filter can destroy existing escaping, so the results are | 
          
            | 110 | 115 | # escaped. | 
          
            | 111 | 116 | 'filter-make_list01': ("{% autoescape off %}{{ a|make_list }}{% endautoescape %}", {"a": mark_safe("&")}, u"[u'&']"), |