从mysql db获取时获取空指针异常

时间:2016-08-16 18:46:41

标签: java mysql spring rest

大家好我正在使用rest和mysql作为我的数据库。

以下是获取所有书籍(资源)的其余获取代码

@GET
@Produces(MediaType.APPLICATION_JSON)
public Response getBooks(@QueryParam("format") String format) {

    //line35: return Response.status(Status.OK).entity((new GenericEntity<List<Book>>(bookService.getAllBooks()) {
    })).header(HttpHeaders.CONTENT_TYPE, "XML".equalsIgnoreCase(format)
            ? MediaType.APPLICATION_XML + ";charset=UTF-8" : MediaType.APPLICATION_JSON + ";charset=UTF-8").build();

}

以下是我的服务

public List<Book> getAllBooks() {

    //books service line 24 return new ArrayList<Book>(booksDao.getAllBooks());
    /* return new ArrayList<Book>(books.values()); */
}

BooksDAO类

public class BooksDAO {

private JdbcTemplate jdbcTemplate;

public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
    this.jdbcTemplate = jdbcTemplate;
}

public List<Book> getAllBooks() {
    //books dao line24: return jdbcTemplate.query("select * from books.books_table", new RowMapper<Book>() {

        @Override
        public Book mapRow(ResultSet rs, int rownumber) throws SQLException {
            Book e = new Book();
            e.setId(rs.getInt(1));

            e.setName(rs.getString(2));

            e.setPrice(rs.getString(3));

            e.setAuthor(rs.getString(4));

            return e;
        }


    });
}

下面是我的bean。我正在使用springJDBC

<?xml version="1.0" encoding="UTF-8"?>  
<beans  
xmlns="http://www.springframework.org/schema/beans"  
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
xmlns:p="http://www.springframework.org/schema/p"  
xsi:schemaLocation="http://www.springframework.org/schema/beans   
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">  

<bean id="ds" 
class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
<property name="driverClassName" value="com.mysql.jdbc.Driver" />  
<property name="url" value="jdbc:mysql://localhost:3306/xxxx" />  
<property name="username" value="xxxx" />  
<property name="password" value="xxxx" />  
</bean>  

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

<bean id="edao" class="com.nag.library.database.BooksDAO">  
<property name="jdbcTemplate" ref="jdbcTemplate"></property>  
</bean>  

</beans> 

没有连接到db我很好得到json / xml响应但是当我连接db时它抛出一个nullpointer异常

Aug 16, 2016 10:43:08 AM org.apache.catalina.core.StandardWrapperValve
invoke     
SEVERE: Servlet.service() for servlet Jersey Web Application threw exception
java.lang.NullPointerException
at com.nag.library.database.BooksDAO.getAllBooks(BooksDAO.java:24)
at com.nag.library.service.BookService.getAllBooks(BookService.java:24)
at com.nag.library.resource.BookResource.getBooks(BookResource.java:35)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at java.lang.Thread.run(Unknown Source)

我做错了什么。请指导我。

谢谢

2 个答案:

答案 0 :(得分:0)

我认为您在dao上的映射时出现了问题,您是否可以使用行号发布代码以确定我的怀疑?,但是我们无法确定与Nullpointer一致的行号( 24)。

首先,如果我是你,我会尝试按名称(getString(&#34; COLUMN_NAME&#34;))而不是索引来映射表格的字段,以检查列是否有问题(索引)或data_type)。

最后,如果这不起作用,请尝试将空对象映射为映射器结果,以检查查询是否存在问题。

Greatings

答案 1 :(得分:0)

我认为问题是你的服务不是Spring管理的bean,因为你的spring conf中没有声明。 所以你不要使用这些bean:

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

<bean id="edao" class="com.nag.library.database.BooksDAO">  
<property name="jdbcTemplate" ref="jdbcTemplate"></property>  
</bean>  

因此,您在运行时使用的jdbcTemplace中的nullBooksDAO
在此配置中将您的服务添加为bean,并将bean edao添加为属性 您还应该将您的服务与您的其他课程联系起来。

编辑精度:我认为问题出在这里,因为在这一行return jdbcTemplate.query("‌​select * from books.books_table", new RowMapper<Book>()中,NullPointerException可以有一个原因:jdbcTemplate为null。此外,您不会在其配置中声明服务bean。此外,方法体中的任何指令都不能触发NPE。 -