Having a POST'able API and Django's CSRF Middleware

T. Stone picture T. Stone · Mar 8, 2010 · Viewed 19.8k times · Source

I have a Django webapp that has both a front-end, web-accessible component and an API that is accessed by a desktop client. However, now with the new CSRF middleware component, API requests from the desktop client that are POST'ed get a 403.

I understand why this is happening, but what is the proper way to fix this without compromising security? Is there someway I can signal in the HTTP header that it's an API request and that Django shouldn't be checking for CSRF or is that a bad strategy?

Edit--

The method I'm using at the moment is that the desktop client sets a header, X-Requested-With: XMLHttpRequest. This is kinda hacky, but I'm not sure how this would be handled better.

Answer

Brian Luft picture Brian Luft · Mar 9, 2010

How about just splitting off a view(s) for your desktop client and decorating them with csrf_exempt?