session.put(key, value)
object object = session.get(key)
用户信息一般放在session里面
1、Cookie的来历与作用Cookie是WEB服务器通过浏览器保存在WWW用户端硬盘上的一个文本文件,这个文本文件中包含了文本信息。
文本信息的内容以“名/值”对(key/value)的形式进行存储。
可以让WEB开发者通过程序读写这个文本文件。
XP中保存Cookie的目录是“C://Documents and Settings\用户名\Cookies”
Cookie的作用
解决浏览器用户与Web服务器之间无状态通信。
2Cookie编程
//创建对象
Date date = new Date()
Cookie c = new Cookie("lastVisited",date.toString())
//设定有效时间 以s为单位
c.setMaxAge(60)
//设置Cookie路径和域名
c.setPath("/")
c.setDomain(".zl.org") //域名要以“.”开头
//发送Cookie文件
response.addCookie(c)
//读取Cookie
Cookie cookies[] = request.getCookies()
Cookie c1 = null
if(cookies != null){
for(int i=0i
c1 = cookies[i]
out.println("cookie name : " + c1.getName() + " ")
out.println("cookie value :" + c1.getValue() + "
")
}
}
//修改Cookie
Cookie cookies[] = request.getCookies()
Cookie c = null
for(int i=0i
c = cookies[i]
if(c.getName().equals("lastVisited")){
c.setValue("2010-04-3-28")
c.setMaxAge(60*60*12)
response.addCookie(c) //修改后,要更新到浏览器中
}
}
//删除Cookie,(将Cookie的有效时间设为0)
Cookie cookies[] = request.getCookies()
Cookie c = null
for(int i=0i
c = cookies[i]
if(c.getName().equals("lastVisited")){
c.setMaxAge(0)
response.addCookie(c)
}
}
4、使用Cookie的注意事项
·Cookie的大小和数量是有限制的。
·Cookie在个人硬盘上所保存的文本信息是以明文格式进行保存的,没有任何的加密措施。
·浏览器用户可以设定不使用Cookie。
protected void readCookies(HttpURLConnection url_con){List<String>cookieList = url_con.getHeaderFields().get("Set-Cookie")
if(cookieList != null){
for(String cookie : cookieList){
int p = cookie.indexOf("=")
String key = cookie.substring(0, p)
String value = cookie.substring(p+1, cookie.indexOf(""))
cookies.put(key, value)
}
}
}