java 模拟登录后,获取服务器上对应的cookie值

Python015

java 模拟登录后,获取服务器上对应的cookie值,第1张

登陆验证成功后存入session,想要获取的话掉通过session获取

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)

}

}

}