mirror of
				https://github.com/encode/django-rest-framework.git
				synced 2025-10-24 20:51:19 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			757 lines
		
	
	
		
			34 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			757 lines
		
	
	
		
			34 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!DOCTYPE html>
 | ||
| <html lang="en">
 | ||
| 
 | ||
| <head>
 | ||
|   <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 | ||
|   <meta charset="utf-8">
 | ||
|   <title>Exceptions - Django REST framework</title>
 | ||
|   <link href="../../img/favicon.ico" rel="icon" type="image/x-icon">
 | ||
|   <link rel="canonical" href="https://www.django-rest-framework.org/api-guide/exceptions/" />
 | ||
|   <meta name="viewport" content="width=device-width, initial-scale=1.0">
 | ||
|   <meta name="description" content="Django, API, REST, Exceptions">
 | ||
|   <meta name="author" content="Tom Christie">
 | ||
| 
 | ||
|   <!-- Le styles -->
 | ||
|   <link href="../../css/prettify.css" rel="stylesheet">
 | ||
|   <link href="../../css/bootstrap.css" rel="stylesheet">
 | ||
|   <link href="../../css/bootstrap-responsive.css" rel="stylesheet">
 | ||
|   <link href="../../css/default.css" rel="stylesheet">
 | ||
| 
 | ||
| 
 | ||
|   <script type="text/javascript">
 | ||
|     var _gaq = _gaq || [];
 | ||
|     _gaq.push(['_setAccount', 'UA-18852272-2']);
 | ||
|     _gaq.push(['_trackPageview']);
 | ||
| 
 | ||
|     (function() {
 | ||
|       var ga = document.createElement('script');
 | ||
|       ga.type = 'text/javascript';
 | ||
|       ga.async = true;
 | ||
|       ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
 | ||
|       var s = document.getElementsByTagName('script')[0];
 | ||
|       s.parentNode.insertBefore(ga, s);
 | ||
|     })();
 | ||
|   </script>
 | ||
| 
 | ||
|   <style>
 | ||
|   #sidebarInclude img {
 | ||
|       margin-bottom: 10px;
 | ||
|   }
 | ||
|   #sidebarInclude a.promo {
 | ||
|       color: black;
 | ||
|   }
 | ||
|     @media (max-width: 767px) {
 | ||
|       div.promo {
 | ||
|         display: none;
 | ||
|       }
 | ||
|     }
 | ||
|   </style>
 | ||
| </head>
 | ||
| <body onload="prettyPrint()" class="-page">
 | ||
| 
 | ||
|   <div class="wrapper">
 | ||
|         <div class="navbar navbar-inverse navbar-fixed-top">
 | ||
|       <div class="navbar-inner">
 | ||
|         <div class="container-fluid">
 | ||
|           <a class="repo-link btn btn-primary btn-small" href="https://github.com/encode/django-rest-framework">GitHub</a>
 | ||
|           <a class="repo-link btn btn-inverse btn-small " rel="next" href="../status-codes/">
 | ||
|             Next <i class="icon-arrow-right icon-white"></i>
 | ||
|           </a>
 | ||
|           <a class="repo-link btn btn-inverse btn-small " rel="prev" href="../reverse/">
 | ||
|             <i class="icon-arrow-left icon-white"></i> Previous
 | ||
|           </a>
 | ||
|           <a id="search_modal_show" class="repo-link btn btn-inverse btn-small" href="#mkdocs_search_modal" data-toggle="modal" data-target="#mkdocs_search_modal"><i class="icon-search icon-white"></i> Search</a>
 | ||
|           <a class="btn btn-navbar" data-toggle="collapse" data-target=".nav-collapse">
 | ||
|             <span class="icon-bar"></span>
 | ||
|             <span class="icon-bar"></span>
 | ||
|             <span class="icon-bar"></span>
 | ||
|           </a>
 | ||
|           <a class="brand" href="https://www.django-rest-framework.org/">Django REST framework</a>
 | ||
|           <div class="nav-collapse collapse">
 | ||
|             
 | ||
|             <!-- Main navigation -->
 | ||
|             <ul class="nav navbar-nav">
 | ||
|                
 | ||
|               <li >
 | ||
|                 <a href="../..">Home</a>
 | ||
|               </li>
 | ||
|                 
 | ||
|               <li class="dropdown">
 | ||
|                 <a href="#" class="dropdown-toggle" data-toggle="dropdown">Tutorial <b class="caret"></b></a>
 | ||
|                 <ul class="dropdown-menu">
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../tutorial/quickstart/">Quickstart</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../tutorial/1-serialization/">1 - Serialization</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../tutorial/2-requests-and-responses/">2 - Requests and responses</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../tutorial/3-class-based-views/">3 - Class based views</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../tutorial/4-authentication-and-permissions/">4 - Authentication and permissions</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../tutorial/5-relationships-and-hyperlinked-apis/">5 - Relationships and hyperlinked APIs</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../tutorial/6-viewsets-and-routers/">6 - Viewsets and routers</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                 </ul>
 | ||
|               </li>
 | ||
|                 
 | ||
|               <li class="dropdown active">
 | ||
|                 <a href="#" class="dropdown-toggle" data-toggle="dropdown">API Guide <b class="caret"></b></a>
 | ||
|                 <ul class="dropdown-menu">
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../requests/">Requests</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../responses/">Responses</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../views/">Views</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../generic-views/">Generic views</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../viewsets/">Viewsets</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../routers/">Routers</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../parsers/">Parsers</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../renderers/">Renderers</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../serializers/">Serializers</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../fields/">Serializer fields</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../relations/">Serializer relations</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../validators/">Validators</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../authentication/">Authentication</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../permissions/">Permissions</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../caching/">Caching</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../throttling/">Throttling</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../filtering/">Filtering</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../pagination/">Pagination</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../versioning/">Versioning</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../content-negotiation/">Content negotiation</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../metadata/">Metadata</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../schemas/">Schemas</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../format-suffixes/">Format suffixes</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../reverse/">Returning URLs</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li class="active" >
 | ||
|                     <a href="./">Exceptions</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../status-codes/">Status codes</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../testing/">Testing</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../settings/">Settings</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                 </ul>
 | ||
|               </li>
 | ||
|                 
 | ||
|               <li class="dropdown">
 | ||
|                 <a href="#" class="dropdown-toggle" data-toggle="dropdown">Topics <b class="caret"></b></a>
 | ||
|                 <ul class="dropdown-menu">
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../topics/documenting-your-api/">Documenting your API</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../topics/internationalization/">Internationalization</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../topics/ajax-csrf-cors/">AJAX, CSRF & CORS</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../topics/html-and-forms/">HTML & Forms</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../topics/browser-enhancements/">Browser Enhancements</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../topics/browsable-api/">The Browsable API</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../topics/rest-hypermedia-hateoas/">REST, Hypermedia & HATEOAS</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                 </ul>
 | ||
|               </li>
 | ||
|                 
 | ||
|               <li class="dropdown">
 | ||
|                 <a href="#" class="dropdown-toggle" data-toggle="dropdown">Community <b class="caret"></b></a>
 | ||
|                 <ul class="dropdown-menu">
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/tutorials-and-resources/">Tutorials and Resources</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/third-party-packages/">Third Party Packages</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/contributing/">Contributing to REST framework</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/project-management/">Project management</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/release-notes/">Release Notes</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.16-announcement/">3.16 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.15-announcement/">3.15 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.14-announcement/">3.14 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.13-announcement/">3.13 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.12-announcement/">3.12 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.11-announcement/">3.11 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.10-announcement/">3.10 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.9-announcement/">3.9 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.8-announcement/">3.8 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.7-announcement/">3.7 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.6-announcement/">3.6 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.5-announcement/">3.5 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.4-announcement/">3.4 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.3-announcement/">3.3 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.2-announcement/">3.2 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.1-announcement/">3.1 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/3.0-announcement/">3.0 Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/kickstarter-announcement/">Kickstarter Announcement</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/mozilla-grant/">Mozilla Grant</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/funding/">Funding</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                   <li >
 | ||
|                     <a href="../../community/jobs/">Jobs</a>
 | ||
|                   </li>
 | ||
|                   
 | ||
|                 </ul>
 | ||
|               </li>
 | ||
|                
 | ||
| 
 | ||
|             </ul>
 | ||
|             
 | ||
|           </div>
 | ||
|           <!--/.nav-collapse -->
 | ||
| 
 | ||
|         </div>
 | ||
|       </div>
 | ||
|     </div>
 | ||
| 
 | ||
|     <div class="body-content">
 | ||
|       <div class="container-fluid">
 | ||
|         <!-- Search Modal -->
 | ||
|         <div id="mkdocs_search_modal" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
 | ||
|           <div class="modal-header">
 | ||
|             <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
 | ||
|             <h3 id="myModalLabel">Documentation search</h3>
 | ||
|           </div>
 | ||
| 
 | ||
|           <div class="modal-body">
 | ||
|             <form role="form" autocomplete="off">
 | ||
|               <div class="form-group">
 | ||
|                 <input type="text" name="q" class="form-control" placeholder="Search..." id="mkdocs-search-query">
 | ||
|               </div>
 | ||
|             </form>
 | ||
|             <div id="mkdocs-search-results"></div>
 | ||
|           </div>
 | ||
| 
 | ||
|           <div class="modal-footer">
 | ||
|             <button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>
 | ||
|           </div>
 | ||
|         </div>
 | ||
| 
 | ||
|         <div class="row-fluid">
 | ||
|           <div class="span3">
 | ||
|             <div id="table-of-contents">
 | ||
|               <ul class="nav nav-list side-nav well sidebar-nav-fixed">
 | ||
|                 
 | ||
| 
 | ||
|                 
 | ||
|                   <li class="main">
 | ||
|                     <a href="#exceptions">Exceptions</a>
 | ||
|                   </li>
 | ||
| 
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#exception-handling-in-rest-framework-views">Exception handling in REST framework views</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#custom-exception-handling">Custom exception handling</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                 
 | ||
|                   <li class="main">
 | ||
|                     <a href="#api-reference">API Reference</a>
 | ||
|                   </li>
 | ||
| 
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#apiexception">APIException</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#parseerror">ParseError</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#authenticationfailed">AuthenticationFailed</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#notauthenticated">NotAuthenticated</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#permissiondenied">PermissionDenied</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#notfound">NotFound</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#methodnotallowed">MethodNotAllowed</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#notacceptable">NotAcceptable</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#unsupportedmediatype">UnsupportedMediaType</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#throttled">Throttled</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#validationerror">ValidationError</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                 
 | ||
|                   <li class="main">
 | ||
|                     <a href="#generic-error-views">Generic Error Views</a>
 | ||
|                   </li>
 | ||
| 
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#rest_frameworkexceptionsserver_error">rest_framework.exceptions.server_error</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#rest_frameworkexceptionsbad_request">rest_framework.exceptions.bad_request</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                 
 | ||
|                   <li class="main">
 | ||
|                     <a href="#third-party-packages">Third party packages</a>
 | ||
|                   </li>
 | ||
| 
 | ||
|                   
 | ||
|                     <li>
 | ||
|                       <a href="#drf-standardized-errors">DRF Standardized Errors</a>
 | ||
|                     </li>
 | ||
|                   
 | ||
|                 
 | ||
| 
 | ||
|                   <div class="promo">
 | ||
|                     <hr/>
 | ||
|                     <div id="sidebarInclude">
 | ||
|                   </div>
 | ||
|               </ul>
 | ||
| 
 | ||
|             </div>
 | ||
|           </div>
 | ||
| 
 | ||
|           <div id="main-content" class="span9">
 | ||
|             
 | ||
|               
 | ||
|                 
 | ||
|                   <a class="github" href="https://github.com/encode/django-rest-framework/tree/main/rest_framework/exceptions.py">
 | ||
|                     <span class="label label-info">exceptions.py</span>
 | ||
|                   </a>
 | ||
|                 
 | ||
|               
 | ||
| 
 | ||
|               <h1 id="exceptions"><a class="toclink" href="#exceptions">Exceptions</a></h1>
 | ||
| <blockquote>
 | ||
| <p>Exceptions… allow error handling to be organized cleanly in a central or high-level place within the program structure.</p>
 | ||
| <p>— Doug Hellmann, <a href="https://doughellmann.com/blog/2009/06/19/python-exception-handling-techniques/">Python Exception Handling Techniques</a></p>
 | ||
| </blockquote>
 | ||
| <h2 id="exception-handling-in-rest-framework-views"><a class="toclink" href="#exception-handling-in-rest-framework-views">Exception handling in REST framework views</a></h2>
 | ||
| <p>REST framework's views handle various exceptions, and deal with returning appropriate error responses.</p>
 | ||
| <p>The handled exceptions are:</p>
 | ||
| <ul>
 | ||
| <li>Subclasses of <code>APIException</code> raised inside REST framework.</li>
 | ||
| <li>Django's <code>Http404</code> exception.</li>
 | ||
| <li>Django's <code>PermissionDenied</code> exception.</li>
 | ||
| </ul>
 | ||
| <p>In each case, REST framework will return a response with an appropriate status code and content-type.  The body of the response will include any additional details regarding the nature of the error.</p>
 | ||
| <p>Most error responses will include a key <code>detail</code> in the body of the response.</p>
 | ||
| <p>For example, the following request:</p>
 | ||
| <pre><code>DELETE http://api.example.com/foo/bar HTTP/1.1
 | ||
| Accept: application/json
 | ||
| </code></pre>
 | ||
| <p>Might receive an error response indicating that the <code>DELETE</code> method is not allowed on that resource:</p>
 | ||
| <pre><code>HTTP/1.1 405 Method Not Allowed
 | ||
| Content-Type: application/json
 | ||
| Content-Length: 42
 | ||
| 
 | ||
| {"detail": "Method 'DELETE' not allowed."}
 | ||
| </code></pre>
 | ||
| <p>Validation errors are handled slightly differently, and will include the field names as the keys in the response. If the validation error was not specific to a particular field then it will use the "non_field_errors" key, or whatever string value has been set for the <code>NON_FIELD_ERRORS_KEY</code> setting.</p>
 | ||
| <p>An example validation error might look like this:</p>
 | ||
| <pre><code>HTTP/1.1 400 Bad Request
 | ||
| Content-Type: application/json
 | ||
| Content-Length: 94
 | ||
| 
 | ||
| {"amount": ["A valid integer is required."], "description": ["This field may not be blank."]}
 | ||
| </code></pre>
 | ||
| <h2 id="custom-exception-handling"><a class="toclink" href="#custom-exception-handling">Custom exception handling</a></h2>
 | ||
| <p>You can implement custom exception handling by creating a handler function that converts exceptions raised in your API views into response objects.  This allows you to control the style of error responses used by your API.</p>
 | ||
| <p>The function must take a pair of arguments, the first is the exception to be handled, and the second is a dictionary containing any extra context such as the view currently being handled. The exception handler function should either return a <code>Response</code> object, or return <code>None</code> if the exception cannot be handled.  If the handler returns <code>None</code> then the exception will be re-raised and Django will return a standard HTTP 500 'server error' response.</p>
 | ||
| <p>For example, you might want to ensure that all error responses include the HTTP status code in the body of the response, like so:</p>
 | ||
| <pre><code>HTTP/1.1 405 Method Not Allowed
 | ||
| Content-Type: application/json
 | ||
| Content-Length: 62
 | ||
| 
 | ||
| {"status_code": 405, "detail": "Method 'DELETE' not allowed."}
 | ||
| </code></pre>
 | ||
| <p>In order to alter the style of the response, you could write the following custom exception handler:</p>
 | ||
| <pre><code>from rest_framework.views import exception_handler
 | ||
| 
 | ||
| def custom_exception_handler(exc, context):
 | ||
|     # Call REST framework's default exception handler first,
 | ||
|     # to get the standard error response.
 | ||
|     response = exception_handler(exc, context)
 | ||
| 
 | ||
|     # Now add the HTTP status code to the response.
 | ||
|     if response is not None:
 | ||
|         response.data['status_code'] = response.status_code
 | ||
| 
 | ||
|     return response
 | ||
| </code></pre>
 | ||
| <p>The context argument is not used by the default handler, but can be useful if the exception handler needs further information such as the view currently being handled, which can be accessed as <code>context['view']</code>.</p>
 | ||
| <p>The exception handler must also be configured in your settings, using the <code>EXCEPTION_HANDLER</code> setting key. For example:</p>
 | ||
| <pre><code>REST_FRAMEWORK = {
 | ||
|     'EXCEPTION_HANDLER': 'my_project.my_app.utils.custom_exception_handler'
 | ||
| }
 | ||
| </code></pre>
 | ||
| <p>If not specified, the <code>'EXCEPTION_HANDLER'</code> setting defaults to the standard exception handler provided by REST framework:</p>
 | ||
| <pre><code>REST_FRAMEWORK = {
 | ||
|     'EXCEPTION_HANDLER': 'rest_framework.views.exception_handler'
 | ||
| }
 | ||
| </code></pre>
 | ||
| <p>Note that the exception handler will only be called for responses generated by raised exceptions.  It will not be used for any responses returned directly by the view, such as the <code>HTTP_400_BAD_REQUEST</code> responses that are returned by the generic views when serializer validation fails.</p>
 | ||
| <hr />
 | ||
| <h1 id="api-reference"><a class="toclink" href="#api-reference">API Reference</a></h1>
 | ||
| <h2 id="apiexception"><a class="toclink" href="#apiexception">APIException</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>APIException()</code></p>
 | ||
| <p>The <strong>base class</strong> for all exceptions raised inside an <code>APIView</code> class or <code>@api_view</code>.</p>
 | ||
| <p>To provide a custom exception, subclass <code>APIException</code> and set the <code>.status_code</code>, <code>.default_detail</code>, and <code>.default_code</code> attributes on the class.</p>
 | ||
| <p>For example, if your API relies on a third party service that may sometimes be unreachable, you might want to implement an exception for the "503 Service Unavailable" HTTP response code.  You could do this like so:</p>
 | ||
| <pre><code>from rest_framework.exceptions import APIException
 | ||
| 
 | ||
| class ServiceUnavailable(APIException):
 | ||
|     status_code = 503
 | ||
|     default_detail = 'Service temporarily unavailable, try again later.'
 | ||
|     default_code = 'service_unavailable'
 | ||
| </code></pre>
 | ||
| <h4 id="inspecting-api-exceptions"><a class="toclink" href="#inspecting-api-exceptions">Inspecting API exceptions</a></h4>
 | ||
| <p>There are a number of different properties available for inspecting the status
 | ||
| of an API exception. You can use these to build custom exception handling
 | ||
| for your project.</p>
 | ||
| <p>The available attributes and methods are:</p>
 | ||
| <ul>
 | ||
| <li><code>.detail</code> - Return the textual description of the error.</li>
 | ||
| <li><code>.get_codes()</code> - Return the code identifier of the error.</li>
 | ||
| <li><code>.get_full_details()</code> - Return both the textual description and the code identifier.</li>
 | ||
| </ul>
 | ||
| <p>In most cases the error detail will be a simple item:</p>
 | ||
| <pre><code>>>> print(exc.detail)
 | ||
| You do not have permission to perform this action.
 | ||
| >>> print(exc.get_codes())
 | ||
| permission_denied
 | ||
| >>> print(exc.get_full_details())
 | ||
| {'message':'You do not have permission to perform this action.','code':'permission_denied'}
 | ||
| </code></pre>
 | ||
| <p>In the case of validation errors the error detail will be either a list or
 | ||
| dictionary of items:</p>
 | ||
| <pre><code>>>> print(exc.detail)
 | ||
| {"name":"This field is required.","age":"A valid integer is required."}
 | ||
| >>> print(exc.get_codes())
 | ||
| {"name":"required","age":"invalid"}
 | ||
| >>> print(exc.get_full_details())
 | ||
| {"name":{"message":"This field is required.","code":"required"},"age":{"message":"A valid integer is required.","code":"invalid"}}
 | ||
| </code></pre>
 | ||
| <h2 id="parseerror"><a class="toclink" href="#parseerror">ParseError</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>ParseError(detail=None, code=None)</code></p>
 | ||
| <p>Raised if the request contains malformed data when accessing <code>request.data</code>.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "400 Bad Request".</p>
 | ||
| <h2 id="authenticationfailed"><a class="toclink" href="#authenticationfailed">AuthenticationFailed</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>AuthenticationFailed(detail=None, code=None)</code></p>
 | ||
| <p>Raised when an incoming request includes incorrect authentication.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "401 Unauthenticated", but it may also result in a "403 Forbidden" response, depending on the authentication scheme in use.  See the <a href="../authentication/">authentication documentation</a> for more details.</p>
 | ||
| <h2 id="notauthenticated"><a class="toclink" href="#notauthenticated">NotAuthenticated</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>NotAuthenticated(detail=None, code=None)</code></p>
 | ||
| <p>Raised when an unauthenticated request fails the permission checks.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "401 Unauthenticated", but it may also result in a "403 Forbidden" response, depending on the authentication scheme in use.  See the <a href="../authentication/">authentication documentation</a> for more details.</p>
 | ||
| <h2 id="permissiondenied"><a class="toclink" href="#permissiondenied">PermissionDenied</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>PermissionDenied(detail=None, code=None)</code></p>
 | ||
| <p>Raised when an authenticated request fails the permission checks.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "403 Forbidden".</p>
 | ||
| <h2 id="notfound"><a class="toclink" href="#notfound">NotFound</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>NotFound(detail=None, code=None)</code></p>
 | ||
| <p>Raised when a resource does not exist at the given URL. This exception is equivalent to the standard <code>Http404</code> Django exception.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "404 Not Found".</p>
 | ||
| <h2 id="methodnotallowed"><a class="toclink" href="#methodnotallowed">MethodNotAllowed</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>MethodNotAllowed(method, detail=None, code=None)</code></p>
 | ||
| <p>Raised when an incoming request occurs that does not map to a handler method on the view.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "405 Method Not Allowed".</p>
 | ||
| <h2 id="notacceptable"><a class="toclink" href="#notacceptable">NotAcceptable</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>NotAcceptable(detail=None, code=None)</code></p>
 | ||
| <p>Raised when an incoming request occurs with an <code>Accept</code> header that cannot be satisfied by any of the available renderers.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "406 Not Acceptable".</p>
 | ||
| <h2 id="unsupportedmediatype"><a class="toclink" href="#unsupportedmediatype">UnsupportedMediaType</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>UnsupportedMediaType(media_type, detail=None, code=None)</code></p>
 | ||
| <p>Raised if there are no parsers that can handle the content type of the request data when accessing <code>request.data</code>.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "415 Unsupported Media Type".</p>
 | ||
| <h2 id="throttled"><a class="toclink" href="#throttled">Throttled</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>Throttled(wait=None, detail=None, code=None)</code></p>
 | ||
| <p>Raised when an incoming request fails the throttling checks.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "429 Too Many Requests".</p>
 | ||
| <h2 id="validationerror"><a class="toclink" href="#validationerror">ValidationError</a></h2>
 | ||
| <p><strong>Signature:</strong> <code>ValidationError(detail=None, code=None)</code></p>
 | ||
| <p>The <code>ValidationError</code> exception is slightly different from the other <code>APIException</code> classes:</p>
 | ||
| <ul>
 | ||
| <li>The <code>detail</code> argument may be a list or dictionary of error details, and may also be a nested data structure. By using a dictionary, you can specify field-level errors while performing object-level validation in the <code>validate()</code> method of a serializer. For example. <code>raise serializers.ValidationError({'name': 'Please enter a valid name.'})</code></li>
 | ||
| <li>By convention you should import the serializers module and use a fully qualified <code>ValidationError</code> style, in order to differentiate it from Django's built-in validation error. For example. <code>raise serializers.ValidationError('This field must be an integer value.')</code></li>
 | ||
| </ul>
 | ||
| <p>The <code>ValidationError</code> class should be used for serializer and field validation, and by validator classes. It is also raised when calling <code>serializer.is_valid</code> with the <code>raise_exception</code> keyword argument:</p>
 | ||
| <pre><code>serializer.is_valid(raise_exception=True)
 | ||
| </code></pre>
 | ||
| <p>The generic views use the <code>raise_exception=True</code> flag, which means that you can override the style of validation error responses globally in your API. To do so, use a custom exception handler, as described above.</p>
 | ||
| <p>By default this exception results in a response with the HTTP status code "400 Bad Request".</p>
 | ||
| <hr />
 | ||
| <h1 id="generic-error-views"><a class="toclink" href="#generic-error-views">Generic Error Views</a></h1>
 | ||
| <p>Django REST Framework provides two error views suitable for providing generic JSON <code>500</code> Server Error and
 | ||
| <code>400</code> Bad Request responses. (Django's default error views provide HTML responses, which may not be appropriate for an
 | ||
| API-only application.)</p>
 | ||
| <p>Use these as per <a href="https://docs.djangoproject.com/en/stable/topics/http/views/#customizing-error-views">Django's Customizing error views documentation</a>.</p>
 | ||
| <h2 id="rest_frameworkexceptionsserver_error"><a class="toclink" href="#rest_frameworkexceptionsserver_error"><code>rest_framework.exceptions.server_error</code></a></h2>
 | ||
| <p>Returns a response with status code <code>500</code> and <code>application/json</code> content type.</p>
 | ||
| <p>Set as <code>handler500</code>:</p>
 | ||
| <pre><code>handler500 = 'rest_framework.exceptions.server_error'
 | ||
| </code></pre>
 | ||
| <h2 id="rest_frameworkexceptionsbad_request"><a class="toclink" href="#rest_frameworkexceptionsbad_request"><code>rest_framework.exceptions.bad_request</code></a></h2>
 | ||
| <p>Returns a response with status code <code>400</code> and <code>application/json</code> content type.</p>
 | ||
| <p>Set as <code>handler400</code>:</p>
 | ||
| <pre><code>handler400 = 'rest_framework.exceptions.bad_request'
 | ||
| </code></pre>
 | ||
| <h1 id="third-party-packages"><a class="toclink" href="#third-party-packages">Third party packages</a></h1>
 | ||
| <p>The following third-party packages are also available.</p>
 | ||
| <h2 id="drf-standardized-errors"><a class="toclink" href="#drf-standardized-errors">DRF Standardized Errors</a></h2>
 | ||
| <p>The <a href="https://github.com/ghazi-git/drf-standardized-errors">drf-standardized-errors</a> package provides an exception handler that generates the same format for all 4xx and 5xx responses. It is a drop-in replacement for the default exception handler and allows customizing the error response format without rewriting the whole exception handler. The standardized error response format is easier to document and easier to handle by API consumers.</p>
 | ||
|             
 | ||
| 
 | ||
|           </div> <!--/span-->
 | ||
|         </div> <!--/row-->
 | ||
|       </div> <!--/.fluid-container-->
 | ||
|     </div> <!--/.body content-->
 | ||
|     <div id="push"></div>
 | ||
|   </div> <!--/.wrapper -->
 | ||
| 
 | ||
|   <footer class="span12">
 | ||
|     <p>Documentation built with <a href="http://www.mkdocs.org/">MkDocs</a>.
 | ||
|     </p>
 | ||
|   </footer>
 | ||
| 
 | ||
|   <!-- Le javascript
 | ||
|   ================================================== -->
 | ||
|   <!-- Placed at the end of the document so the pages load faster -->
 | ||
|   <script async src="https://fund.django-rest-framework.org/sidebar_include.js"></script>
 | ||
|   <script src="../../js/jquery-1.8.1-min.js"></script>
 | ||
|   <script src="../../js/prettify-1.0.js"></script>
 | ||
|   <script src="../../js/bootstrap-2.1.1-min.js"></script>
 | ||
|   <script src="../../js/theme.js"></script>
 | ||
| 
 | ||
|   <script>var base_url = '../..';</script>
 | ||
|   
 | ||
|   <script src="../../search/main.js" defer></script>
 | ||
|   
 | ||
| 
 | ||
|   <script>
 | ||
|     var shiftWindow = function() {
 | ||
|       scrollBy(0, -50)
 | ||
|     };
 | ||
| 
 | ||
|     if (location.hash) shiftWindow();
 | ||
|     window.addEventListener("hashchange", shiftWindow);
 | ||
| 
 | ||
|     $('.dropdown-menu').on('click touchstart', function(event) {
 | ||
|       event.stopPropagation();
 | ||
|     });
 | ||
| 
 | ||
|     // Dynamically force sidenav/dropdown to no higher than browser window
 | ||
|     $('.side-nav, .dropdown-menu').css('max-height', window.innerHeight - 130);
 | ||
| 
 | ||
|     $(function() {
 | ||
|       $(window).resize(function() {
 | ||
|         $('.side-nav, .dropdown-menu').css('max-height', window.innerHeight - 130);
 | ||
|       });
 | ||
|     });
 | ||
|   </script>
 | ||
| </body>
 | ||
| 
 | ||
| </html> | 
