ServletContext接口

  * javax.servlet.ServletContext

  * Tomcat服务器中ServletContecxt的完整类名: ServletContext:org.apache.catalina.core.ApplicationContextFacade

  *  获取ServletCotext

     - 分别创建两个Servlet实现类,分别获取两个Servlet实现类的ServletContecxt,发现输出的结果是一样的,是同一个内存地址

    public void service(ServletRequest request, ServletResponse response) throws ServletException, IOException {

	//获取ServletConfig

	 ServletConfig config=getServletConfig();

	 //获取ServletContext

	 ServletContext application=config.getServletContext();

	 //输出ServletContext
System.out.println("ServletContext01'ServletContext"+application);
}
   *  总结:

	     1.javaweb程序员只需要面向 javax.servlet.ServletContext接口进行调用方法,不需要关心Tomcat对ServletContext接口的实现

             2. ServletContext可以完成跨用户传递数据,因为一个项目中的所有Servle共享一个ServletContext。

	     3.ServletContext到底是什么?  什么时候被创建?   什么时候被销毁?  一个WEb项目中创建几个?

	        > ServletContext被翻译为Servlet上下文

		> 一个WebApp只有一个ServletContext对象,无论有几个Servlet实现类都只有一个ServletContext对象。(而ServletConfig则是一个Servlet对象对应一个ServletConfig)

		> 一个Webapp只有一个Web.xml文件,所有的Servle对象的配置信息都写在这一个Web.xml文件中

		> Web.xml文件在服务器启动的时候被解析

		> ServletContext对象在服务器启动阶段被实例化

		> ServletContext对象在服务器关闭的时候被销毁

		> 得出结论 :ServletContext对应的是Web.xml文件,是Web.xml文件的代表。

		> ServletContext是所有Servlet对象四周环境的代表{在同一个Webapp中所有的Servlet共享同一个ServletContext}

		> 所有用户如果想共享同一个数据,可以把该数据放在ServletContext对象中。可实现跨用户传递数据。

		> 一般放在ServletContext对象中的数据是不建议涉及到修改操作的,因为可能触发线程安全问题。

  * ServletContext中有哪些常用的方法?

                -  void  setAttribute(String name,Object object)   向ServletContext中添加数据

                       BServletContext.setAttribute("学历","大学本科");

                -  Object getAttribute(String name)   从ServletContext 获取数据

                      Object obj=BServletContext.getAttribute("学历");

                - Enumeration   getAttributeNames();  获取所有ServletContext中数据的name

                        Enumeration attributeNames=BServletContext.getAttributeNames();
while(attributeNames.hasMoreElements()){
Object name=attributeNames.nextElement();
Object value=BServletContext.getAttribute((String)name);
System.out.println(name+"="+value);
} - void removeAttribute(String name) 移除ServletContext中的数据 AServletContext.removeAttribute("学历"); - String getInitParameter(String name) // 通过name获取value String value=application.getInitParameter(name); - 什么是ParameterNames? <param-name>name</param-name> <context-param>
<param-name>name</param-name>
<param-value>ShiGe</param-value>
</context-param> <context-param>
<param-name>age</param-name>
<param-value>18</param-value>
</context-param> - Enumeration getInitParameterNames // 获取所有上下文初始化参数的name public void service(ServletRequest request, ServletResponse response) throws ServletException, IOException { //获取ServletConfig ServletConfig config=getServletConfig(); //获取ServletContext ServletContext application=config.getServletContext(); //获取所有上下文初始化参数的name Enumeration<String> names=application.getInitParameterNames(); while(names.hasMoreElements()) { String name=names.nextElement(); //通过name获取value
String value=application.getInitParameter(name); //out.print(name+"="+value); System.out.println(name+"="+value);
} } - String getRealPath(String path) 获取项目中某个文件的绝对路径 String path = BServletContext.getRealPath("index.html");
System.out.println(path); * Servlet, ServletConfig, ServletContext 三者之间的关系。 - 一个Servlet对应一个ServletConfig,一百个Servlet对应一百个ServletConfig。 - 所有的Servlet实例对象共享一个ServletContext对象 - 一个Web项目中只有一个web.xml文件,一个web.xml中包含了所有Servlet实例对象的配置信息。

JAVAEE_Servlet_06_ServletContext接口的更多相关文章

  1. App开发:模拟服务器数据接口 - MockApi

    为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...

  2. 干货来袭-整套完整安全的API接口解决方案

    在各种手机APP泛滥的现在,背后都有同样泛滥的API接口在支撑,其中鱼龙混杂,直接裸奔的WEB API大量存在,安全性令人堪优 在以前WEB API概念没有很普及的时候,都采用自已定义的接口和结构,对 ...

  3. 12306官方火车票Api接口

    2017,现在已进入春运期间,真的是一票难求,深有体会.各种购票抢票软件应运而生,也有购买加速包提高抢票几率,可以理解为变相的黄牛.对于技术人员,虽然写一个抢票软件还是比较难的,但是还是简单看看123 ...

  4. Java基础Map接口+Collections工具类

    1.Map中我们主要讲两个接口 HashMap  与   LinkedHashMap (1)其中LinkedHashMap是有序的  怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...

  5. Java基础Map接口+Collections

    1.Map中我们主要讲两个接口 HashMap  与   LinkedHashMap (1)其中LinkedHashMap是有序的  怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...

  6. java基础_集合List与Set接口

    List接口继承了Collection的方法  当然也有自己特有的方法向指定位置添加元素   add(索引,添加的元素); 移除指定索引的元素   remove(索引) 修改指定索引的元素   set ...

  7. 【WCF】自定义错误处理(IErrorHandler接口的用法)

    当被调用的服务操作发生异常时,可以直接把异常的原始内容传回给客户端.在WCF中,服务器传回客户端的异常,通常会使用 FaultException,该异常由这么几个东东组成: 1.Action:在服务调 ...

  8. PHP以接口方式实现多重继承(完全模拟)--学习笔记

     1.UML类图: 2.PHP代码: <?php /** * Created by PhpStorm. * User: andy * Date: 16-11-23 * Time: 下午7:57 ...

  9. 【微框架】Maven +SpringBoot 集成 阿里大鱼 短信接口详解与Demo

    Maven+springboot+阿里大于短信验证服务 纠结点:Maven库没有sdk,需要解决 Maven打包找不到相关类,需要解决 ps:最近好久没有写点东西了,项目太紧,今天来一篇 一.本文简介 ...

随机推荐

  1. React高级

    1.React应用 1.1创建应用 创建项目可以使用react脚手架,创建步骤如下 1)安装react脚手架 npm i -g create-react-app 2)创建项目 create-react ...

  2. 绿色城市之地下综合管廊3D可视化平台

    前言 现阶段,我国绿色城市建设发展正在热火朝天的进行,面对迅速城镇化建设导致的城市病,需要不断寻求足以丰富城市的资源,以此实现城市绿色化智能化发展,比如改造地下管廊.路灯等城市基础设施. 地下综合管廊 ...

  3. HDFS 03 - 你能说说 HDFS 的写入和读取过程吗?

    目录 1 - HDFS 文件的写入 1.1 写入过程 1.2 写入异常时的处理 1.3 写入的一致性 2 - HDFS 文件的读取 2.1 读取过程 2.2 读取异常时的处理 版权声明 1 - HDF ...

  4. MySQL注入 前端int型参数插入SQL语句

    类似PHP语言的 mysql_real_escape_string() 的函数,在用来防范SQL注入的时候,可能会遇到int型注入成功的情况. mysql_real_escape_string()用法 ...

  5. CentOS 7关闭firewalld启用iptables 开放端口

    在CentOS7中,有很多CentOS 6中的常用服务发生了变化. 其中iptables是其中比较大的一个.防火墙iptables被firewalld取代. 本文将介绍,如果采用systemctl关闭 ...

  6. MySQL时间戳unix_timestamp

    函数:FROM_UNIXTIME作用:将MYSQL中以INT(11)存储的时间以"YYYY-MM-DD"格式来显示.语法:FROM_UNIXTIME(unix_timestamp, ...

  7. 在 .NET Core 中应用六边形架构

    在本文中,您会看到一个Web API应用的模板,在.NET Core 中应用了六边形架构,并且里面包含了一些基础功能. 介绍 这是一个模板项目,里面集成了一些必备的基础功能,当我们需要开发一个新项目时 ...

  8. 使用createrepo构建本地yum仓库

    rpm包安装的时候会有很多软件会出现因为其他依赖包没有,而导致安装失败的情况.一般可以连接外网的时候我们直接使用 yum 进行安装,可以为我们解决依赖包关系,但是很多工作环境下是没有外网的,内网情况下 ...

  9. Office2013安装教程(附安装包+激活工具)

    office2013中文版是微软推出的新一代office办公软件,重点加强了云服务项目,Office2013[☜借你手指用下]采用了全新的Merto界面,使用户更加专注于内容,配合Windows 8的 ...

  10. 线上MySQL读写分离,出现写完读不到问题如何解决

    大家好,我是历小冰. 今天我们来详细了解一下主从同步延迟时读写分离发生写后读不到的问题,依次讲解问题出现的原因,解决策略以及 Sharding-jdbc.MyCat 和 MaxScale 等开源数据库 ...