1,session 是对象储备用户登录网站时的信息,当用户在页面跳转时,储存的session不会被清除,并且保存在服务器端,主要是共享数据。
详细看:WebApp之Session原理
2,代码测试:
package com.session;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class SessionDemo extends HttpServlet{
/**
*
*/
private static final long serialVersionUID = 1L;
@Override
public void init() throws ServletException {
// TODO Auto-generated method stub
super.init();
}
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//创建一个session对象
String name=request.getParameter("name");
HttpSession session=request.getSession();
Date createTime=new Date(session.getCreationTime());
Date lastTime=new Date(session.getLastAccessedTime());
String message="欢迎新用户"+name+"来到!";
Integer count=new Integer(0);
//检查是否是新的session
if(session.isNew()){
message="欢迎用户"+name+"再次来到!";
}else{
count=count+1;
}
response.setContentType("text/html");
response.setCharacterEncoding("utf-8");
PrintWriter out=response.getWriter();
out.print(message+"<br>");
out.println("id:"+session.getId()+"<br>");
out.println("createTime"+createTime+"<br>");
out.println("lastTime"+lastTime+"<br>");
out.println("count"+count+"<br>");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(req, resp);
}
@Override
public void destroy() {
// TODO Auto-generated method stub
super.destroy();
}
}
3,主要配置web.xml文件
<!-- 主要配置文件 -->
<servlet>
<servlet-name>session</servlet-name>
<servlet-class>com.session.SessionDemo</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>session</servlet-name>
<url-pattern>/SessionDemo</url-pattern>
</servlet-mapping>`
4,查看浏览器