有个测试需求需要登录才可以实现,原来的设想是手动在浏览器中登录得到cookie,再复制到代码中,后来想想这样太繁琐,能不能代码实现呢?测试代码用的是python语言,网上搜索了一下,发现可以通过代码直接读取浏览器存储的cookie。参考链接为http://www.jianshu.com/p/cd2117b931e3。chrome的cookie存在SQLite文件中,可以根据域名来查询得到所测试站点的cookie,然而chrome33+版本之后,开始对cookies信息进行了加密,在windows上使用的加密函数是CryptUnprotectData,具体的解密方法看这里http://www.ftium4.com/chrome-cookies-encrypted-value-python.html
经分析,获取chrome浏览器的cookie主要需要以下两步:
1. 读取chrome浏览器的存储在SQLite里面的已加密的cookie。使用sqlite3 python标准库,不需要下载安装
2. 解密,即可得到cookie。解密需要用windows的库win32crypt,建议手动下载对应版本pywin32安装 https://sourceforge.net/projects/pywin32/?source=directory,也可以通过cmd中输入命令行:pip install pywin32 .
本人用的python版本为Python 2.7.10。需要下载对应python的pywin32,否则安装的时候安装程序将无法找到python路径。这里踩了一个大坑,代码无错运行之后,出现这个错误“DatabaseError: malformed database schema (is_transient) - near "where": syntax error”
实际上这个问题是因为Python2.7自带的SQLite版本太低,下载一个新版本的‘sqlite3.dll’来替换掉python目录下的旧的‘sqlite3.dll’,就可以解决这个问题,具体的解决方法参考这里:https://www.obsidianforensics.com/blog/upgrading-python-sqlite