一般的情况使用requests.Session()方法就可以解决cookies问题,但是在途中添加cookie遇到了一些问题。
第一种:
1 | session = requests.Session() |
功能:可以添加cookie,不会清除原cookie
缺点:不能设置path,domain等参数
第二种:
1 | session = requests.Session() |
功能:设置path、domain等参数。
缺点:清楚原来的cookies
第三种:
1 | session = requests.Session() |
功能:可以添加cookie,不会清除原cookie
缺点:不能设置path,domain等参数
第四种:
1 | session = requests.Session() |
功能:既能添加cookies,还能添加path,domain等参数。
cookie的path和domain属性
- domain表示的是cookie所在的域,默认为请求的地址,如网址为www.test.com/test/test.aspx,那么domain默认为www.test.com。而跨域访问,如域A为t1.test.com,域B为t2.test.com,那么在域A生产一个令域A和域B都能访问的cookie就要将该cookie的domain设置为.test.com;如果要在域A生产一个令域A不能访问而域B能访问的cookie就要将该cookie的domain设置为t2.test.com。
- path表示cookie所在的目录,asp.net默认为/,就是根目录。在同一个服务器上有目录如下:/test/,/test/cd/,/test/dd/,现设一个cookie1的path为/test/,cookie2的path为/test/cd/,那么test下的所有页面都可以访问到cookie1,而/test/和/test/dd/的子页面不能访问cookie2。这是因为cookie能让其path路径下的页面访问。
- 浏览器会将domain和path都相同的cookie保存在一个文件里,cookie间用*隔开。
- 含值键值对的cookie:以前一直用的是nam=value单键值对的cookie,一说到含多个子键值对的就蒙了。现在总算弄清楚了。含多个子键值对的cookie格式是name=key1=value1&key2=value2。可以理解为单键值对的值保存一个自定义的多键值字符串,其中的键值对分割符为&,当然可以自定义一个分隔符,但用asp.net获取时是以&为分割符。
本文为作者原创 转载时请注明出处 谢谢
乱码三千 – 点滴积累 ,欢迎来到乱码三千技术博客站