Tuesday, December 15, 2009

Chrome Frame's Shifty User-Agent

One of the security measures we have in place at Wesabe is to invalidate a session and log the user out if their User-Agent or IP address subnet changes between requests. However, we recently had a number of complaints that users were getting logged out prematurely. Looking at one user's session in the logs, I noticed that their user agent string had "chromeframe/4.0" appended for some requests, but not others. It turns out that Google's Chrome Frame only modifies the user agent for top-level requests, and not for subsequent requests sent as that page loads:

It was a compromise to keep code complexity down. In order to tag every request from IE...we have to have hooks in place at many more places (not to mention supporting the different things IE6, 7 and 8 do). So, as a compromise we decided to keep it down to only the single hook that allows us to tag top level requests.


This fix on our side was to just strip the chromeframe identifier from the user agent string, although it makes me wonder what other browser extensions cause similar issues and whether invalidating a session when the user agent changes is even a worthwhile security measure.

1 comment:

  1. Hi Brad, we've run into the same issue. Like you we also invalidate sessions when the user agent changes and this behavior from Chrome Frame seems to be causing problems for our users too. We'll probably have to do what you did as well -- strip the chromeframe part off the user agent string before comparing it.

    We've also run into a similar problem with IE8 -- it can change it's behavior mid-session and switch over into "IE7 compatibility mode". When it does that, the UA string switches to MSIE/7.x from MSIE/8.x. As we'll do with the chromeframe issue, our solution was to modify the user agent string before doing the check -- masking out the version number in IE user agent strings to end up with MSIE/#.# no matter whether it is 7 or 8.

    Like you I wonder if this security measure is even worth doing still.

    ---Lawrence

    ReplyDelete