Google analytics illegal cookie breaks Python backend

В моем фиде, который публикуется в feedburner, есть русские символы в названии кампании в настройках отслеживания Feed: ${feedUri} ${feedName}. Проблема в том, что это приводит к неправильному __utmz cookie, установленному Google Analytics, и не может быть обработано моим бэкендом (который является web.py).

  File "/home/dw0rm/lib/ve/lib/python2.7/site-packages/web/session.py", line 96, in _load
    self.session_id = web.cookies().get(cookie_name)
  File "/home/dw0rm/lib/ve/lib/python2.7/site-packages/web/webapi.py", line 359, in cookies
    cookie.load(ctx.env.get('HTTP_COOKIE', ''))
  File "/usr/local/lib/python2.7/Cookie.py", line 627, in load
    self.__ParseString(rawdata)
  File "/usr/local/lib/python2.7/Cookie.py", line 660, in __ParseString
    self.__set(K, rval, cval)
  File "/usr/local/lib/python2.7/Cookie.py", line 580, in __set
    M.set(key, real_value, coded_value)
  File "/usr/local/lib/python2.7/Cookie.py", line 455, in set
    raise CookieError("Illegal key value: %s" % key)
CookieError: Illegal key value: )|utmcmd

Эта ошибка возникала в Firefox, и мне удалось исправить ее с помощью этого кода:

def myinternalerror():
    try:
        web.cookies()
    except CookieError:
        if not "cookie_err" in web.input():
            web.setcookie("__utmz", None, domain=web.ctx.host)
            raise web.seeother(web.changequery(cookie_err=1))
    return web.internalerror(render.site.e500())
app.internalerror = myinternalerror

Но сегодня я получил это перенаправление "cookie_err=1" даже в Chrome. Я попробовал это на некоторых других сайтах, основанных на web.py и Analytics, и все они выдают ошибку внутреннего сервера. И эта ошибка сохраняется до тех пор, пока нелегальный cookie не будет удален, что трудно сделать обычному посетителю.

Я хочу знать, какие еще варианты мне следует рассмотреть. Может быть, модуль Python Cookie некорректен, или это ошибка браузера, который пропускает некорректные cookie. Этот материал может быть использован в злонамеренных целях, потому что есть много сайтов на Python, которые используют Google Analytics и модуль Cookie.

Это запрос отслеживания: utm_source=feedburner&utm_medium=twitter&utm_campaign=Feed%3A+cafenovru+%28%D0%9E%D0%BF%D0%B8%D1%81%D1%8C+%D1%82%D1%80%D0%B0%D0%BF%D0%B5%D0%B7%D0%BD%D1%8B%D1%85+%D0%92%D0%B5%D0%BB%D0%B8%D0%BA%D0%BE%D0%B3%D0%BE+%D0%9D%D0%BE%D0%B2%D0%B3%D0%BE%D1%80%D0%BE%D0%B4%D0%B0%29

Incorrect __utmz cookie value is 37098290. 1322168259.5.3.utmcsr=feedburner|utmccn=Feed:%20cafenovru%20(Опись%20трапезных%20Великого%20Новгорода)|utmcmd=twitter

Нелегальный cookie устанавливается javascript Analytics при первом обращении к странице, при последующих запросах возникает ошибка на стороне сервера.

13
задан Andrey Kuzmin 24 November 2011 в 21:06
поделиться