java cookie

java cookie,第1张

java cookie是什么,让我们一起了解一下?

Cookie是由服务器端生成,发送给浏览器,浏览器会将Cookie的key/value保存到某个目录下的文本文件内,下次请求同一网站时就发送该Cookie给服务器(前提是浏览器设置为启用cookie)。Cookie名称和值可以由服务器端开发自己定义,对于JSP而言也可以直接写入JSESSIONID用于标记一个会话(session) 。

cookie的有什么作用?

1、记录用户名和密码:以及该用户需要保存的一些信息,如购物购站,使用cookie,可以让用户自动登录到站点等。

2、定制站点:可以使用cookie来记录用户的偏好。

3、定向广告:可以使用cookie来记录用记经常访问的主题,并向他们显示与这些主题相关的广告。

java cookie常用方法都有哪些?

1、setComment()/getComment():指定或查找与该cookie相关的注释。

2、setDomain()/getDomain():设置或读取该cookie适用的域。

3、setMaxAge()/getMaxAge(): *** 作cookie保留的时间,多长时间后过期。

4、getName():读取cookie的名称。

5、setPath()/getPath():设置或取得cookie适用的路径。

6、cookie.setPath(“/”)指定服务器的所有页面都应该收到该cookie。

7、setSource()/getSource():指定cookie是否只能通过加密连接(SSL)。

8、setValue()/getValue():指定或获取cookie的值。

Java Cookie的基本 *** 作是什么?

以下是示例代码: package com.itheima.cookie   import java.io.IOException import javax.servlet.ServletException import javax.servlet.http.Cookie import javax.servlet.http.HttpServlet import javax.servlet.http.HttpServletRequest import javax.servlet.http.HttpServletResponse   public class SendCookieServlet extends HttpServlet {   protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //1、创建cookie对象 Cookie cookie = new Cookie("name","zhangsan") //1.1 为cookie设置持久化时间 ---- cookie信息在硬盘上保存的时间 cookie.setMaxAge(10*60)//10分钟 ---- 时间设置为0代表删除该cookie //1.2 为cookie设置携带的路径 //cookie.setPath("/WEB16/sendCookie")//访问sendCookie资源时才携带这个cookie cookie.setPath("/WEB16")//访问WEB16下的任何资源时都携带这个cookie //cookie.setPath("/")//访问服务器下的所有的资源都携带这个cookie //2、将cookie中存储的信息发送到客户端---头 response.addCookie(cookie) }   protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response) } }

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。

5、实例:Servlet中的Cookie编程

cookieInput.html页面

SetCookie.java

GetCookie.java

cookieInput.html页面中的参数提交到SetCookie.java中,由SetCookie.java保存在浏览器的Cookie中,在SerCookie.java中链接到GetCookie.java从而读取刚刚保存的Cookie。

SetCookie.java :

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

response.setContentType("text/htmlcharset=utf-8")

PrintWriter out = response.getWriter()

String username = request.getParameter("username")

//保存Cookie

if(username !=""){

Cookie c1 = new Cookie("username",username)

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd")

Cookie c2 = new Cookie("lastVisited",sdf.format(new java.util.Date()))

c1.setMaxAge(60*60*60*12*30)

c2.setMaxAge(60*60*60*12*30)

response.addCookie(c1)

response.addCookie(c2)

out.println("Cookie保存成功!")

out.println("

")

out.println("读取Cookie")

}else{

response.sendRedirect("../cookieInput.html")

}

out.flush()

out.close()

}

GetCookie.java:

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

response.setContentType("text/htmlcharset=utf-8")

PrintWriter out = response.getWriter()

out.println("

")

out.println("")

out.println("

")

out.println("

")

//读取Cookie

Cookie cookies[] = request.getCookies()

Cookie c = null

if(cookies != null){

for(int i=0i

c = cookies[i]

if(c.getName().equals("username")){

out.println("用户名: "+c.getValue())

out.println("

")

}

if(c.getName().equals("lastVisited")){

out.println("上次登录的时间: "+c.getValue())

}

}

}else{

out.println("No cookie !")

}

out.println("

")

out.println("

")

out.flush()

out.close()

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11076622.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-13
下一篇 2023-05-13

发表评论

登录后才能评论

评论列表(0条)

保存