首页 > Python基础教程 >
-
web.py cookie使用之cookie设置与获取
上一篇文章说到了web.py初探之第一个页面hello word,下面我们继续深入web.py编程,来说一下web.py的cookie设置。
cookie相信学过web编程的人并不陌生,它在web编程中担任着非常重要的角色。用户登录、验证码、session(基于cookie)、语言选择器、身份识别等等都会有cookie的身影。那么怎么样在web.py中设置cookie呢?
其实在web.py中设置cookie非常简单,web.py早已经为我们想到了这一点,提供了一个非常简单有用的函数:
1
|
setcookie(name, value, expires = "", domain = None , secure = False ) |
参数详解:
-
name (string) - Cookie的名称,由浏览器保存并发送至服务器。
-
value (string) -Cookie的值,与Cookie的名称相对应。
-
expires (int) - Cookie的过期时间,这是个可选参数,它决定cookie有效时间是多久。以秒为单位。它必须是一个整数,而绝不能是字符串。可选参数,不写该参数则默认永久有效。
-
domain (string) - Cookie的有效域-在该域内cookie才是有效的。一般情况下,要在某站点内可用,该参数值该写做站点的域(比如.webpy.org),而不是站主的主机名(比如wiki.webpy.org),可选参数
-
secure (bool)- 如果为True,要求该Cookie只能通过HTTPS传输。可选参数
例如:
1
2
|
#设置website的值为www.pythontab.com,有效期60秒 web.setcookie( "website" , "www.pythontab.com" , 60 ) |
示例
用web.setcookie() 设置cookie,如下:
1
2
3
4
5
|
class CookieSet: def GET( self ): i = web. input (age = '25' ) web.setcookie( 'age' , i.age, 3600 ) return "Age set in your cookie" |
用 GET方式调用上面的类将设置一个名为age,默认值是25的cookie(实际上,默认值25是在web.input中赋予i.age的,从而间接赋予 cookie,而不是在setcookie函式中直接赋予cookie的)。这个cookie将在一小时后(即3600秒)过期。
web.setcookie()的第三个参数-"expires"是一个可选参数,它用来设定cookie过期的时间。如果是负数,cookie将立刻过期。如果是正数,就表示cookie的有效时间是多久,以秒为单位。如果该参数为空,cookie就永不过期。
获得Cookies
概述
获取Cookie的值有很多方法,它们的区别就在于找不到cookie时如何处理。
方法1(如果找不到cookie,就返回None):
通过get方法获得
1
2
3
|
#通过设置的cookie的名字获取cookie,例如website #web.cookies().get("website") web.cookies().get(cookieName) |
方法2(如果找不到cookie,就抛出AttributeError异常):
1
2
3
4
|
#先把cookie对象赋值给一个变量,然后通过cookie的名字获得 #例如:foo.website foo = web.cookies() foo.cookieName |
方法3(如果找不到cookie,可以设置默认值来避免抛出异常):
1
2
3
4
|
#该方法最大的特点就是可以设置cookie的默认值 foo = web.cookies(cookieName = defaultValue) #如果不存在该cookieName,就会返回设置的默认cookie foo.cookieName |