I need to create a secure restFUL api using sencha and django. I am fairly new to python. So far i am able to send request from sencha to server using basic authentication as below
new Ext.data.Store({
proxy: {
type: "ajax",
headers: {
"Authorization": "Basic asdjksdfsksf="
}
}
})
In php/apache i can access those header with ease with the code below
$headers = apache_request_headers();
print_r($headers);
How to do this in python?
-
2It doesn't make sense to ask how you do this in Python, as Python is not a web-only language. You should ask how you do it with your framework, ie Django.Daniel Roseman– Daniel Roseman2012年05月16日 07:02:04 +00:00Commented May 16, 2012 at 7:02
-
you are right , i am editing :)sumit– sumit2012年05月16日 07:03:17 +00:00Commented May 16, 2012 at 7:03
5 Answers 5
You can access them within a view using request.META, which is a dictionary.
If you wanted the Authorization header, you could do request.META['HTTP_AUTHORIZATION']
If you're creating a restful API from scratch, you might want to take a look at using tastypie.
6 Comments
As of django 2.2 HttpRequest.headers were added to allow simple access to a request’s headers. So now you can also get authentication header using get() function on request.headers
request.headers.get('Authorization')
This will give you value token value back.
Bearer eyJ0eYourToken...
https://docs.djangoproject.com/en/2.2/ref/request-response/#django.http.HttpRequest.headers
1 Comment
You can use
request.META['HTTP_AUTHORIZATION']
and sometimes
request.META['Authorization']
can help.
Comments
For older versions of django prior to 2.2, you'll need to access the headers in the following way using the META key. Always important to first check if the key authorization header keys exists just in case it wasn't posted otherwise you'll run into non-existent key errors.
if not ('HTTP_AUTHORIZATION' in request.META.keys()):
return HttpResponse('NO AUTH HEADER PROVIDED')
elif (request.META['HTTP_AUTHORIZATION'] == 'Bearer YourAuthorizationKey123':
# Validation passed - Proceed with whatever else you want to do
Comments
HttpRequest.headers
New in Django 2.2.
if 'Authorization' in request.headers: # Authorization header exists
#do something here
pass
else: # Authorization header not exists
#do something here
pass
Read also Django official Doc