配置:
<servlet>
<!-- 名称-->
<servlet-name>FirstServlet</servlet-name>
<servlet-class>gz.itcase.a_servlet.FirstServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>FirstServlet</servlet-name>
<url-pattern>/first</url-pattern>
</servlet-mapping>
原理:
1、tomcat 服务启动前,首先加载webapps中的每个web应用的web.xml配置文件
2、通过路径查找是否有匹配的url-pattern内容
3、通过url-pattern 找到servlet配置
4、通过servlet-class 找到类
5、通过反射创建servlet对象,调用其方法
servlet的映射路径:
url-pattern 游览器输入路径
1、精确匹配 /first _http://localhost:8080/test/first
2、模糊匹配 /* _http://localhost:8080/test/…
*.后缀名
*.action
*.do
注意: url-pattern 必须以/ 或者 * 开头,两种模糊匹配不能同时使用
当有多个servlet被匹配上了,精确的优先。
/* 是servlet 的缺省默认路径,改路径对应的一个是DefaultServlet,这个缺省的
servlet的作用是用于解析web的应用的静态资源文件
DefaultServlet程序到应用目录的根目录下查找一个存在的index.html的静态文件
如果找不到就返回404
引入:
Servlet 的生命周期:servlet类对象什么时候创建,什么时候调用什么方法,什么时候
销毁。
Servlet的程序的生命周期由tomcat服务器控制
Servlet的生命周期:
构造方法:创建servlet对象的时候调用,第一次访问servlet的时候创建对象,servlet对象在tomcat服务器中是单实例的
init方法:创建servlet对象的时候调用
service方法:每次发出的请求的时候调用
destroy方法:销毁servlet对象的时候调用,停止服务器或者重新部署web应用时销毁servlet对象
servlet的自动加载:
默认情况下,第一次访问servlet的时候创建servlet对象,如果servlet的构造方法或者init方法执行代码比较多,则会导致第一次加载较慢
设置servlet在服务器启动的时候加载
<load-on-startup>数字<load-on-startup> 数值越大,创建优先级越低
servlet的生命周期方法,一定会被tomcat服务器调用
init(ServletConfig config) throwss ServletException
下面该方法是给程序员覆盖的
public void init() throws ServletException
servlet在tomcat 中是单实例多线程运行的
同一个对象的共享数据(成员变量)则会产生数据安全性问题。
解决方法:
使用synchronized 锁起来,使用类字节对象作为锁
建议在servlet 中尽量不用成员变量,如果确实要使用成员变量
必须要同步,而且尽量缩小同步代码块范围,同步会影响并发性能
(哪里使用到了成员变量,就同步哪里,以避免因为同步导致并发效率降低)
HttpServletRequest 请求对象,获取请求信息
HttpServletResponse 响应对象,
ServletConfig servlet 配置对象
ServletContext servlet 上下文对象
ServletConfig对象:主要用于加载servlet的初始化参数
创建:
在servlet 对象创建以后,在init方法调用之前
初始参数
<int-param>
<param -name>path</param-name>
<param-value>e:/a.txt</param-value>
</init-param>
API
getInitParameter(String name) 根据参数名获取参数
ServletContext 对象
引用:表示当前的web环境
Api:
getContextPath() -- 表示当前web应用的路径
getInitParamter(str) -- web应用的初始化参数
getAttribute() --域对象的相关方法
setAttribute(name)
示例:
ServletContet context = this.getServletContext();
// web 应用路径 :项目名称
String contextPath = context.getContextpath();
/**
*案例:应用到请求重定向
*/
response.sendRediect(contextPath +"/index.html");
参数配置:
<web-app>
<context-param>
<param-name>AAA</param-name>
<param-value>AAA 's Value</param-value>
</context-param>
<servlet>
// 只能该servlet 访问
<context-param>
<param-name>AAA</param-name>
<param-value>AAA 's Value</param-value>
</context-param>
</servlet>
</web-app>
context.getInitParameter("name");
Enumeration<String> enums = context.getInitParameterName();
while(enums.hasMoreElements()){
String paramName = enums.nextElement();
String paramValue = context.getInitParameter(paramName);
}
域对象:
作用:用于保存数据,获取数据,可以在不同的动态资源之间共享数据
案例:url传参只能传递字符串,域对象可以共享任何类型的数据!!!!
保存数据: setAttribute(str,obj);
取出数据: getAttribute(str);
删除数据: removeAttribute();
ServletContext 域对象:作用范围是整web应用有效
所有域对象:
HttpSevletRequest
ServletContext
HttpSession
PageContext
转发:
RequestDispatcher rd =this.getRequestDispatchaer("/index.html");
rd.forward(request,response);
转发和重定向的区别:
1、转发地址栏不变,重定向地址栏会变
2、转发只能转当前web应用内部资源,重定向可以任意资源
3、转发可以在转发过程中把数据存在request域对象中,重定向不能把数据保存在request中
重定向原理返回 302 + location
结论:如果用request域对象进行数据共享,必须用转发,不能用重定向