I want to keep some statistics about users and locations in a database. For instance, I would like to store "Mozilla","Firefox","Safari","Chrome","IE", etc... as well as the versions, and possibly the operating system.
What I am trying to locate from Python is this string;
Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.14) Gecko/2009090216 Ubuntu/9.04 (jaunty) Firefox/3.0.14
Is there an efficient way to use Python or mod_python to detect the http user agent/browser?
HTTP_USER_AGENT
contains this information, and will be passed in the environment variables your application uses. In mod_python, this is expressed as:
def my_request_handler(req):
req.add_common_vars()
agent = req.subprocess_env.get("HTTP_USER_AGENT")
# `agent` now contains the full user agent of the browser, or None
It's a basic CGI thing, but this is how mod_python gives it to you.
The method suggested by Jed Smith works, but I was sure there was a simpler way.
The req.headers_in
variable contains all the header info, and you can easily access the user agent using mod_python by calling:
req.headers_in[ 'User-Agent' ]
It is not necessary to call req.add_common_vars()
when using this method.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With