Servlet知识点总结

1. 使用Servlet前引入依赖包

		<!-- SSM框架引入 -->
   		<!-- servlet依赖的jar包start -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
        </dependency>
        <!-- servlet依赖的jar包start -->
        <!-- jsp依赖jar包start -->
        <dependency>
            <groupId>javax.servlet.jsp</groupId>
            <artifactId>javax.servlet.jsp-api</artifactId>
            <version>2.3.1</version>
        </dependency>
        <!-- jsp依赖jar包end -->
        <!--jstl标签依赖的jar包start -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
        <!--jstl标签依赖的jar包end -->
		<!--springboot引入 -->
		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

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: 单纯记录自己所学之坑------------仅供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值