GWT中的“Servlet”(服务器端)初始化代码

时间:2014-04-10 21:56:47

标签: java gwt

如何在GWT应用程序的服务器端进行单次初始化?

我可能会想HttpServlet,你可以覆盖init(),但旧的习惯很久就会丢失;)

我想做的是:

  • 加载一堆属性

  • 建立与数据库的连接

2 个答案:

答案 0 :(得分:2)

  

加载一堆属性?

注册ServletContextListener以在服务器启动时加载Init参数。

加载属性并使其对其他类静态可见。

我已经发布了示例代码Retrieve Init parameters outside servlet


  

建立与数据库的连接?

使用JNDI绑定数据源。

使用Connection Utility类获取连接,并在完成后立即关闭连接。

以下是示例代码。

import java.sql.Connection;
import java.sql.SQLException;

import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;

import com.woodmac.datavisualizer.shared.DVConstants;

public class ConnectionUtil {

    private DataSource dataSource;

    private static ConnectionUtil instance = new ConnectionUtil();

    private ConnectionUtil() {
        try {
            Context initContext = new InitialContext();
            dataSource = (DataSource) initContext.lookup(JNDI_LOOKUP_NAME);

        } catch (NamingException e) {
            e.printStackTrace();
        }
    }

    public static ConnectionUtil getInstance() {
        return instance;
    }

    public Connection getConnection() throws SQLException {
        Connection connection = dataSource.getConnection();
        return connection;
    }

    public void close(Connection connection) throws SQLException {
        if (connection != null && !connection.isClosed()) {
            connection.close();
        }
        connection = null;
    }
}

如果您使用JBOSS in standalone mode。然后只需在standalone.xml中创建一些条目即可创建数据源。只需根据您的数据库连接更新部分值,例如connection-urluser-namepassword

在这种情况下,JNDI_LOOKUP_NAME将为java:jboss/datasources/oracle

<datasource jta="true" jndi-name="java:jboss/datasources/oracle" pool-name="OracleDS" enabled="true" use-java-context="true" use-ccm="true">
    <connection-url>jdbc:oracle:thin:@ipaddress:1521/sid</connection-url>
    <driver>oracle</driver>
    <new-connection-sql>select * from dual</new-connection-sql>
    <pool>
        <min-pool-size>20</min-pool-size>
        <max-pool-size>50</max-pool-size>
        <prefill>true</prefill>
    </pool>
    <security>
        <user-name>username</user-name>
        <password>password</password>
    </security>
    <validation>
        <check-valid-connection-sql>select * from dual</check-valid-connection-sql>
        <background-validation>true</background-validation>
    </validation>
    <timeout>
        <blocking-timeout-millis>30000</blocking-timeout-millis>
        <idle-timeout-minutes>1</idle-timeout-minutes>
        <use-try-lock>60</use-try-lock>
        <allocation-retry>1</allocation-retry>
    </timeout>
</datasource>

答案 1 :(得分:2)

您可以添加评论中提及的ServletContextListener

public class ServerConfig implements ServletContextListener {

    public void contextInitialized(ServletContextEvent event) {
    // Do stuff on startup.
    }

    public void contextDestroyed(ServletContextEvent event) {
    // Do stuff on shutdown.
    }
}

现在将新类放在服务器端,您也可以在web.xml文件中注册Listener:

<listener>
<listener-class>path.to.class.ServerConfig</listener-class> 
</listener>