• java web项目启动加载顺序


    转载:https://www.cnblogs.com/writeLessDoMore/p/6935524.html

    web.xml加载过程(步骤):
           1.启动WEB项目的时候,容器(如:Tomcat)会去读它的配置文件web.xml.读两个节点:   

       <listener></listener> 和 <context-param></context-param>

    2.紧接着,容器创建一个ServletContext(上下文),这个WEB项目所有部分都将共享这个上下文.

    3.容器将<context-param></context-param>转化为键值对,并交给ServletContext.

    4.容器创建<listener></listener>中的类实例,即创建监听.

    5.在监听中会有contextInitialized(ServletContextEvent args)初始化方法,在这个方法中获得:

    ServletContext = ServletContextEvent.getServletContext();   
                       context-param的值 = ServletContext.getInitParameter("context-param的键");  

    6.得到这个context-param的值之后,你就可以做一些操作了.注意,这个时候你的WEB项目还没有完全启动完成.这个动作会比 所 有的Servlet都要早.
    换句话说,这个时候,你对<context-param>中的键值做的操作,将在你的WEB项目完全启动之前被执行.

    7.举例.你可能想在项目启动之前就打开数据库.
    那么这里就可以在<context-param>中设置数据库的连接方式,在监听类中初始化数据库的连接.

    8.这个监听是自己写的一个类,除了初始化方法,它还有销毁方法.用于关闭应用前释放资源.比如说数据库连接的关闭.

    web.xml节点加载顺序:

    可以肯定的是,节点的加载顺序与它们在 web.xml 文件中的先后顺序无关。即不会因为 filter 写在 listener 的前面而会先加载 filter。最终得出的结论是:listener -> filter -> servlet

            同时还存在着这样一种配置节点:context-param,它用于向 ServletContext 提供键值对,即应用程序上下文信息。我们的 listener, filter 等在初始化时会用到这些上下文中的信息,那么 context-param 配置节是不是应该写在 listener 配置节前呢?实际上 context-param 配置节可写在任意位置,因此真正的加载顺序为:

    context-param -> listener -> filter -> servlet

    对于某类配置节而言,与它们出现的顺序是有关的。以 filter 为例,web.xml 中当然可以定义多个 filter,与 filter 相关的一个配置节是 filter-mapping,这里一定要注意,对于拥有相同 filter-name 的 filter 和 filter-mapping 配置节而言,filter-mapping 必须出现在 filter 之后,否则当解析到 filter-mapping 时,它所对应的 filter-name 还未定义。web 容器启动时初始化每个 filter 时,是按照 filter 配置节出现的顺序来初始化的,当请求资源匹配多个 filter-mapping 时,filter 拦截资源是按照 filter-mapping 配置节出现的顺序来依次调用 doFilter() 方法的。

           servlet 同 filter 类似,此处不再赘述。

    【加载spring

           比如filter 需要用到 bean ,但加载顺序是: 先加载filter 后加载spring,则filter中初始化操作中的bean为null;

           所以,如果过滤器中要使用到 bean,可以将spring 的加载 改成 Listener的方式 :


    <listener>  
            <listener-class>  
                 org.springframework.web.context.ContextLoaderListener   
            </listener-class>  
    </listener>

        最终结论:

               web.xml 的加载顺序是:[context-param -> listener -> filter -> servlet -> spring] ,而同类型节点之间的实际程序调用的时候的顺序是根据对应的 mapping 的顺序进行调用的。

    ============================================================

    java filter 读取 filter init-param 配置的变量

    转载:https://blog.csdn.net/home_zhang/article/details/7754634

    web.xml中

    <!-- 编码过滤 避免出现乱码 -->
    <filter>
    <filter-name>txtFilter</filter-name>
    <filter-class>com.filter.txtFilter</filter-class>
    <init-param>
    <param-name>URL</param-name>
    <param-value>http://127.0.0.1:8081/uu/</param-value>
    </init-param>
    <init-param>
    <param-name>LocalURL</param-name>
    <param-value>http://127.0.0.1:8081/vv/</param-value>
    </init-param>
    </filter>
    <filter-mapping>
    <filter-name>txtFilter</filter-name>
    <url-pattern>/*</url-pattern>
    </filter-mapping>

    读取变量的代码:

    public void init(FilterConfig filterConfig) throws ServletException {
    System.out.println("init()...............");
    this.URL = filterConfig.getInitParameter("URL");
    this.LocalURL = filterConfig.getInitParameter("LocalURL");
    System.out.println("URL:" + URL);
    System.out.println("LocalURL:" + LocalURL);


    }

    运行控制台显示结果:

    init()...............
    UMT.URL:http://127.0.0.18081/uu/
    LocalURL:http://127.0.0.1:8081/vv/

    servlet-获取web.xml配置的init-param参数

    转载:https://www.cnblogs.com/luoxiaozhao/p/6963824.html

    1.web.xml配置的参数

    复制代码
     1      <servlet>
     2         <servlet-name>firstServlet</servlet-name>
     3         <servlet-class>com.Conservlet</servlet-class>
     4         <init-param>
     5             <param-name>url</param-name>
     6             <param-value>jdbc:mysql://localhost:3306/house</param-value>
     7         </init-param>
     8         <init-param>
     9             <param-name>user</param-name>
    10             <param-value>root</param-value>
    11         </init-param>
    12         <init-param>
    13             <param-name>pwd</param-name>
    14             <param-value>123456</param-value>
    15         </init-param>
    16         <init-param>
    17             <param-name>driver</param-name>
    18             <param-value>com.mysql.jdbc.Driver</param-value>
    19         </init-param>
    20     </servlet>
    21     <servlet-mapping>
    22         <servlet-name>firstServlet</servlet-name>
    23         <url-pattern>/a</url-pattern>
    24     </servlet-mapping>
    复制代码

    2.servlet的doGet()获取值

    复制代码
     1 protected void doGet(HttpServletRequest request, HttpServletResponse response)
     2             throws ServletException, IOException {
     3             // TODO Auto-generated method stub
     4             try {            
     5             ServletConfig config = getServletConfig();
     6             String driver=config.getInitParameter("driver");
     7             String url=config.getInitParameter("url");
     8             String user=config.getInitParameter("user");
     9             String pwd=config.getInitParameter("pwd");
    10             response.setCharacterEncoding("gbk");
    11             //注册驱动
    12             Class.forName(driver);
    13             //建立连接
    14             Connection conn = (Connection)DriverManager.getConnection(url, user, pwd);
    15             Statement stm = (Statement)conn.createStatement();
    16             ResultSet rs = stm.executeQuery("select username,pwd from user");
    17             response.setContentType("text/html;charset=gbk");
    18             PrintStream out = new PrintStream(response.getOutputStream());
    19             out.println("<html>");
    20             out.println("<head>");
    21             out.println("<title>测试连接</title>");
    22             out.println("</head>");
    23             out.println("<body>");
    24             out.println("<table border="1" width="300"");
    25             while(rs.next())
    26             {
    27                 out.println("<tr>");
    28                 out.println("<td>"+rs.getString(1)+"</td>");
    29                 out.println("<td>"+rs.getString(2)+"</td>");
    30                 out.println("</tr>");
    31             }    
    32             out.println("</table>");
    33             out.println("</body>");
    34             out.println("</html>");
    35         } catch (Exception e) {
    36             // TODO: handle exception
    37         }
    38     }
     
  • 相关阅读:
    DBCC Page查看表和索引数据
    sp_configure
    学习
    OpenRowSet, OpenDataSource
    sp output
    SQL Server中使用CLR调用.NET方法
    SQL Server 2005五个有用的动态管理对象
    SQL显示执行语句信息
    接规则,每三个一组编一个号
    C# winform 与 flash as 的交互通讯
  • 原文地址:https://www.cnblogs.com/ConfidentLiu/p/11760094.html
Copyright © 2020-2023  润新知