0

filestorePath がハードコードの場合、pdf ファイルを作成するコードは正常に機能します。ハードコーディングされた filestorePath をデータベースから取得した値に置き換えるとすぐに、ビューが呼び出されたときに NullPointerException が発生します。ロジックはコード内の他の場所で使用され、そこでは正常に機能するため、クエリは正しい値を返します。

何か案は?

public class PDFDeliveryNoteBuilder extends AbstractPdfViewCustom{

Logger logger = LoggerFactory.getLogger(PDFDeliveryNoteBuilder.class);

@Autowired
private RepositoryJdbcTemplate dbRepository;

private BaseFont bfBold;
private BaseFont bf;
private int pageNumber = 0;

protected void buildPdfDocument(Map<String, Object> model, Document doc,
                    PdfWriter docWriter, HttpServletRequest request, HttpServletResponse response)
                    throws Exception {

    //String filestorePath = "/xxx/www/xxxxx/tmp/";
    //TODO gives null pointer exception
    SysParam sysParam = dbRepository.findSysParam();
    String sysTmpdir = sysParam.getSysTmpdir();
    String filestorePath = sysTmpdir;
    String downloadfileNm = "DeliveryNote.pdf";
    String filePath = filestorePath+downloadfileNm;
    logger.debug("--> filePath: "+filePath);
    initializeFonts();

    try {
        // get data model which is passed by the Spring container
        @SuppressWarnings("unchecked")
        List<AuditTrailHist> auditTrailHistPublishDeliveredList = (ArrayList<AuditTrailHist>) model.get("auditTrailHistDeliveredList");

        docWriter = PdfWriter.getInstance(doc , new FileOutputStream(filePath));
        doc.addAuthor("xxx");
        doc.addCreationDate();
        doc.addProducer();
        doc.addCreator("xxx");
        doc.addTitle("Delivery Note");
        doc.setPageSize(PageSize.LETTER);
        doc.open();
        PdfContentByte cb = docWriter.getDirectContent();
        boolean beginPage = true;
        int y = 0;
        //get the most recent audit trail history record for header
        Integer size = auditTrailHistPublishDeliveredList.size();
        AuditTrailHist auditTrailHistRecentRec = auditTrailHistPublishDeliveredList.get(size-1);
        //get all the audit trail history records for detail
        for (AuditTrailHist auditTrailHist : auditTrailHistPublishDeliveredList) {
            if(beginPage){
                beginPage = false;
                generateLayout(doc, cb);
                generateHeader(doc, cb,auditTrailHistRecentRec);
                y = 615; 
            }
            generateDetail(doc, cb, auditTrailHist, y);
            y = y - 15;
            if(y < 50){
                printPageNumber(cb);
                doc.newPage();
                beginPage = true;
            }
        }
        printPageNumber(cb);
    }
    catch (DocumentException dex) {
        dex.printStackTrace();
    }
    catch (Exception ex) {
        ex.printStackTrace();
    }
    finally {
        if (doc != null){
            doc.close();
        }
        if (docWriter != null) {
            docWriter.close();
        }
    }
} //end buildPdfDocument

エラーログは次のとおりです。

2015-04-22 23:53:41.551 DEBUG   org.springframework.jdbc.datasource.DataSourceUtils [http-bio-8080-exec-3]  Returning JDBC Connection to DataSource
2015-04-22 23:53:41.552 DEBUG   org.springframework.beans.factory.support.DefaultListableBeanFactory    [http-bio-8080-exec-3]  Returning cached instance of singleton bean 'pdfDeliveryNoteView'
2015-04-22 23:53:41.552 DEBUG   org.springframework.web.servlet.DispatcherServlet   [http-bio-8080-exec-3]  Rendering view [com.xxxx.view.PDFDeliveryNoteBuilder: name 'pdfDeliveryNoteView'] in DispatcherServlet with name 'dispatcher'
2015-04-22 23:53:41.679 DEBUG   com.xxx.view.PDFDeliveryNoteBuilder [http-bio-8080-exec-3]  --> before dbRepository
2015-04-22 23:53:41.681 DEBUG   org.springframework.web.servlet.DispatcherServlet   [http-bio-8080-exec-3]  Error rendering view [com.xxxx.view.PDFDeliveryNoteBuilder: name 'pdfDeliveryNoteView'] in DispatcherServlet with name 'dispatcher'
java.lang.NullPointerException
    at com.xxxx.view.PDFDeliveryNoteBuilder.buildPdfDocument(PDFDeliveryNoteBuilder.java:48)
    at com.xxxx.view.AbstractPdfViewCustom.renderMergedOutputModel(AbstractPdfViewCustom.java:92)
    at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:303)

spring XML 構成の下。web.xml

<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id="WebApp_ID" version="3.0">

<display-name>xxx Web Application</display-name>
<description>xxx Web Application</description> 

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>
        /WEB-INF/spring-mvc-dispatcher.xml
        /WEB-INF/spring-jdbc.xml
        /WEB-INF/spring-security.xml
    </param-value>
</context-param>
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

<servlet>
    <servlet-name>dispatcher</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/spring-mvc-dispatcher.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
    <servlet-name>dispatcher</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>

<filter>
    <filter-name>springSecurityFilterChain</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>

<filter-mapping>
    <filter-name>springSecurityFilterChain</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping> 

<error-page>
    <error-code>404</error-code>
    <location>/WEB-INF/jsp/notfound.jsp</location>
</error-page>
<error-page>
    <error-code>403</error-code>
    <location>/WEB-INF/jsp/notauthorized.jsp</location>
</error-page>
<error-page>
    <exception-type>java.lang.Throwable</exception-type>
    <location>/WEB-INF/jsp/error.jsp</location>
</error-page>

<welcome-file-list>
    <welcome-file>/resources/index.html</welcome-file>
</welcome-file-list>

spring-mvc-dispatcher.xml:

<beans xmlns="http://www.springframework.org/schema/beans"   
xmlns:context="http://www.springframework.org/schema/context" 
xmlns:mvc="http://www.springframework.org/schema/mvc" 
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.xsd

http://www.springframework.org/schema/context 
http://www.springframework.org/schema/context/spring-context.xsd 

http://www.springframework.org/schema/mvc 
http://www.springframework.org/schema/mvc/spring-mvc.xsd">

<context:component-scan base-package="com.xxx" />

<mvc:resources location="/resources/" mapping="/resources/**"/>

<mvc:annotation-driven />

<!-- <bean class="org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping" /> -->

<bean id="xmlViewResolver"
    class="org.springframework.web.servlet.view.XmlViewResolver">
   <property name="location"><value>/WEB-INF/spring-mvc-views.xml</value>
   </property><property name="order" value="0" />
</bean>

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

<bean id="messageSource" 
    class="org.springframework.context.support.ResourceBundleMessageSource">
        <property name="basename" value="messages" />
</bean>

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <!-- set to 5 MB
    <property name="maxUploadSize" value="5242880"/>
    --> 
</bean>

<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping">
    <property name="useDefaultSuffixPattern" value="false" />
</bean>

<!-- Validator beans  -->
<bean id="deliveryDataStoreCreateValidator" class="com.xxx.validator.DeliveryDataStoreCreateValidator" />
<bean id="deliveryDataStoreUpdateValidator" class="com.xxx.validator.DeliveryDataStoreUpdateValidator" />
<bean id="deliveryDataStoreAccessUpdateValidator" class="com.xxx.validator.DeliveryDataStoreAccessUpdateValidator" />
<bean id="reportTemplateCreateValidator" class="com.xxx.validator.ReportTemplateCreateValidator" />
<bean id="reportTemplateUpdateValidator" class="com.xxx.validator.ReportTemplateUpdateValidator" />
<bean id="reportTemplateAccessUpdateValidator" class="com.xxx.validator.ReportTemplateAccessUpdateValidator" />
<bean id="dataProfileIdFileValidator" class="com.xxx.validator.DataProfileIdFileValidator" />
<bean id="dataProfileIdValidator" class="com.xxx.validator.DataProfileIdValidator" />
<bean id="dataProfileCreateValidator" class="com.xxx.validator.DataProfileCreateValidator" />
<bean id="dataProfileUpdateValidator" class="com.xxx.validator.DataProfileUpdateValidator" />
<bean id="dataProfileAccessUpdateValidator" class="com.xx.validator.DataProfileAccessUpdateValidator" />
<bean id="userCreateValidator" class="com.xxx.validator.UserCreateValidator" />
<bean id="userUpdateValidator" class="com.xxx.validator.UserUpdateValidator" />

spring-mvc-views.xml:

<bean id="pdfDeliveryNoteView" class="com.xxx.view.PDFDeliveryNoteBuilder">

4

0 に答える 0