Servlet

配置:

 

<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>

 

原理:

1tomcat 服务启动前,首先加载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

 

 

servlettomcat 中是单实例多线程运行的

 

同一个对象的共享数据(成员变量)则会产生数据安全性问题。

 

解决方法:

使用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域对象进行数据共享,必须用转发,不能用重定向


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值