-
-
ServletConfig
概述
代表当前web应用的对象,在web应用被加载后,服务器会立即创建出代表当前web应用的ServletContext对象,创建后该对象会一直驻留在内存中唯一的代表当前web应用,知道服务器关闭或者web应用移出容器时为止,随着web应用的销毁,ServletContext对象也跟着销毁。
this.getServletConfig().getServletContext();
//或者
this.getServletContext();
功能
1、在当前Servlet中配置的参数信息, 只能在当前Servlet中通过ServletConfig对象来获取, 在其他的Servlet中无法获取!如果有一段初始化参数, 希望不是属于某一个Servlet对象, 而是整个web应用都可以使用, 可以将这些参数配置到web.xml的根目录下, 配置在根目录下的这些信息是属于整个web应用的, 可以通过代表整个web应用的ServletContext来获取。
<param-name>scparam1</param-name>
<param-value>scvalue1</param-value>
<context-param>
</context-param>
下面是获取参数的方法
getInitParameter();
getInitParameterNames();
2、作为域对象使用
ServletContext对象是一个域对象,利用这个对象上的map就可以在整个web应用内实现资源的共享。如下是获取方法
setAttribute();
getAttribute();
removeAttribute();
getAttributeNames();
生命周期:和web应用的生命周期一样长(web应用被加载之后创建,随着web应用被销毁,对象也被销毁)
作用范围:在整个web应用内都可以被看见
主要功能:在整个web应用内实现资源的共享
3、获取web资源
在web开发中, 如果要在程序中获取web应用的资源文件, 需要写一个路径时:
1) 如果写一个相对路径 File file = new File("conf.properties"); 这时会到程序启动的目录下去寻找这个资源, 对于web应用来说, web应用是在容器中运行的, 这时候就会到tomcat/bin目录下去找这个文件, 找不到!!
2) 如果写一个绝对路径, 则会到程序启动目录的硬盘根目录去找这个资源文件, 也找不到!!
3) 写一个盘符开始的硬盘路径, 可以解决这个问题, 但是这种写法一旦换一个发布环境, 路径很可能是错误的. 这种写法也不可取!!
4) 可以通过ServletContext提供的方法来解决这个路径问题:sc.getRealPath("xxx"); 传入一个相对于web应用根目录的资源文件的路径, 这个方法会在传入的路径的前面动态的拼接上当前web应用根目录的硬盘路径, 从而拼接出当前资源文件的硬盘路径, 由于web应用的根目录的硬盘路径是动态获取的. 没有写死, 即使换一个发布环境, 也能获取到正确的路径
5) 当没有ServletContext对象可以使用时, 可以通过类加载器来加载资源, 类加载器提供了方法来加载资源, 但是要求传入的文件路径必须是相对于类加载器加载类的路径
getResource(xxx)
getResourceAsStream(xxx)
URL resource = xxx.class.getClassLoader().getResource("1.properties");