Servlet知识盘点
当前端需要访问到后端的一些接口时,需要指定一个类来负责与前后端建立通信。这个类便是servlet类。它是⽤服务器端程序,其主要功能在于交互式地浏览和修改数据,⽣成动态Web内容。
三个主体:
客户端 servlet容器 服务端
1 Servlet配置
1.1 旧版本
需要在web.xml中指明url , 类名, 类路径等信息
<servlet>
<servlet-name>⾃定义名称</servlet-name>
<servlet-class>处理请求的类的完整路径</servlet-class>
</servlet>
<servlet-mapping><!-- mapping 表示映射 -->
<servlet-name>⾃定义名称</servlet-name>
<url-pattern>请求名</url-pattern>
</servlet-mapping>
请求过来以后->web.xml->servlet-mapping标签中的url-pattern标签中的内容和请求名
进⾏匹配->匹配成功后找对应的servlet-mapping标签中的servlet-name->
去servlet标签中找和上⼀个servlet-name相同的name值->去找servlet标签中
的servlet-class中处理类的完整路径
1.2 新版本Servlet3.0
@WebServlet注解配置Servlet, 但依然保留了旧版本的配置方式。
@WebServlet(name = "myUserServlet",//可以省略
urlPatterns = "/user/test", //斜杠必须,这是客户端访问的路径
loadOnStartup = 1, //优先级,数值越小优先级越高,越是优先被类加载器加载
initParams = {//初始的缺省值
@WebInitParam(name="name", value="⼩明"),
@WebInitParam(name="pwd", value="123456")
} )
2 Servlet 工作原理
ServletRequest, ServletResponse,Servletcontext, ServletConfig
(1) Servlet接⼝定义了Servlet与servlet容器之间的契约。这个契约是:Servlet容器将Servlet类载⼊内存,并产⽣Servlet实例和调⽤它具体的⽅法。但是要注意的是,在⼀个应⽤程序中,每种Servlet类型只能有⼀个实例。
(2)⽤户请求致使Servlet容器调⽤Servlet的Service()⽅法,并传⼊⼀个ServletRequest对象和⼀个ServletResponse对象。ServletRequest对象和ServletResponse对象都是由Servlet容器(例如TomCat)封装好的,并不需要程序员去实现,程序员可以直接使⽤这两个对象。
(3)ServletRequest中封装了当前的Http请求,因此,开发⼈员不必解析和操作原始的Http数据。
ServletResponse表示当前⽤户的Http响应,程序员只需直接操作ServletResponse对象就能把响应轻松的发回给⽤户。
(4)对于每⼀个应⽤程序,Servlet容器还会创建⼀个ServletContext对象。这个对象中封装了上下⽂(应⽤程序)的环境详情。每个应⽤程序只有⼀个ServletContext。每个Servlet对象也都有⼀个封装Servlet配置的ServletConfig对象。全局参数在ServletContext里,每个servlet对象有自己的局部参数。
3 Servlet生命周期
当客户端⾸次发送第⼀次请求后,由容器(web服务器(tomcat))去解析请求, 根据请求找到对应的servlet,
判断该类的对象是否存在,不存在则创建servlet实例,调取init()⽅法 进⾏初始化操作,初始化完成后调取
service()⽅法,由service()判断客户端的请求⽅式,如果是get,则执⾏doGet(),如果是post则执⾏
doPost().处理⽅法完成后,作出相应结果给客户端.单次请求处理完毕。
当⽤户发送第⼆次以后的请求时,会判断对象是否存在,但是不再执⾏init(),⽽直接执⾏service⽅法,调取
doGet()/doPost()⽅法。
当服务器关闭时调取destroy()⽅法进⾏销毁。
四个过程:
(1)实例化 --先创建servlet实例
(2)初始化 --init()
(3)处理请求 —service()
(4)服务终⽌ --destory()
4请求
指客户端发送到服务端的消息
4.1 方式
-
get。请求的数据会附加在URL之后,以?分割URL和传输数据,多个参数⽤&连接。URL的编码格式采⽤的是ASCII编码,⽽不是uniclde,即是说所有的⾮ASCII字符都要编码之后再传输。
GET请求的数据会暴露在地址栏中,⽽POST请求则不会。
在HTTP规范中,没有对URL的⻓度和传输的数据⼤⼩进⾏限制。但是在实际开发过程中,对于GET,特定的浏览器和服务器对URL的⻓度有限制。因此,在使⽤GET请求时,传输数据会受到URL⻓度的限制。
-
post。POST请求会把请求的数据放置在HTTP请求包的包体中。
对于POST,由于不是URL传值,理论上是不会受限制的,但是实际上各个服务器会规定对POST提交数据⼤⼩进⾏限制,Apache、IIS都有各⾃的配置。
4.2 请求乱码
-
setCharacterEncoding(“UTF-8”);//post提交时管⽤
-
String s=new String(变量名.getBytes(“ISO-8859-1”),“UTF-8”);//针对于get提交时中⽂乱码
示例: String s=new String(request.getParameter(“key”).getBytes(“ISO-8859-1”),“GBK”);
-
修改tomcat中配置⽂件://使⽤于get提交
在Tomcat⽬录结构\conf\server.xml中设置字符集 。但tomcat8之后不需要手动配置了,意味着tomcat8基本上get不会出现乱码问题。
5 响应
在Service API中,定义了⼀个HttpServletResponse接⼝,它继承⾃ServletResponse接⼝,专⻔⽤来封装HTTP响应消息。 在HttpServletResponse接⼝中定义了向客户端发送响应状态码,响应消息头,响应消息体的⽅法。
5.1重定向和转发
重定向:response.sendRedirect()
重定向后 客户端网页url地址发生了改变。重定向客户端与服务器实现了二次请求和二次响应。第一次请求,服务端把目标的页面地址发给客户端。第二次请求将带上该目标地址,获取页面资源。
request.getRequestDispatcher("../success.jsp").forward(request,response);
转发属于⼀次请求⼀次响应, 客户端第一次请求后,服务端直接将所有目标资源给了客户端。
重定向会造成第一次的请求的数据丢失,如果有数据需要在各阶段请求中使用,需要将数据放在全局区 - session
6 session
request存的值只能在单次请求中保存,保存的数据不能跨⻚⾯,当重定向时,request存的值会丢失
session的数据可以在多个⻚⾯中共享,即使重定向⻚⾯,数据不会丢失
session中可以包含n个request。
会话的概念:从打开浏览器到关闭浏览器,期间访问服务器就称为⼀次会话
-
配置session.setMaxInactiveInterval(10*60);//设置有效时间为10分钟
-
让session失效。:让session失效的⽅式
1)invalidate()
2)removeAttribute(“key”)
3)直接关闭浏览器