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> 

这是我用来在网页中查看的 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是空的,因为它没有被注入。你的createTemplate方法不会被调用。

您应该使用由 提供的实例JdbcDaoSupport。删除createTemplate方法和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,因为它并没有真正增加太多。相反,您可以将 aDataSource直接注入您自己的 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

TestDb.createTemplate(DataSource dataSource)将签名更改为并重TestDb.setDataSource(DataSource dataSource)试。你会得到 NPE,因为 createTemplate 方法从未被调用过。

于 2012-06-21T14:52:49.437 回答
0

你需要在你的 DAO 上使用这个方法:

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

由于您必须创建 JdbcTemplate 的方法永远不会运行,这就是您得到空指针异常的原因。

于 2012-06-21T14:52:58.770 回答
0

您需要使用 JdbcDaoSupport 提供的 JdbcTemplate 而不是在私有字段中拥有自己的。您可以通过 JdbcDaoSupport 的 getJdbcTemplate() 方法访问它。

此外,您不能使用 jsp:useBean 访问 Spring bean。相反,您调用控制器中的 bean(使用 Spring WebMVC)并将结果发送到 JSP。

这个论坛中,他们讨论了一种在没有 Spring MVC 的情况下访问 bean 的方法。

于 2012-06-21T14:52:16.323 回答