0

Spring初心者で初投稿者です。基本的な概念は理解できたと思いますが、独自のコードを記述しようとするとエラーが発生します。宿題をして、サイトの他の関連トピックを調べましたが、コードが機能しない理由がまだわかりません。

愚かな間違いを犯した場合は、ご容赦ください。関連するコードのスニペットはすべて次のとおりです。

DAO インターフェイス

public interface TestDAO {

public int getId();

}

メイン SQL 接続コード

import javax.sql.DataSource;

import org.springframework.jdbc.core.simple.SimpleJdbcTemplate;
import org.springframework.jdbc.core.support.JdbcDaoSupport;


public class TestDb extends JdbcDaoSupport implements TestDAO{

private SimpleJdbcTemplate jdbcTemplate;

public int getId()
{
    String sql="SELECT DOI.DOI_ID FROM ***.DOI where DOI='test58'";
    int id=jdbcTemplate.queryForInt(sql);
    return id;
}

public void createTemplate(DataSource dataSource) {
    this.jdbcTemplate = new SimpleJdbcTemplate(dataSource);
}

}

beans.xml ファイル

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">

  <bean id="webMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
    <property name="mappings">
        <props>
            <prop key="/Form.html">DoiEntry</prop>
        </props>
    </property>
</bean>

<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix">
        <value>/WEB-INF/jsp/</value>
    </property>
    <property name="suffix">
        <value>.jsp</value>
    </property>
</bean>

<bean name="DoiEntry" class="com.****.****.DoiEntry">
    <property name="eventsService" ref="eventsService"/>
    <property name="sendEventsQueueService" ref="sendEventsQueueService"/>
</bean>

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> 
    <property name="dataSource" ref="dataSource"/> 
</bean>

<bean id="dataSource"        class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="oracle.jdbc.OracleDriver" />
    <property name="url" value="jdbc:oracle:thin:@localhost:1521:XE" />
    <property name="username" value="**USER**" />
    <property name="password" value="**PASSWORD**" />
</bean>

<bean id="testDAO" class="com.****.****.TestDAO">
    <property name="dataSource" ref="dataSource" />
</bean>

<bean id="testDb" class="com.****.****.TestDb">
    <property name="dataSource" ref="dataSource" />
</bean>

</beans>

そして最後に、私の web.xml ファイル

<?xml version="1.0" encoding="ISO-8859-1" ?>

<web-app xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
version="2.4">

<display-name>DOILookupApp</display-name>
<description>
    This is a simple web application with a source code organization
    based on the recommendations of the Application Developer's Guide.
</description>

<servlet>
    <servlet-name>DOILookup</servlet-name>
    <servlet-class>com.****.****.DoiLookup</servlet-class>
</servlet>


<servlet-mapping>
    <servlet-name>DOILookup</servlet-name>
    <url-pattern>/DOI</url-pattern>
</servlet-mapping>

<taglib>
<taglib-uri>
    functions.tld
</taglib-uri>
<taglib-location>
    functions.tld
</taglib-location>
</taglib>

    <!-- The main spring MVC servlet -->
<servlet>
   <servlet-name>spring</servlet-name>
   <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
   <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>beans.xml</param-value>
    </init-param>
   <load-on-startup>1</load-on-startup>
</servlet>


</web-app> 

これは、Web ページで表示するために使用する JSP ファイルです。srciptlet は無視してください。コーディングの慣習が悪いことはわかっています。テスト用に何かが必要だっただけです。

<%@ page language="java" import="java.util.*, java.sql.*;" %>

<html>
<head>
<title>Test DB</title>
</head>
  <body>

<jsp:useBean id="testDb" scope="session" class="com.****.****.TestDb"/>

<% 
  int output=testDb.getId();
  out.print("DOI ID for test58 is: ");
  out.print(output);


%>

  </body>
</html>

そして最後に、これが私のエラーメッセージです

タイプ例外レポート

メッセージ

description The server encountered an internal error () that prevented it from fulfilling this request.

exception

org.apache.jasper.JasperException: java.lang.NullPointerException
org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:502)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:430)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
root cause

java.lang.NullPointerException
com.****.****.TestDb.getId(TestDb.java:15)
org.apache.jsp.jsp.testDb_jsp._jspService(testDb_jsp.java:78)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:388)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
javax.servlet.http.HttpServlet.service(HttpServlet.java:717)

これは非常に多くのコードを確認する必要があることは承知していますが、ご協力いただきありがとうございます。

ティム

4

4 に答える 4

1

jdbcTemplate注入されていないので、あなたはnullだと思います。メソッドは呼び出されませcreateTemplateん。

によって提供されるインスタンスを使用する必要がありますJdbcDaoSupportcreateTemplateメソッドとインスタンスを削除し、メソッドを次のjdbcTemplateように置き換えますgetId

public int getId()
{
    String sql="SELECT DOI.DOI_ID FROM ***.DOI where DOI='test58'";
    int id=getJdbcTemplate().queryForInt(sql);
    return id;
}

実際に親メソッドをオーバーライドしようとしている場合、それはと呼ばれcreateJdbcTemplateます。

JdbcDaoSupportまたは、実際にはあまり追加されないため、拡張することはまったく忘れてください。代わりDataSourceに、独自のBeanに直接注入して、テンプレートインスタンスを作成できます。コンストラクタインジェクションの使用:

public class TestDb {
    private final JdbcTemplate template;

    public TestDb(DataSource ds) {
        template = new JdbcTemplate(ds);
    }
}

アプリコンテキストのBeanは次のようになります。

<bean id="testDAO" class="com.****.****.TestDb">
    <constructor-arg  ref="dataSource" />
</bean>
于 2012-06-21T14:57:00.623 に答える
0

DAO でこのメソッドが必要です。

public void setDataSource(DataSource dataSource) {
        this.jdbcTemplate = new SimpleJdbcTemplate(dataSource);
    }

JdbcTemplate を作成する必要があるメソッドが実行されないため、nullpointer 例外が発生します。

于 2012-06-21T14:52:58.770 に答える
0

独自のプライベート フィールドを使用する代わりに、JdbcDaoSupport によって提供される JdbcTemplate を使用する必要があります。JdbcDaoSupport の getJdbcTemplate() メソッドを介してアクセスします。

また、jsp:useBean を使用して Spring Bean にアクセスすることもありません。代わりに、コントローラーで (Spring WebMVC を使用して) Bean を呼び出し、結果を JSP に送信します。

このフォーラムでは Spring MVC を使用せずに Bean にアクセスする方法について話しています。

于 2012-06-21T14:52:16.323 に答える
0

TestDb.createTemplate(DataSource dataSource)署名を に変更してTestDb.setDataSource(DataSource dataSource)、再試行してください。createTemplate メソッドが呼び出されないため、NPE が発生します。

于 2012-06-21T14:52:49.437 に答える