正如在其他答案中所说,此信息位于 Accept 请求标头中。在请求中以HttpRequest.META['HTTP_ACCEPT'] 提供。
但是,请求的内容类型并不只有一种,而且此标头通常是接受/首选内容类型的列表。正确利用此列表可能有点烦人。这是一个完成这项工作的函数:
import re
def get_accepted_content_types(request):
def qualify(x):
parts = x.split(';', 1)
if len(parts) == 2:
match = re.match(r'(^|;)q=(0(\.\d{,3})?|1(\.0{,3})?)(;|$)',
parts[1])
if match:
return parts[0], float(match.group(2))
return parts[0], 1
raw_content_types = request.META.get('HTTP_ACCEPT', '*/*').split(',')
qualified_content_types = map(qualify, raw_content_types)
return (x[0] for x in sorted(qualified_content_types,
key=lambda x: x[1], reverse=True))
例如,如果request.META['HTTP_ACCEPT'] 等于"text/html;q=0.9,application/xhtml+xml,application/xml;q=0.8,*/*;q=0.7"。这将返回:['application/xhtml+xml', 'text/html', 'application/xml', '*/*'] (实际上不是,因为它返回一个生成器)。
然后您可以遍历结果列表以选择您知道如何正确响应的第一个内容类型。
请注意,此函数应该适用于大多数情况,但不能处理诸如 q=0 之类的情况,这意味着“不可接受”。
来源:HTTP Accept header specification 和 Quality Values specification