大家好我正在使用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)
我做错了什么。请指导我。
谢谢
答案 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
中的null
为BooksDAO
。
在此配置中将您的服务添加为bean,并将bean edao
添加为属性
您还应该将您的服务与您的其他课程联系起来。
编辑精度:我认为问题出在这里,因为在这一行return jdbcTemplate.query("select * from books.books_table", new RowMapper<Book>()
中,NullPointerException可以有一个原因:jdbcTemplate为null。此外,您不会在其配置中声明服务bean。此外,方法体中的任何指令都不能触发NPE。 -