Подтвердить что ты не робот

Как я могу получить все заголовки запросов в Django?

Мне нужно получить все заголовки запросов Django. Из того, что я читал, Django просто сбрасывает все в переменную request.META наряду с большим количеством других данных. Каким будет лучший способ получить все заголовки, которые клиент отправил в мое приложение Django?

Я собираюсь использовать их для создания запроса httplib.

4b9b3361

Ответ 1

В соответствии с documentation request.META является "стандартным словарем Python, содержащим все доступные HTTP-заголовки". Если вы хотите получить все заголовки, вы можете просто перебирать словарь.

Какая часть вашего кода для этого зависит от вашего точного требования. Любое место, имеющее доступ к request, должно делать.

Обновление

Мне нужно получить к нему доступ в классе Middleware, но когда я перебираю его, я получаю много значений, кроме заголовков HTTP.

Из документации:

За исключением CONTENT_LENGTH и CONTENT_TYPE, как указано выше, любые заголовки HTTP в запросе преобразуются в клавиши META путем преобразования всех символов в верхний регистр, заменяя любые дефисы символами подчеркивания и добавление префикса HTTP_ к имени.

(добавлен акцент)

Чтобы получить только заголовки HTTP, просто отфильтруйте по ключам с префиксом HTTP_.

Обновление 2

Не могли бы вы показать мне, как я мог бы создать словарь заголовков, отфильтровывая все ключи из переменной request.META, которые начинаются с HTTP_ и выделяют ведущую часть HTTP_.

Конечно. Вот один из способов сделать это.

import re
regex = re.compile('^HTTP_')
dict((regex.sub('', header), value) for (header, value) 
       in request.META.items() if header.startswith('HTTP_'))

Ответ 2

Это еще один способ сделать это, очень похожий на Manoj Govindan ответ выше:

import re
regex_http_          = re.compile(r'^HTTP_.+$')
regex_content_type   = re.compile(r'^CONTENT_TYPE$')
regex_content_length = re.compile(r'^CONTENT_LENGTH$')

request_headers = {}
for header in request.META:
    if regex_http_.match(header) or regex_content_type.match(header) or regex_content_length.match(header):
        request_headers[header] = request.META[header]

Это также захватит заголовки запросов CONTENT_TYPE и CONTENT_LENGTH, а также теги HTTP_. request_headers['some_key] == request.META['some_key'].

Измените соответственно, если вам нужно включить/опустить определенные заголовки. Django перечисляет кучу, но не все, из них здесь: https://docs.djangoproject.com/en/dev/ref/request-response/#django.http.HttpRequest.META

алгоритм Django для заголовков запросов:

  • Заменить дефис - с помощью подчеркивания _
  • Преобразовать в UPPERCASE.
  • Подготовьте HTTP_ ко всем заголовкам в исходном запросе, за исключением CONTENT_TYPE и CONTENT_LENGTH.

Значения каждого заголовка должны быть немодифицированы.

Ответ 3

Начиная с Django 2.2, вы можете использовать request.headers для доступа к заголовкам HTTP. Из документации по HttpRequest.headers:

Нечувствительный к регистру объект типа dict, обеспечивающий доступ ко всем заголовкам с префиксом HTTP (плюс Content-Length и Content-Type) из запроса.

Имя каждого заголовка стилизовано с помощью заголовка (например, User-Agent) при его отображении. Вы можете получить доступ к заголовкам без учета регистра:

>>> request.headers
{'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6', ...}

>>> 'User-Agent' in request.headers
True
>>> 'user-agent' in request.headers
True

>>> request.headers['User-Agent']
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6)
>>> request.headers['user-agent']
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6)

>>> request.headers.get('User-Agent')
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6)
>>> request.headers.get('user-agent')
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6)

Чтобы получить все заголовки, вы можете использовать request.headers.keys() или request.headers.items().

Ответ 4

request.META.get( 'HTTP_AUTHORIZATION') /python3.6/site-packages/rest_framework/authentication.py

вы можете получить это из этого файла, хотя...

Ответ 5

Я не думаю, что есть простой способ получить только HTTP-заголовки. Вы должны перебирать запрос request.META, чтобы получить то, что вам нужно.

django-debug-toolbar использует тот же подход для отображения информации заголовка. Посмотрите этот файл, ответственный за получение информации заголовка.

Ответ 6

Если вы хотите получить ключ клиента из заголовка запроса, вы можете попробовать следующее:

from rest_framework.authentication import BaseAuthentication
from rest_framework import exceptions
from apps.authentication.models import CerebroAuth

class CerebroAuthentication(BaseAuthentication):
def authenticate(self, request):
    client_id = request.META.get('HTTP_AUTHORIZATION')
    if not client_id:
        raise exceptions.AuthenticationFailed('Client key not provided')
    client_id = client_id.split()
    if len(client_id) == 1 or len(client_id) > 2:
        msg = ('Invalid secrer key header. No credentials provided.')
        raise exceptions.AuthenticationFailed(msg)
    try:
        client = CerebroAuth.objects.get(client_id=client_id[1])
    except CerebroAuth.DoesNotExist:
        raise exceptions.AuthenticationFailed('No such client')
    return (client, None)

Ответ 7

По-видимому, ваша цель - использовать входящий HTTP-запрос для формирования другого HTTP-запроса. Вроде как ворота. Существует отличный модуль django-revproxy, который выполняет именно это.

Источник - довольно хороший справочник о том, как выполнить то, что вы пытаетесь сделать.

Ответ 8

<b>request.META</b><br>
{% for k_meta, v_meta in request.META.items %}
  <code>{{ k_meta }}</code> : {{ v_meta }} <br>
{% endfor %}

Ответ 9

Просто вы можете использовать HttpRequest.headers начиная с Django 2.2 и далее. Следующий пример взят непосредственно из официальной документации Django в разделе объектов запросов и ответов.

>>> request.headers
{'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6', ...}

>>> 'User-Agent' in request.headers
True
>>> 'user-agent' in request.headers
True

>>> request.headers['User-Agent']
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6)
>>> request.headers['user-agent']
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6)

>>> request.headers.get('User-Agent')
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6)
>>> request.headers.get('user-agent')
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6)