使用jsp可以完成动态的web开发,但是在开发时发现大量的代码在页面中,这样不简洁,不利于维护!
1,什么是Servlet?
Servlet(服务器端小程序)是使用java编写的服务器端程序,可以像jsp一样,生成动态的Web页,Servlet主要运行在服务器端,并由服务器调用执行,是一种按照Servlet标准开发的类;Servlet是Java对CGI程序的实现,但是与传统的CGI相比,Servlet是多线程的处理方式,这样Servlet的运行效率会比CGI高,Servlet还保留了Java的可移植性特点,使得Servlet更加易用,功能也更加强大;
2,Servlet的运行步骤;
- 客户端通过HTTP发出请求;
- Web服务器接收该请求并将其发送给Servlet。如果这个Servlet尚未被加载,Web服务器将把它加载到JAVA虚拟机并执行它;
- Servlet程序将接收该HTTP请求并执行某种处理;
- Servlet会将处理后的结果向Web服务器返回应答;
- Web服务器将从Servlet收到的应答发回给客户端;
3,第一个Servlet!
index.jsp:
<a href="firstServlet">测试Servlet</a>
web.xml:
<servlet>
<servlet-name>firstServlet</servlet-name>
<servlet-class>com.keith.servlet.FirstServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>firstServlet</servlet-name>
<url-pattern>/firstServlet</url-pattern>
</servlet-mapping>
FirstServlet.java:
package com.keith.servlet;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class FirstServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
this.doPost(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
System.out.println("------------hello,world---------------");
}
}
客户端发出请求,通过web.xml找到FirstServlet类,然后执行doPost()/doGet()方法,在控制台输出hello,world!
4,Servlet生命周期!
Servlet程序是运行在服务器端的一段java程序,其生命周期将受到Web容器的控制,生命周期包括加载程序,初始化,服务,销毁,卸载5部分;
其作用如下:
- 加载Servlet
web容器负责加载Servlet,当Web容器启动时或者是在第一次使用这个Servlet时,容器会负责创建Servlet实例,但是用户必须通过部署描述符(web.xml)指定Servlet的位置(Servlet所在的包,类),成功的加载后,web容器会通过反射的方式对Servlet进行实例化;
- 初始化
当一个Servlet被实例化后,容器将调用init()方法初始化这个对象,初始化的目的是为了让Servlet对象在处理客户端请求前完成一些初始化工作,比如建立数据库连接,读取资源文件等信息,如果初始化失败,则此Servlet将直接被卸载!
- 处理服务
当有请求提交时,Servlet将调用service()方法(常用的是doGet()/doPost())进行处理。在service()方法中,Servlet可以通过ServletRequest接受客户端的请求,也可以利用ServletResponse设置响应信息;
- 销毁
当Web容器关闭或者检测到一个Servlet要从容器中被删除时,会自动调用destory()方法,以便让该实例释放掉所占用的资源;
- 卸载
当一个Servlet调用完destory()方法后,此实例将等待被垃圾收集器所回收,如果需要再次使用此Servlet()时,会重新调用init()方法初始化;
注意:正常情况下,Servlet只会初始化一次,而处理服务会调用对次,销毁也只会调用一次。但是如果一个Servlet长时间不使用的话,也会被容器自动销毁,而如果需要再次使用时会重新进行初始化操作,即在特殊的情况下初始化可能会进行多次,销毁也可能进行多次;
5,取得初始化配置信息
在web.xml中配置servlet时,我们可以为其添加<init-param>标签,里面可以设置参数可以通过config对象获取;
例如,在web.xml中:
<servlet> <servlet-name>firstServlet</servlet-name> <servlet-class>com.keith.servlet.FirstServlet</servlet-class> <init-param> <param-name>name</param-name> <param-value>keith</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>firstServlet</servlet-name> <url-pattern>/firstServlet</url-pattern> </servlet-mapping>
FirstServlet.java:
package com.keith.servlet;
import java.io.IOException;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class FirstServlet extends HttpServlet {
private String initParam = null;
@Override
public void init(ServletConfig config) throws ServletException {
this.initParam = config.getInitParameter("name");
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
this.doPost(req, resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
System.out.println("初始化参数name:"+this.initParam);
}
}
可以得到name的值:keith;每一个Servlet可以同时配置多个初始化参数,配置参数时直接使用<init-param>元素即可;
6,获取其他内置对象
- 获取HttpSession实例:
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
HttpSession session = req.getSession();
session.setAttribute("name", "keith");
System.out.println("name的值是"+session.getAttribute("name"));
}
- 获取ServletContext实例:
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
ServletContext app = super.getServletContext();
System.out.println("真实路径是:"+app.getRealPath("/"));
}