ps:好久没更新了,我把知识点都写在了文档上,别急以后可能一天会更新好多条,哈哈哈
一、上下文概念:
每一个Web Project,运行时都部署在Tomcat下,称为一个应用。
部署后,启动Tomcat时,Tomcat将为每一个应用创建一个对象,这个对象称之为上下文对象。
一个应用有且只有一个上下文对象,由容器创建,并保存在容器上。
简单的说呢:上下文对象就像一个通道
tomcat 容器加载配置文件通过 context来告诉tomcat去哪里加载
容器和容器之间要想通信就需要依赖context
context依赖Map,一个容器进行K/V存储 一个容器通过K/V获取
二、上下文作用:
1.上下文对象类似一个全局变量,在整个应用中有效。
2.利用上下文对象,可以实现多个用户间的数据共享。
Servlet API中定义了ServletContext接口,用来封装上下文对象。
该接口中定义了一些列的方法:
Context的种类
根据Context依托的组件以及用途不同,可以将Context分为以下几种
1)Application:Android 应用中国的默认单例类,在Activity或者Service中通过getApplication()可以获取到这个单例,通过context。getApplicationContext()可以获取到应用全局唯一的Context实例。2.
2)Activity/Service: 这两个类都是ContextWrapper的子类,在这两个类中看通过getBaseContext()获取到它们的Context实例,不同的Activity或者service实例,它们的Context都是独立的,不会复用。
3)BroadcastReceiver:和Activity以及Service不同,BoadcastReceiver本身并不是Context的子类,而是在回调函数onReceive()中由Android框架传入一个Context的实例。系统传入的这个Context实例是经过功能裁剪的,它不能调用registerReceiver()以及bindService()这两个函数。
4)ContentProvider:同样的,ContentProvider也不是Context 的子类,但在创建时,系统会传入一个Context实例,这样在ContenttProvider中可以通过调用getContext()函数获取。如果ContentProvider和调用者处于相同的应用进程中,那么getContext()将返回应用全局唯一的Context实例。如果是其他进程调用的ContentProvider,那么ContentProvider将持有自身所在进程的Context实例。
三、如何获得上下文对象
1.Servlet类中常用的获取上下文对象的方法
-Servlet直接调用getServletContext方法返回ServletContext对象
2.JSP文件中使用上下文对象的方法
-JSP文件的内置对象application即上下文对象,可以调用ServletContext接口中的任意方法
ex:
<%=application.getAttribute("") %>
ServletContext sc = this.getServletContext();
if(sc.getAttribute("a")){
}