首页 > 学院 > 开发设计 > 正文

ServletContext接口

2019-11-18 12:32:48
字体:
来源:转载
供稿:网友

  debug 原创
  
  安装在一个服务器中的一个特定URL名字空间(比如,/myapplication)下的所有Servlet,jspjavaBean等Web部件的集合构成了一个Web的应用,每一个Web应用(同一JVM),容器都会有一个背景对象,而javax.servlet.ServletContext接口就提供了访问这个背景对象的途径。你可以通过一个Servlet实例的getServletContext方法得到该Servlet运行其中的这个背景对象。从这个背景对象中你可以访问如下信息或资源:
  
  ·初始化参数
  ·存储在背境中的对象
  ·与本背景关联的资源
  ·日志
  
  可以调用ServletContext.getInitParameterNames()返回一个初始化参数的枚举对象(java.util.Enumeration),或直接指定一个参数名来得到特定的参数值:ServletContext.getInitParameter(String name)。
  另外,在Servlet的背景中还可以存放与特定名字绑定的任意类型的对象,比如:
  
   context.setAttribute(String name, Object object);
  将把object对象绑定到名字name,存放在Servlet背景中,可供同一背景中的其他Servlet共享。其他Servlet可以通过context.getAttribute(String name),得到一个背景中的对象,或通过context.removeAttribute(String name)在背景中移除一个对象。
  一个特定资源的URL可以通过调用ServletContext.getResource(String path)得到,这儿的path参数必须以“/”开始,将被解析为相对于当前Servlet背景的根的相对路径。这个方法有别于基于类加载器的java.lang.Class.getResource方法。假如你通过ServletContext.getResource方法请求了一个.jsp页面,你得到的将是JSP的源码,要得到执行结果,可以使用RequestDispatcher对象的include方法。你也可以直接以输入流的形式得到资源,
  
   public InputStream getResourceAsStream(String path);
  
  ServletContext提供了日志的支持,你可以简单的通过调用ServletContext.log(String msg),或ServletContext.log(String msg,Throwable throwable)方法,向底层的Servlet日志记录写入日志信息,后者还可写入异常信息和throwable的跟踪栈。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表