Servlet与Jsp(1)

  • Servlet 实现原理
    Servlet接口使Servlet容器能将Servlet类载入内存,并在Servlet实例上调用具体的方法.
  • Servlet的生命周期
    Servlet进入Servlet容器后调用其生命周期方法,分别是:
    • init:当Servlet第一次被请求时,Servlet会调用此方法,此方法只会被调用一次,后续请求中不会再次调用.调用此方法会将ServletConfig赋予类级变量.
    • Service:每次请求Servlet时,都会调用次方法
    • destroy:销毁Servlet时调用
  • Servlet的会话管理
    包含URL重写,隐藏域,Cookies,HttpSession四种
  • URL重写
    使用html 的a标签,将信息添加至URL上
    London
  • 隐藏域
    隐藏域的保持状态与URL重写类似,但它不是将值附加到URL上,而是将值放入HTML的隐藏域中,跟随其他显示表示的信息一起通过表单方式提交

URL重写与隐藏域只适用于无须跨越太多页面的信息.

  • Cookies
    Cookies可以帮助我们在多页面之间很好的会话,浏览器通常支持每个网站高达20个Cookies
    Cookies的创建:
    Cookie cookie=new Cookie(name,value);
    Cookie cookie=new Cookie("user","admin");
    将cookie发送至浏览器,使用HttpServletResponse的add方法:
    httpServletResponse.addCookie(cookie);
    • Cookies的信息获取与删除
      Cookies信息获取
      在Servlet中并没有getCookieByName来简化获取信息的工作,只能遍历Cookie
Cookie cookies=request.getCookies();
Cookie cookie=null;
if(cookies!=null){
  for(Cookie cookieCopy:cookies){
    if(cookie.getName().equals("user")){
    cookie=cookieCopy;
break;
}  
}
}

Cookie删除
使用JavaScript也可以创建和删除cookie,详情Google
cookie无法直接删除,只能重新命名一个相同名字的cookie然后将其MaxAge设置为0

Cookie cookie=new Cookie("userName","");
cookie.setMaxAge(0);
response.addCookie(cookie);
  • HttpSession
    • 在所用会话追踪技术中HttpSession是最强大也是最通用的.HttpSession在对象第一次访问网站时创建,用户可以根据HttpServletRequest的getSession()方法获取
      HttpSession session=httpServletRequest.getSession();
    • HttpSession存储于内存之中,因此尽量不要在其存储大量数据,要将数据存储于HttpSession之中,使用其setAttribute()方法,获取数据较Cookies简单,直接使用getAttribute(name)
session.setAttribute(name,value);//存储数据
session.getAttribute(name);//获取数据
  • 当忘记存储于session中的数据名字,可以使用getAttributeNames获取,其返回一个Enumeration对象可供迭代访问保存在session中的值
  • 对于HttpSession由于是存储于内存中,过多会导致系统运行不流畅,所以Java提供了HttpSession的过期属性.
    1.当到达一定时间未访问此session属性后,系统将使会话过期,并清空其保存的对象,设置时长使用getMaxInactiveInterval(int second).如果将second设置为0,session将永不过期,直到servlet容器关闭.
  1. 强制关闭session,清空所有数据,使用invalidate方法

你可能感兴趣的:(Servlet与Jsp(1))