ServletContext 与application的异同

servletContext接口是Servlet中最大的一个接口,呈现了web应用的Servlet视图。ServletContext实例是通过 getServletContext()方法获得的,由于HttpServlet继承Servlet的关系GenericServlet类和HttpServlet类同时具有该方法。

条件:假设说我们有一个WEB应用,这个WEB应用中有10个SERVLET

在这里,这个WEB应用就拥有一个它自己的仓库-ServletContext,而这10个Servlet则共享这个大仓库,并且各自拥有属于他们自己的小仓库-ServletConfig。

ServletContext就是一个全局的概念,它属于应用,但我们有时候不想让某些参数被其他Servlet应用,仅仅想在自己的Servlet中被共享,这时候就需要把它保存在ServletConfig中,换句话说,从【一个Servlet】来看,ServletConfig是它的全局,而从一个【Servlet集合(Web应用)】来看,ServletContext是它的全局。

个人观点,仅供参考。

是这样的,假设现在要运行一个应用。

1.Tomcat启动→读入xml文件 
2.容器为这个应用建立一个新的ServletContext实例,应用的所有部分都共享这个上下文 
3.如果xml中有定义上下文的初始参数,则容器首先创建初始参数实例(应该就像一个Bean一样) 
4.把初始化参数实例的引用交给ServletContext 
5.容器建立一个新的servlet,这时建立一个新的ServletConfig对象,并且为这个ServletConfig对象提供一个ServletContext的引用 
6.调用servlet的init()方法初始化servlet

由第5步可以看出,每个servlet中都有一个上下文(ServletContext)的引用,因此,servlet都知道这个上下文。 
但是ServletContext的实例比Servlet先诞生,所以ServletContext诞生的时候并不知道Servlet的存在。

在JAVA EE API文档中 
ServlectContext拥有获得Servlet的方法 
例如:Servlet getServlet(String name) 
但是,这一类的方法已经废弃了,从注释中可以看出,原先的这些方法返回的值是null,也就是无法获得servlet

因此,ServlectContext诞生的时候并不知道Servlet的存在,它的诞生仅仅是因为容器诞生了~~

我个人感觉,ServletContext中并没有Servlet的信息,相反,每个Servlet中都持有ServletContext的引用。

在HeadFirstJSP中有一个说法我觉得不错,ServletContext就像一块布告栏,你可以往上贴布告,走过的人都可以看到它!

servlet上下文,是针对servletconfig而提出来的,因为容器在配置文件中提取的初始化参数保存在了servletconfig对象中,但由于初始化参数只针对某个具体的servlet而言,别的servlet是访问不到这个参数的,所以为了提供一个可以供全体servlet使用的对象--这个对象也可以从配置文件中获取参数,哪个老外就弄出了一个servletcontext对象,并把它称为上下文或者应用上下文,其实就这么简单。只不过大家现在所听到的所看到的上下文被形态化了,经典话了而已。追起本质,还是很好理解的。

ServletContext 与application的异同

相同:其实servletContext和application 是一样的,就相当于一个类创建了两个不同名称的变量。在

servlet中ServletContext就是application对象。大家只要打开jsp编译过后生成的Servlet中的

_jspService()方法就可以看到如下的声明:
            ServletContextapplication = null;

application= pageContext.getServletContext();

不同:两者的区别就是application用在jsp中,servletContext用在servlet中。application和page

requestsession 都是JSP中的内置对象,在后台用ServletContext存储的属性数据可以用

application对象获得。

而且application的作用域是整个Tomcat启动的过程。
例如:ServletContext.setAttribute("username",username);
则在JSP网页中可以使用  application.getAttribute("username");
来得到这个用户名。

时间: 2024-10-08 11:09:54

ServletContext 与application的异同的相关文章

Java中session与application的异同

客户端的session 其实是标记了你的请求来自哪个浏览器 问题1:永远都一样吗? 答:重启了浏览器,你的session id就改变了, 结果会导致,再无法取回原来在服务端保存的数据. 问题2:假设客户端的session id不变(浏览器不重启), 那么服务器会一直保存这个session的数据吗? 答:服务端(tomcat)如果20分钟,没有人动, 那么这个session就自动销毁. 对于application在整个项目中,变量是有且只有1个,所有客户端都共享同一个application对象.

web中servletcontext和applicationContext

参看:http://www.cnblogs.com/isisbenben/p/5594323.html servletContext和ApplicationContext有什么区别 servletContext:是web容器的东西,一个webapp一个,比session作用范围要大,从中得到很多信息,比如:工程部署的路径目录. ApplicationContext:是Spring的东西,spring通过这个读取xml配置文件来new bean的(应用上下文) 作用:(1)读取bean配置文件,管

Listener-监听器+ServletContext+ApplicationContext

参考资料 ServletContext和ApplicationContext有什么区别 ServletContext:是web容器的东西, 一个webapp一个, 比session作用范围要大, 从中可以得到很多信息, 比如, 工程部署的路径目录, 工程的初始化参数,也可以setAttribute进去用法和session一样, 不过注意作用域 作用: ApplicationContext:Spring的东西, spring是通过这个读取xml配置文件来new bean的 (应用上下文关系) 作用

JSP中的内置对象和Struts中的Web资源的详解

JSP中的内置对象有如下几种: request :继承于HttpServletRequest, HttpServletRequest继承ServletRequest, 获得的Request对象的方法:只能在Servlet中获取的doGet()和doPost()方法中获取 作用:封装用户请求信息 response   : 继承于HttpServletResponse,   HttpServletResponse继承ServletResponse 获得response对象的方法:只能在Servlet

Java四大域

根据有作用范围由小到大: page(jsp有效)------>page域指的是pageContext. request(一次请求)--->request域request  HttpServletRequest session(一次会话)--->session域session HttpSession application(当前web应用)--->application域指的是application  ServletContext: 之所以他们是域对象,原因是他们都内置了map集合,

struts2在action中获取request、session、application,并传递数据

如果只是通过request.session.application传递数据,则不需要获取相应的对象也可以传递数据,代码如下: ScopeAction.java: package com.itheima.action; import com.opensymphony.xwork2.ActionContext; public class ScopeAction { public String execute() { /* * 我们这里不通过字段(添加setXXX.getXXX方法)传递数据,我们想着

JSP作用域之pageContext,request,session,application

作用域的作用是用来绑定数据.属性   pageContext          页面           javax.servlet.jsp.PageContext pageContext 当前页面范围,pageContext对象不能向其它页面传递参数据   request                 页面跳转     javax.servlet.http.HttpServletRequest request 范围在一个页面到另一个页面的一个请求,请求转发中可以使用request     s

Setvlet基础(三)ServletContext

1.ServletContext  是服务器内共享的对象. 2.ServletContext与application的区别 相同:其实servletContext和application 是一样的,就相当于一个类创建了两个不同名称的变量. 在 servlet中ServletContext就是application对象. 大家只要打开jsp编译过后生成的Servlet中的_jspService()方法就可以看到如下的声明: ServletContext application = null; ap

在Struts2中使用ValueStack、ActionContext、ServletContext、request、session等 .

笔者不知道该用哪个词来形容ValueStack.ActionContext等可以在Struts2中用来存放数据的类.这些类使用的范围不同,得到的方法也不同,下面就来一一介绍. 声明:本文参考Struts2版本为2.3.1.2,内容仅供参考,限于笔者水平有限,难免有所疏漏,望您能友善指出.本文发表于ITEYE,谢绝转载. 1. ValueStack ValueStack在中文版的<Struts2深入浅出>一书中译作“值栈”.其本身数据结构是一个栈,使用者可以把一些对象(又称作bean)存入值栈中