Servlet&Session
一、Servlet()
1、 Servlet接口必须要实现一下五个方法
- init()
- ServletConfig()
- service(ServletRequest request, ServletResponse response)
- getServletConfig()
- destroy()
涉及到的包,servlet-api.jar,在IDEA中导入时,不要导入带有20081211的包,
2、涉及到的类或接口,以及他们之间的关系
- interface Servlet
- class GenericServlet
- class HttpServlet
三者关系,GenericServlet实现了Servlet接口,HttpServlet继承了GenericServlet类
- Servlet
- GenericServlet重载了除了service()之外的四个方法,简化了Servlet的开发
- HttpServlet
- 与Http协议有关
- 重写了service()方法,分为了doGet和doPost,因此执行时,至于要父类做判断,到底调用哪个方法,具体实现,还是实现HttpServlet中的方法
但是HttpServlet中的doGet()和doPost()方法,里面是HttpServletRequest 和HttpServletResponse这两个类。并且着两个类分别继承ServletRequest和ServletResponse。
注意:
URL:Uniform Resource Locator
如果不明确的调用doGet()或者doPost(),那么浏览器默认的时用GET方法
- GET方法:
- 提交的数据在URI后面以?分割,以&相连,数据暴露,不安全
- 数据量小
- 效率高
- 也是浏览器默认的提交方法
- POST方法
- 提交的数据在Http包中的body中,数据安全
- 数据量大
- 效率低
Ctrl+O:重载方法
3、浏览器和服务器之间的交互流程
无论是doGet()doPost(),请求所有相关的内容,全都在request对象里面
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JSjxG9Yj-1626961434821)(image-20210722161426180.png)]
描述执行流程
- 在浏览器中,向服务器发送一个请求,一般是通过表单来实现,表单上有请求发送的地址以及请求发送的方法
- 请求是通过浏览器发送的(会有一个Session对象),会将请求相关的所有数据都封装在一个request对象中,发送到服务器。
- 服务器接收到一个请求后(即一个request对象),按照request对象进行解析。得到,这个请求时通过什么方法发送过来的,发送了什么数据,应该把这个request对象交给服务器上的哪一个Servlet去处理。
4、request和response的常见用法
4.1、request:
常用方法和概述
- 接收参数:String getParameter(String)
- 指定每个请求的编码:void setCharacterEncoding()
- Get—>doGet()
- POST—>doPost()
request可以存储数据
- requesr.setAttribute(String, Object)
- request.getAttribute(String)
特点:
- request作用域是一次请求有效(可以多次转发)
注意:
- Tomcat7之前,GET方法,服务器默认解码用的是ISO,收到的(即客户端发送的)时UTF-8
- POST跟GET不一样
4.2、response:响应用户,向客户端输出信息,同时也是作为参数,传递
- setHeader
- setContentType()
- setCharacterEncoding()
- getWrite()获取字符输出流
服务器默认设置response对象的编码格式为ISO,浏览器默认的解码格式为UTF-8
设置服务器端的编码格式
response.setCharacterEncoding(“UTF-8”)
告诉接收的浏览器,我这个response对象应该用UTF-8解码
response.setHeader(“Content-type”, “text/html;charset=utf-8”);
以上两条语句,等同于一下一条语句的效果
setContentType( “text/html;charset=utf-8”)
5、转载(转发)和重定向
5.1、转发:是一次请求
将请求发送给服务器上的其他资源,比如说servlet,以共同完成同一次请求处理
- request.getRequestDispatcher("/TypeYourLife/userServlet").forward(request, response);
注:
- 后面的forward表示继续向前执行,并且将request对象和response对象也传递过去了
- 转发是服务器行为
- 转发是服务器一次请求中的一个小点
- 转发后,浏览器地址不变
- 转发后,不同servlet中传递的信息不会丢失,会在request中保存,可以通过getAttribute读取
- 转发只能将请求转发给同一个web应用中的组件
5.2、重定向(即页面跳转):是两次请求
作用在客户端,将请求发送给服务器后,服务器响应客户端一个新的请求地址,客户端重新发送一个请求去新的地址。
response.sendRedirect(“URI”),要给全路径/项目名/servlet访问名
注:
- 地址栏会变化
- request对象和response对象是一个新的
- 数据无法共享,但是可以在URI后拼接要传递的数据,用?隔开,用&链接,并且只能传String类型的数据
- 传了过后,通过getParameter(“name”)来获取
特点:
- 重定向是客户端行为
- 重定向是浏览器至少做了两次请求
- 浏览器地址改变
- 重定向两次跳转之间传输的数据会丢失,因为,重定向过后,是新的request对象和response对象
- 重定向可以指定任何资源。
当两个servlet互相之间需要传递数据,建议使用转发,不建议使用重定向
6、servlet生命周期
- 实例化 1次
- 初始化 1次
- 服务 多次
- 销毁 1次
web.xml
<servlet>
<servlet-name>hs</servlet-name>
<servlet-class>全限定名</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>hs</servlet-name>
<url-pattern>/hs</url-pattern>
//
</servlet-mapping>
处理结果
PrintWriter printWriter = resp.getWriter()
二、Session
描述:
用于记录用户状态。Session值的是在一段时间内,单个客户端与web服务器的一连串相关交互过程
作用:记录请求与响应
原理:
- Session类
- 服务器为每一次会话分配一个Session对象
- 同意浏览器的多次请求同属于一次会话
- 首次发起请求,服务器会自动创建Session对象,并创建Cookie存储Session,并发送回浏览器
Session拥有存储数据的空间,
使用:
作用域,Session一次会话有效,request一次请求有效
获取Session:HttpSession session = request.getSession();
当关闭浏览器,重新访问Servlet地址时,Session已经跟新了。
方法
- 保存:session.setAttribute()
- 读取:session.getAttribute()
- 删除:session.removeAttribute()
Session与Requset的区别
生命周期
- Session是由服务器创建的,在第一次请求发起时。
- 销毁:
- 浏览器关闭
- Session超时 setMaxInactiveIntervalk(30)
- 手动销毁 session.invalidate()
验证码
相关包:validateCode.jar
首先建创建生成验证码的Servlet
ValidateCode code = new ValidateCode(宽,高,字符数,干扰线数)
code.write(response.getOutputStream)
String codes = code.getCode();