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