Servlet知识点总结

1. 使用Servlet前引入依赖包

		
   		
        
            javax.servlet
            javax.servlet-api
            3.1.0
        
        
        
        
            javax.servlet.jsp
            javax.servlet.jsp-api
            2.3.1
        
        
        
        
            javax.servlet
            jstl
            1.2
        
        
		
		
            org.springframework.boot
            spring-boot-starter-web
        

2. servlet执行流程

a. 读取web.xml文件解析servlet
b. 使用java的反射机制初始化servlet类
c. 继承HttpServlet父类service()
4. 再通过service()判断请求方式
5. 具体实现子类方法

3. servlet的生命周期

init()---->service(dopost、doget)---->destroy()
service和doget、dopost这些的区别:
service底层是通过判断请求方式然后去选择调用doget、dopost等方法

4. servlet线程是否安全

不安全,因为servlet是单例的
如何判断是否是单例,使用无参构造函数去判断

5. cookie和session

@WebServlet("/AddCookieServlet")
public class AddCookieServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Cookie cookie=new Cookie("zero","rxp");
        resp.addCookie(cookie);
        System.out.println("添加cookie成功");
    }
}
@WebServlet("/GetCookieServlet")
public class GetCookieServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        Cookie[] cookies=req.getCookies();
        for (Cookie cookie:cookies){
            System.out.println(cookie.getName()+"-------"+cookie.getValue());
        }
    }
}

a. 创建Cookie过程,使用响应返回客户端
b. 客户端获取服务器创建的cookie信息,保存在本地
c. 每次请求浏览器会将本地cookie信息放入请求头中
d. 服务器端直接从请求头中获取到cookie
cookie能不能跨浏览器查询?为什么不能跨浏览器查询?
因为每个浏览器存的cookie位置不同

@WebServlet("/AddSessionServlet")
public class AddSessionServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //默认不传为true,没有sessionID  我会创建session
        HttpSession httpSession = req.getSession(true);
        httpSession.setAttribute("zero","rxp");
    }
}
@WebServlet("/GetSessionServlet")
public class GetSessionServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        HttpSession httpSession = req.getSession(false);
        Object zero = httpSession.getAttribute("zero");
        System.out.println("zero:"+zero);
    }
}

a. 调用req.getSession(true);
b. 创建session值成功后,将session通过响应头返回给客户端
c. 本地sessionid放入在请求头中
d. 服务端使用请求头获取sessionid找到对应session值信息
为什么换一个浏览器查询不到session?
因为没有sessionid值

cookie和session的区别:

cookie存在本地,session存在服务端
cookie可以设置存活时间,session只能直接销毁
cookie没有session安全,因为本地可以编辑伪造
cookie只能存储String类型,session什么对象都可以存储

ps: 单纯记录自己所学之坑------------仅供参考

你可能感兴趣的:(Servlet知识点总结)