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)
これは非常に多くのコードを確認する必要があることは承知していますが、ご協力いただきありがとうございます。
ティム