深入体验JavaWeb开发内幕——由创建Cookie到通过Cookie获取用户上次访问某站点时间的简单应用



        当客户端发出请求时,服务器在处理客户请求并将处理结果返回给客户的同时还会额外的创建一个Cookie返还给客户端,以便该客户端下次再访问服务器时服务器可以很快的知道是哪个用户在访问该网站,利用Cookie的这个特性,我们就可以实现一些现实生活中会应用到的应用了。如:购物网站、用户的登陆信息保存等。

一、模拟服务器创建Cookie到客户端

        下面,我们来通过程序模拟服务器创建一个Cookie发送给客户端:

     
MakeCookie .java
package net.csdn.cookie;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;

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 MakeCookie extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		makeCookie(response);
		
	}


	private void makeCookie(HttpServletResponse response) throws IOException {
		response.setContentType("text/html;charset=utf-8");
		PrintWriter out = response.getWriter();
		
		Cookie cookie = new Cookie("username","lijizh1013");
		cookie.setMaxAge(24*3600);
		cookie.setPath("/Cookie/MakeCookie");
		response.addCookie(cookie);
		out.println("Cookie已经写入到客户端!");
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

效果如图:

在本地磁盘上的Cookies文件夹下便会产生一个相应的扩展名为.txt的文件,该文件就是服务器端返还给客户端的cookie。

 

二、通过Cookie获取客户端传过来的信息

package net.csdn.cookie;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;

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 MakeCookie extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		getCookie(request, response);
	}

	private void getCookie(HttpServletRequest request,
			HttpServletResponse response) throws IOException {
		response.setContentType("text/html;charset=utf-8");
		PrintWriter out = response.getWriter();
		Cookie [] cookies = request.getCookies();
		for(int i=0;cookies!=null && i<cookies.length;i++){
			String cname = cookies[i].getName();
			String cvalue = cookies[i].getValue();
			out.println("获取Cookie"+cname+"——"+cvalue);
		}
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}
如图:

     

三、通过Cookie获取用户上次浏览该网站的具体时间

package net.csdn.cookie;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;

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 MakeCookie extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

	response.setContentType("text/html;charset=utf-8");
		PrintWriter out = response.getWriter();
		out.println("你上次访问的时间是:");
		Cookie [] cookies = request.getCookies();
		for(int i=0;cookies!=null && i<cookies.length;i++){
			if(cookies[i].getName().equals("LastAccessName")){
				long time  = Long.valueOf(cookies[i].getValue());
				Date date = new Date (time);
				out.println(date.toLocaleString());
			}
	    
			
		}
		Cookie cok = new Cookie("LastAccessName",System.currentTimeMillis()+"");
		cok.setMaxAge(1*3600);
		response.addCookie(cok);
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		doGet(request, response);
	}

}

效果如图:

当第一次访问时;

再次访问:


好了,赶快自己试一试吧!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值