zoukankan      html  css  js  c++  java
  • JavaWeb四个域

    一、ServletContext对象(Context域)
    1.服务器启动的时候,会为每一个webapp创建一个对应的ServletContext对象,他代表该webapp,当服务器停止或将webapp从服务器中移除的时候,就会销毁对应的ServletContext对象
    2.查阅ServletContext对象的相关API,很重要
    3.获取ServletContext对象的方法
    a.this.getServletConfig().getServletContext();
    b.this.getServletContext();
    4.ServletContext对象的应用:
    a.在多个Servlet之间实现数据共享(注意线程安全)
    b.获取WEB应用的初始化参数,为WEB应用设置初始化参数的方法:在web.xml配置文件中添加<context-param>节点,可以设置初始化参数,常配的初始化参数(数据库的连接信息,之前说
    配在servlet的初始化参数是不合理的,因为如果有上百个servlet要连接数据库,我们还得为这些Servlet都配置连接信息)
    c.实现Servlet的转发,通过this.getServletContext().getRequestDispacther().forward("/xx/xx.jsp");实现请求转发
    d.利用ServletContext对象读取文件(WEB工程中的配置文件.properties和.xml文件区别,如果数据没有关系,则使用.properties文件,否则使用.xml)
    Servlet中读取文件的代码:
    A.InputStream in = this.getServletContext().getResourceAsStream("path");
    Properties prop = new Properties();
    prop.load(in);
    prop.getProperty("name");

    B.String realPath = this.getServletContext().getRealPath("path");
    FileInputStream in = new FileInputStream(realPath);
    Properties prop = new Properties();
    prop.load(in);
    prop.getProperty("name");
    e.当我们使用FileInputStream读取文件的时候,并且path是相对路径的时候,该路径一定是相对于JVM的路径,Tomcat的JVM要看我们在配置的时候,配置的那个
    f.创建一个对象的流程,首先类装载器将类的字节码文件加载到内存,然后根据字节码文件反射出类的实例,如果一个类装载器能够装载某个目录下的类,那么他也能装载该目录下的文件
    g.普通JAVA类中读取文件的方式(使用claassLoader):
    A.这种方式只会在程序运行的时候加载一次,不能读到更新后的内容
    InputStream in = xxx.class.getClassLoader().getResourceAsStream("相对于该目录的相对路径");
    Properties prop = new Properties();
    prop.load(in);
    prop.getProperty("name");
    B.这种方式能读到更新后的内容
    String path = xxx.class.getClassLoader().getResource("相对于该目录的相对路径").getPath();
    FileInputStream fin = new FileInputStream(path);
    Properties prop = new Properties();
    prop.load(fin);
    prop.getProperty("name");

    四个作用域:

    何为作用域
     先让我们看看效果:

    大概流程是这样的,我们访问04-01/index.jsp的时候,分别对pageContext, request, session,

    application四个作用域中的变量进行累加。(当然先判断这个变量是不是存在,如果变量不存在,则要

    把变量初始化成1。)计算完成后就从index.jsp执行forward跳转到test.jsp。在test.jsp里再进行一次

    累加,然后显示出这四个整数来。

    从显示的结果来看,我们可以直观的得出结论:

    page里的变量没法从index.jsp传递到test.jsp。只要页面跳转了,它们就不见了。

    request里的变量可以跨越forward前后的两页。但是只要刷新页面,它们就重新计算了。

    session和application里的变量一直在累加,开始还看不出区别,只要关闭浏览器,再次重启浏览器访问

    这页,session里的变量就重新计算了。

    application里的变量一直在累加,除非你重启tomcat,否则它会一直变大。

    而作用域规定的是变量的有效期限。

    如果把变量放到pageContext里,就说明它的作用域是page,它的有效范围只在当前jsp页面里。

    从把变量放到pageContext开始,到jsp页面结束,你都可以使用这个变量。

    如果把变量放到request里,就说明它的作用域是request,它的有效范围是当前请求周期。

    所谓请求周期,就是指从http请求发起,到服务器处理结束,返回响应的整个过程。在这个过程中可能使

    forward的方式跳转了多个jsp页面,在这些页面里你都可以使用这个变量。

    如果把变量放到session里,就说明它的作用域是session,它的有效范围是当前会话。

    所谓当前会话,就是指从用户打开浏览器开始,到用户关闭浏览器这中间的过程。这个过程可能包含多个

    请求响应。也就是说,只要用户不关浏览器,服务器就有办法知道这些请求是一个人发起的,整个过程被

    称为一个会话(session),而放到会话中的变量,就可以在当前会话的所有请求里使用。

    如果把变量放到application里,就说明它的作用域是application,它的有效范围是整个应用。

    整个应用是指从应用启动,到应用结束。我们没有说“从服务器启动,到服务器关闭”,是因为一个服务

    器可能部署多个应用,当然你关闭了服务器,就会把上面所有的应用都关闭了。

    application作用域里的变量,它们的存活时间是最长的,如果不进行手工删除,它们就一直可以使用。

    与上述三个不同的是,application里的变量可以被所有用户共用。如果用户甲的操作修改了application

    中的变量,用户乙访问时得到的是修改后的值。这在其他scope中都是不会发生的,page, request,

    session都是完全隔离的,无论如何修改都不会影响其他人的数据。

    我们使用public Object getAttribute(String name)获得变量值,使用public void setAttribute

    (String name, Object value)将变量值保存到对应作用域中。举个pageContext的例子就是:

    // page
    Integer countPage = (Integer) pageContext.getAttribute("countPage");
    if (countPage == null) {
        pageContext.setAttribute("countPage", 1);
    } else {
        pageContext.setAttribute("countPage", countPage + 1);
    }
    这里先从pageContext中取出名为countPage的整数,因为返回的都是java.lang.Object类型,所以需要强

    制转换成我们需要的整形。这里取得的变量如果不存在就会返回null,通过判断countPage == null来辨

    别变量是否存在,如果不存在就设置为1,如果存在就进行累加,最后使用setAttribute()方法将修改后

    的变量值放入pageContext。

    将其中的pageContext换成request, session, application就可以操作其他三个作用域中的变量。

    总言之:

    pageContext:在本页面中有效

    request:       在一次请求及转发的Servlet中有效

    session:              在一次会话中有效,直到超时及销毁

    application:  在整个web应用有效,生命周期为Web运行期间

  • 相关阅读:
    ORA-00600: internal error code, arguments: [kgl-no-mutex-held]
    MongoDB3.4版本配置详解
    java.lang.CharSequence cannot be resolved
    truncate表恢复
    ERROR 1045 (28000): Access denied for user 'mycat'@'localhost' (using password: YES)
    安装mysql-python
    pip virtualenv requirements
    mapreduce on yarn简单内存分配解释
    tez参数
    jstat命令的使用及VM Thread分析
  • 原文地址:https://www.cnblogs.com/kydnn/p/5098415.html
Copyright © 2011-2022 走看看