• Servlet------>session


    原理:

    下面一个简单的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);
    	}
    
    }
    
  • 相关阅读:
    java期末复习2
    java期末复习
    Educational Codeforces Round 76 (Rated for Div. 2)
    ICPC南昌时间安排
    codeforces 597 div2 ABCDF
    codeforces 597 div2 ABC
    Vue中provide和inject 用法
    Js打印九九乘法表
    document.documentElement和document.body的区别
    移动端关于横屏问题
  • 原文地址:https://www.cnblogs.com/SnowingYXY/p/6678054.html
Copyright © 2020-2023  润新知