2

私の質問は [Link] と非常によく似ています: ( Why Servlet.service() for servlet [XYZ] in context with path [/ABC] throwed exception ) しかし、解決されたとは思いません。

これは単純な SQL ゲートウェイ アプリケーションです。私のパソコンの localhost では問題なく動作します。ただし、warファイルをサーバーにアップロードすると、この例外がスローされます

org.apache.catalina.core.StandardWrapperValve invoke SEVERE: Servlet.service() for servlet [SqlGatewayServlet] in context with path [/DEV-JDBC] threw exception java.lang.NullPointerException at sql.SqlGatewayServlet.do

java.lang.NullPointerException sql.SqlGatewayServlet.doPost(SqlGatewayServlet.java:34)

ライン:34はStatement statement = connection.createStatement();

SqlGatewayサーブレット

public class SqlGatewayServlet extends HttpServlet {

@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {

    String sqlStatement = request.getParameter("sqlStatement");
    String sqlResult = "";



    try{
        ConnectionPool pool = ConnectionPool.getInstance();
        Connection connection = pool.getConnection();

        // create a statement
        Statement statement = connection.createStatement();

        // parse the SQL string
        sqlStatement = sqlStatement.trim();
        if(sqlStatement.length() > 6){

            String sqlType = sqlStatement.substring(0, 6);
            if(sqlType.equalsIgnoreCase("select")){

                // create the HTML for the result set
                ResultSet resultSet = statement.executeQuery(sqlStatement);
                sqlResult = SQLUtil.getHtmlTable(resultSet);
                resultSet.close();

            }else{

                int i = statement.executeUpdate(sqlStatement);
                // a DDL statement
                if(i == 0){
                    sqlResult = "The statement executed successfully";
                }else{
                    sqlResult = "The statment executed sucessfully.<br>"
                            + i + "row(s) affected.";
                }                   
            }
        statement.close();
        connection.close();

        }

    }catch( SQLException e){
        sqlResult = "Error executing the SQL statement: <br>"
                + e.getMessage();

    }
    HttpSession session = request.getSession();
    session.setAttribute("sqlResult", sqlResult);
    session.setAttribute("sqlStatement", sqlStatement);

    String url = "/index.jsp";

    RequestDispatcher dispatcher = getServletContext().getRequestDispatcher(url);

    dispatcher.forward(request, response);
}

}

context.xml

<Context path="/DEV-JDBC">

<Resource name="jdbc/uplink_project" auth="Container" 
    maxActive="100" maxIdle="30" maxWait="10000" 
    username="xxxxx" password="xxxxxx" 
    driverClassName="com.mysql.jdbc.Driver" 
    url="jdbc:mysql://localhost:2082/uplink_project?autoReconnect=true" 
    logAbandoned="true" removeAbandoned="true" 
    removeAbandonedTimeout="60" type="javax.sql.DataSource" />

セットアップに何か問題がありますか? それともサーバーの問題ですか?他に必要な情報を教えてください。

少し早いですがお礼を

4

2 に答える 2

2

ConnectionPoolメソッドのクラスに問題があるgetConnection()可能性がconnectionありnullます。

于 2013-08-23T03:08:10.113 に答える
1

次のステートメントにヌル ポインター例外がある場合:

   Statement statement = connection.createStatement();

接続オブジェクトが null であることを意味します。

ConnectionPool クラスから接続オブジェクトを初期化しているためです。したがって、その getConnection メソッドが有効な接続オブジェクトを返すことを確認してください。

    ConnectionPool pool = ConnectionPool.getInstance();
    Connection connection = pool.getConnection();

ConnectionPool クラスをデバッグする必要があります。

于 2013-08-23T03:13:03.527 に答える