Estou tentando obter acesso ao agente do usuário com Flask, mas não consigo encontrar a documentação sobre ele ou ele não me diz.
Estou tentando obter acesso ao agente do usuário com Flask, mas não consigo encontrar a documentação sobre ele ou ele não me diz.
Respostas:
from flask import request
request.headers.get('User-Agent')
Você também pode usar o request.user_agent
objeto que contém os seguintes atributos, criados com base na string useragent:
== request.headers.get('User-Agent')
)flask.request.user_agent.string
Se você usar
request.headers.get('User-Agent')
você pode obter: Mozilla / 5.0 (Windows NT 6.1; WOW64) AppleWebKit / 537.36 (KHTML, como Gecko) Chrome / 45.0.2454.101 Safari / 537.36
Se você usar
request.user_agent
você pode ficar assim:
UA geralmente não contém idioma. Se quiser que o idioma seja definido no navegador, você pode usar
request.accept_languages
Ele lhe dará uma lista de idiomas. Por exemplo
LanguageAccept([('en-US', 1), ('en', 0.5)])
Para acessar o primeiro valor, você pode usar
request.accept_languages[0][0]
que resultará em string
'en-US'
Informações detalhadas sobre o cabeçalho 'accept_language ": https://www.w3.org/International/questions/qa-lang-priorities
A questão implora por muito mais informações. Esta biblioteca parece ser adequada para coletar muitas informações fora do frasco e tem exemplos de chamadas para obter essas informações fora do contexto do aplicativo.
https://pythonhosted.org/Flask-Track-Usage/
O uso é armazenado neste formato:
[
{
'url': str,
'user_agent': {
'browser': str,
'language': str,
'platform': str,
'version': str,
},
'blueprint': str,
'view_args': dict or None
'status': int,
'remote_addr': str,
'xforwardedfor': str,
'authorization': bool
'ip_info': str or None,
'path': str,
'speed': float,
'date': datetime,
},
{
....
}
]
Aqui está um dos locais da biblioteca onde os dados são coletados:
https://github.com/ashcrow/flask-track-usage/blob/master/src/flask_track_usage/ init .py em torno da linha 158
data = {
'url': ctx.request.url,
'user_agent': ctx.request.user_agent,
'server_name': ctx.app.name,
'blueprint': ctx.request.blueprint,
'view_args': ctx.request.view_args,
'status': response.status_code,
'remote_addr': ctx.request.remote_addr,
'xforwardedfor': ctx.request.headers.get(
'X-Forwarded-For', None),
'authorization': bool(ctx.request.authorization),
'ip_info': None,
'path': ctx.request.path,
'speed': float(speed),
'date': int(time.mktime(current_time.timetuple())),
'content_length': response.content_length,
'request': "{} {} {}".format(
ctx.request.method,
ctx.request.url,
ctx.request.environ.get('SERVER_PROTOCOL')
),
'url_args': dict(
[(k, ctx.request.args[k]) for k in ctx.request.args]
),
'username': None,
'track_var': g.track_var
}