【知了堂学习笔记】_Java中cookie的学习

5 篇文章 0 订阅
3 篇文章 0 订阅

请关注“知了堂学习社区”,地址:http://www.zhiliaotang.com/portal.php
cookie概念
1. cookie是客户端技术,程序把每个用户的数据以cookie的形式写给用户各自的浏览器,当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去。这样,web资源处理的就是用户各自的数据了。
2. cookie是客户端和服务器之间交换的一小段数据,用户不用介入,cookie是自动完成的。
3. cookie在服务器端创建,保存在客户端,客户端会自动携带cookie信息去访问服务器。
4. cookie是以键值对的形式存在。
5. 一个web应用可以有多个cookie,一个cookie只有一个键值对。
6. cookie是可以被多个浏览器共享的。
7. cookie的应用:
(1) 自动登录
(2) 上次登录时间
(3) 上次浏览过的商品
8. cookie是服务器发送给客户端的。
cookie的API
1. javax.servlet.http.Cookie类用于创建一个Cookie,response接口中定义了一个addCookie方法,它用于在其响应头中增加一个相应的Set-Cookie头字段。同样,request接口中也定义了一个getCookies方法,它用于获取客户端提交的Cookie。Cookie类的方法:
(1) public Cookie(String name,String Value)
(2) setValue与getValue方法
(3) setMaxAge与getMaxAge方法(秒)
(4) setPath与getPath方法
(5) setDomain与getDomain方法
(6) getName方法
2. t1.com:设置t1这个网站发送的cookie的域为t.com。
3. t2.com:设置要读取的cookie的域为t.com。
4. SetCookie的代码:
doGet方法的代码:
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//1.创建一个cookie对象:信息是以键值对的形式存在的,一个cookie就是一个键值对
Cookie cookie = new Cookie(“name”,”shunyu”);
//2.设置cookie在客户端的存活时间
cookie.setMaxAge(30*60);
//3.将cookie发送到客户端
response.addCookie(cookie);
}
5. GetCookie的代码:
doGet方法的代码:
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//1.从请求对象中得到cookie
Cookie[] cookies = request.getCookies();
for(Cookie cookie:cookies){
System.out.print(cookie.getName()+”:”);
System.out.println(cookie.getValue());
System.out.println(“———————-“);
}
}
6. CookieTest的代码:
doGet方法的代码:
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
response.setContentType(“text/html;charset=UTF-8”);
request.setCharacterEncoding(“UTF-8”);

    //1.得到当前访问时间
    Date date = new Date();
    //2.将当前时间作为最后访问时间发送给客户端保存
    Cookie cookie = new Cookie("lastAccessTime",date.toString());
    cookie.setMaxAge(30*60);
    response.addCookie(cookie);

    PrintWriter out = response.getWriter();

    //将上次的访问时间显示出来

Cookie[] cookies = request.getCookies();//得到的cookie是上一次发送的cookie
boolean flag = false;//是否得到上次访问时间
for(Cookie cookieLast:cookies){
if(“lastAccessTime”.equals(cookieLast.getName())){
flag = true;
out.print(cookieLast.getValue());
}
}
if(!flag){
out.print(“第一次访问”);
}
}
session和cookie的关系
1. 获取名称为JSESSIONID的cookie值。
2. 没有这样的cookie,创建一个新的HttpSession对象,分配一个唯一的SessionID,并且向客户端写了一个名字为JSESSIONID = sessionID的cookie。
3. 有这样的Cookie,获取cookie的值(即HttpSession对象的值),从服务器的内存中根据ID找那个HttpSession对象。
(1) 找到了:取出继续为你服务
(2) 找不到:从2开始。
4. 服务器会将sessionID作为cookie自动发送给客户端。
5. 客户端会自动携带sessionID去向服务器要同一个session共享区域。
6. session的本质是由cookie实现的。
7. session的实现是基于cookie。
8. GetCookie的代码:
doGet方法的代码:
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
request.getSession();

    //1.从请求对象中得到cookie
    Cookie[] cookies = request.getCookies();
    for(Cookie cookie:cookies){
        System.out.print(cookie.getName()+":");
        System.out.println(cookie.getValue());
        System.out.println("----------------------");
    }

}

自动登录的实现
1. LoginPageServlet的代码:
doGet方法的代码:
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
response.setContentType(“text/html;charset=UTF-8”);
PrintWriter out = response.getWriter();
//验证一下是否有登录成功的凭证
Cookie[] cookies = request.getCookies();
for(Cookie cookie:cookies){
if(“checked”.equals(cookie.getName())){
if(“success”.equals(cookie.getValue())){
System.out.println(“有凭证,无需登录”);
response.sendRedirect(“wel.jsp”);
}
}
}

    out.write("<form action='ValidateLoginServlet' method='post'>");
    out.write("用户名:<input type='text' name='name' /><br>");
    out.write("密码:<input type='text' name='pwd' /><br>");
    out.write("<input type='submit' value='登录' /><br>");
    out.write("</form>");
}

2. wel.jsp的代码:
body主体代码:

登录成功

3. ValidateLoginServlet的代码:
doGet和doPost方法的代码:
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doPost(request, response);
}

/**

* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//根据用户名密码验证是否登录成功
request.setCharacterEncoding(“utf-8”);
String name = request.getParameter(“name”);
String pwd = request.getParameter(“pwd”);
if(“admin”.equals(name)&&”123”.equals(pwd)){
System.out.println(“登录成功”);
//发送一个cookie到客户端,登录成功的凭证
Cookie cookie = new Cookie(“checked”,”success”);
cookie.setMaxAge(30*60);
response.addCookie(cookie);
response.sendRedirect(“wel.jsp”);
}
else{
System.out.println(“登录失败”);
response.sendRedirect(“LoginPageServlet”);
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值