Cookie:Cookie数据是由客户端来保存和携带的,所以称之为客户端技术。
属性:
name:名称不能唯一确定一个Cookie。路径可能不同。
value:不能存中文。
path:默认值是写Cookie的那个程序的访问路径
maxAge:cookie的缓存时间。默认是-1(默认存在浏览器的内存中)。单位是秒。
负数:cookie的数据存在浏览器缓存中
0:删除。路径要保持一致,否则可能删错人。
正数:缓存(持久化到磁盘上)的时间
简单的获取上次你访问浏览器的时间
public class Demo01 extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, 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++){
if("lastaccuess".equals(cookies[i].getName())){
long l=Long.parseLong(cookies[i].getValue());
out.write("上次访问时间是:"+new Date(l).toLocaleString());
}
}
Cookie cookie = new Cookie("lastaccuess",System.currentTimeMillis()+"");
response.addCookie(cookie);
}
}
HttpSession
它也是一个域对象: session servletContext request
同一个会话下,可以使一个应用的多个资源共享数据
cookie客户端技术,只能存字符串。HttpSession服务器端的技术,它可以存对象。
常用方法:
设置:void setAttribute(String name,Object value);
得到:Object getAttribute(String name);
删除:void removeAttribute(String name);
HttpSession.getId():
setMaxInactiveInterval(int interval) 设置session的存活时间
invalidate() 使此会话无效
简单的存储数据,并得到数据
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String name=request.getParameter("name");
HttpSession session = request.getSession();
session.setAttribute("name", name);
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
HttpSession session = request.getSession();
String name=(String) session.getAttribute("name");
System.out.println(name);
}