原理:


下面一个简单的demo:在访问购买servlet时创建一个session,key为name
在访问购买servlet时取出值来进行购买
/**
* 购买servlet
*/
@WebServlet("/sessionDemo1")
public class sessionDemo1 extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session=request.getSession();
session.setAttribute("name", "洗衣机");
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request, response);
}
}
/**
* 结账servlet
*/
@WebServlet("/sessionDemo2")
public class sessionDemo2 extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setCharacterEncoding("UTF_8");
response.setContentType("text/html;charset=UTF-8");
PrintWriter out=response.getWriter();
Object value=request.getSession().getAttribute("name");
out.write(value.toString());
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request, response);
}
}

session生命周期:
第一个getsession出现时创建,第二getssesion出现时取值
默认30分钟没活动就会才摧毁
也可以设失效时间在web.xml

------>十分钟失效
代码方式摧毁session
session.invalidate();
场景————————》电商网站,选择好的商品关闭浏览器就丢失,所以这里需要分析下session的原理
每个浏览器有一个session,两个连接的关键点在于用JSESSIONID来寻找对应的session
关闭浏览器,再重新访问,虽然session还存在,因为JSESSIONID没有传入进来所以不知道寻找哪个session
通过如下代码给浏览器回写给浏览器JSESSIONID:
HttpSession session=request.getSession();
String sessionId=session.getId();
Cookie cookie=new Cookie("JSESSIONID", sessionId);
cookie.setMaxAge(30*60);
cookie.setPath("/day06");
response.addCookie(cookie);
浏览器可以控制cookie被禁,因为session基于cookies,这样session也就不能正常进行
getsession这个方法逻辑是这样的------》先判断是否以cookies回写JSESSION,在判断是否以URL形式带来JSESSION,都没有创建新的session
如果这样写----》getsession(false)只读取,不创建
所以解决cookie被禁的方法是重写url
response.encodeURL(URL)----->自动给这个url加上JSESSION
特例:在IE8版本的浏览器里,开新浏览器不创建新的session,用的是同一个
下面给一个用户登录时,密码正确就给用户一个登录的session标记,退出就销毁session,下面是demo
效果:
先登录----》aa aa---->登录成功------》注销----》弹回登录页面
-----》
----
---》
-----》![]()
LoginServlet.java
/**
* 登录
*/
@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setCharacterEncoding("UTF_8");
response.setContentType("text/html;charset=UTF-8");
PrintWriter out=response.getWriter();
String username=request.getParameter("username");
String password=request.getParameter("password");
List<User> lists=DB.getAll();
for(User list:lists){
if(list.getUsername().equals(username)){
if(list.getPassword().equals(password)){
request.getSession().setAttribute("user", list);// 登录成功往session里存入登录标记
response.sendRedirect("/day06/index.jsp");//重定向到首页
return;
}
}
}
out.write("用户名或者密码不对");
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request, response);
}
}
@SuppressWarnings("unchecked")
class DB{//模拟数据库
@SuppressWarnings("rawtypes")
public static List list=new ArrayList();
static{
list.add(new User("aa","aa"));
list.add(new User("bb","bb"));
list.add(new User("cc","cc"));
}
@SuppressWarnings("rawtypes")
public static List getAll(){
return list;
}
}
login.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <form action="/day06/LoginServlet" method="post "> 用户名:<input type="text" name="username" /> 密码:<input type="password" name="password" /> <input type="submit" value="提交"> </form> </body> </html>
user.java(用户实体)
/**
*
*/
package session;
/**
* @author: snowing
* @date : 2017年4月9日
*
*/
public class User {
private String username;
private String password;
/**
* @param string
* @param string2
*/
public String getUsername() {
return username;
}
public User() {
super();
// TODO Auto-generated constructor stub
}
public User(String username, String password) {
super();
this.username = username;
this.password = password;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
index.jsp(登录成功页面)
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
success!!${user.username} <a href="/day06/LoginoutServlet">注销登录</a>
</body>
</html>
LoginoutServlet.java
/**
* 登出
*/
@WebServlet("/LoginoutServlet")
public class LoginoutServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session=request.getSession(false);
if(session==null){
response.sendRedirect("/day06/login.html");
return;
}
session.removeAttribute("user");
response.sendRedirect("/day06/login.html");
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request, response);
}
}