Servlet--ServletContext接口

  • Servlet--ServletContext接口
定义public interface ServletContext

定义了一个 Servlet 的环境对象,通过这个对象,Servlet 引擎向 Servlet 提供环境信息。一个 Servlet 的环境对象必须至少与它所驻留的主机是一一对应的。在一个处理多个虚拟主机的 Servlet 引擎中(例如,使用了 HTTP1.1 的主机 头域) ,每一个虚拟主机必须被视为一个单独的环境。此外,Servlet 引擎还可以创建对应于一组 Servlet 的环境对象。


方法
1、getAttribute
public Object getAttribute(String name);
返回 Servlet 环境对象中指定的属性对象。如果该属性对象不存在,返回空值。这个方法允许访问有关这个 Servlet 引擎的在该接口的其他方法中尚未提供的附加信息。
2、getAttributeNames
public Enumeration getAttributeNames();
返回一个 Servlet 环境对象中可用的属性名的列表。
3、getContext
public ServletContext getContext(String uripath);
返回一个 Servlet 环境对象,这个对象包括了特定 URI 路径的 Servlets 和资源,如果该路径不存在,则返回一个空值。URI 路径格式是/dir/dir/filename.ext。为了安全,如果通过这个方法访问一个受限制的 Servlet 的环境对象,会返回一个空值 。
4、getMajorVersion
public int getMajorVersion();
返回 Servlet 引擎支持的 ServletAPI 的主版本号。例如对于 2.1 版,这个方法会返回一个整数 2。
5、getMinorVersion
public int getMinorVersion();
返回 Servlet 引擎支持的 ServletAPI 的次版本号。例如对于 2.1 版,这个方法会返回一个整数 2。
6、getMimeType
public String getMimeType(String file);
返回指定文件的 MIME 类型,如果这种 MIME 类型未知,则返回一个空值。MIME 类型是由 Servlet 引擎的配置决定的。
7、getRealPath
public String getRealPath(String path);
一个符合 URL 路径格式的指定的虚拟路径的格式是: /dir/dir/filename.ext。 用这个方法 ,可以返回与一个符合该格式的虚拟路径相对应 的真实路径的 String。这个真实路径的格式应该适合于运行这个 Servlet 引擎的计算机(包括其相应的路径解析器) 。
不管是什么原因, 如果这一从虚拟路径转换成实际路径的过程不能执行, 该方法将会返回一个空值。
8、getResource
public URL getResource(String uripath);
返回一个 URL 对象,该对象反映位于给定的 URL 地址(格式:/dir/dir/filename.ext ) 的Servlet 环境对象已知的资源。 无论 URLStreamHandlers 对于访问给定的环境是不是必须的 ,Servlet 引擎都必须执行。如果给定的路径的 Servlet 环境没有已知的资 源,该方法会返回一个空值。这个方法和 java.lang.Class 的 getResource 方法不完全相同。 java.lang.Class 的
getResource 方法通过装载类来寻找资源。而这个方法允许服务器产生环境变量给任何资源的任何 Servlet, 而不必依赖于装载类、特定区域等等。
9、getResourceAsStream
public InputStream getResourceAsStream(String uripath);
返回一个 InputStream 对象,该对象引用指定的 URL 的 Servlet 环境对象的内容。如果没找到 Servlet 环境变量,就会返回空值,URL 路径应该具有这种格式:/dir/dir/filename.ext 。这个方法是一个通过 getResource 方法获得 URL 对象的方便的途径。请注意,当你使用这个方法时,meta-information(例如内容长度、内容类型)会丢失。
10、getRequestDispatcher
public RequestDispatcher getRequestDispatcher(String uripath);
如果这个指定的路径下能够找到活动的资源(例如一个 Servlet,JSP 页面,CGI 等等)就返回一个特定 URL 的RequestDispatcher 对象,否则,就返回一个空值,Servlet 引擎负责用一个 request dispatcher 对象封装目标路径。这个 request dispatcher 对象可以用来完全请求的传送。
11、getServerInfo
public String getServerInfo();
返回一个 String 对象,该对象至少包括 Servlet 引擎的名字和版本号。
12、log
public void log(String msg);
public void log(String msg, Throwable t);
public void log(Exception exception, String msg); // 这种用法将被取消
写指定的信息到一个 Servlet 环境对象的 log 文件中。被写入的 log 文件由 Servlet 引擎指定,但是通常这是一个事件 log。当这个方法被一个异常调用时,log 中将包括堆栈跟踪 。
13、setAttribute
public void setAttribute(String name, Object o);
给予 Servlet 环境对象中你所指定的对象一个名称。
14、removeAttribute
public void removeAttribute(String name);
从指定的 Servlet 环境对象中删除一个属性。
注:以下几个方法将被取消
15、getServlet
public Servlet getServlet(String name) throws ServletException;
最初用来返回一个指定名称的 Servlet,如果没找到就返回一个空值。如果这个 Servlet能够返回,这就意味着它已经被初始化,而且已经可以接受 service 请求。这是一个危险的方法。当调用这个方法时,可能并不知道 Servlet 的状态,这就可能导致有关服务器状态的问题。而允许一个 Servlet 访问其他 Servlet 的这个方法也同样的危险。现在这个方法返回一个空值, 为了保持和以前版本的兼容性, 现在这个方法还没有被取消。在以后的 API 版本中,该方法将被取消。
16、getServletNames
public Enumeration getServletNames();
最初用来返回一个 String 对象的列表,该列表表示了在这个 Servlet 环境下所有已知的Servlet 对象名。这个列表总是包含这个 Servlet 自身。基于与上一个方法同样的理由,这也是一个危险的方法。现在这个方法返回一个空的列表。 为了保持和以前版本的兼容性, 现在这个方法还没有被取消。在以后的 API 版本中,该方法将被取消。
17、getServlets
public Enumeration getServlets();

最初用来返回在这个 Servelet 环境下所有已知的 Servlet 对象的列表。这个列表总是包含这个 Servlet 自身。基于与 getServlet 方法同样的理由,这也是一个危险的方法。现在这个方法返回一个空的列表。 为了保持和以前版本的兼容性, 现在这个方法还没有被取消。在以后的 API 版本中,该方法将被取消。


这个类一般不怎么用到,下面贴出这个类的源码:

package javax.servlet;

import java.io.InputStream;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.Enumeration;
import java.util.Set;

public abstract interface ServletContext
{
  public abstract ServletContext getContext(String paramString);

  public abstract String getContextPath();

  public abstract int getMajorVersion();

  public abstract int getMinorVersion();

  public abstract String getMimeType(String paramString);

  public abstract Set getResourcePaths(String paramString);

  public abstract URL getResource(String paramString)
    throws MalformedURLException;

  public abstract InputStream getResourceAsStream(String paramString);

  public abstract RequestDispatcher getRequestDispatcher(String paramString);

  public abstract RequestDispatcher getNamedDispatcher(String paramString);

  /** @deprecated */
  public abstract Servlet getServlet(String paramString)
    throws ServletException;

  /** @deprecated */
  public abstract Enumeration getServlets();

  /** @deprecated */
  public abstract Enumeration getServletNames();

  public abstract void log(String paramString);

  /** @deprecated */
  public abstract void log(Exception paramException, String paramString);

  public abstract void log(String paramString, Throwable paramThrowable);

  public abstract String getRealPath(String paramString);

  public abstract String getServerInfo();

  public abstract String getInitParameter(String paramString);

  public abstract Enumeration getInitParameterNames();

  public abstract Object getAttribute(String paramString);

  public abstract Enumeration getAttributeNames();

  public abstract void setAttribute(String paramString, Object paramObject);

  public abstract void removeAttribute(String paramString);

  public abstract String getServletContextName();
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值