2017-02-28 21 views
0

マイDaoClasshibernatetemplate.getSessionFactoryは、()はNullPointerException

@Repository("genObj") 
public class GeneralQueries { 
    HibernateTemplate hibernatetemplate; 
    public HibernateTemplate getHibernatetemplate() { 
     return hibernatetemplate; 
    } 
    public void setHibernatetemplate(HibernateTemplate hibernatetemplate) { 
     this.hibernatetemplate = hibernatetemplate; 
    } 
    public String getStringfromQuery(String sql) 
{ 
    SessionFactory sessionFactory=hibernatetemplate.getSessionFactory(); 
    Session session=sessionFactory.openSession(); 

    String data=null; 
    try 
    { 
     System.out.println(sql); 
     data=session.createSQLQuery(sql).list().toString(); 
    } 
    catch (Exception e) 
    { 
     e.printStackTrace(); 
    } 

    return data; 
}} 

をスローこのメソッドは、データを文字列として返します

私のコントローラクラス

genObj.getStringfromQuery()メソッドを呼び出そうと
@Controller 
public class SchoolStudentsConfirmationContrl 
{ 
    @Autowired 
    SchoolStudentsConfirmationIntr schoolstdconfirmservice; 
    @Autowired 
    GeneralQueries genObj=new GeneralQueries(); 

    @RequestMapping(value="/getData",method=RequestMethod.GET) 
    public ModelAndView getData(@ModelAttribute("schooldetailsform")SchoolDetailsForm formbean,HttpServletRequest request) 
    { 
     String PageHeading = ""; 


     try 
     { 
     String district = request.getSession().getAttribute("dist_code").toString(); 

     PageHeading = "BAS Students Confirmation for the Academic Year:"+ formbean.getAc_year() + " <br> District:" 
        + genObj.getStringfromQuery("select dist_name from pmss_districts_mst where dist_code=" + district + "")+""; 

     mav.setViewName("showreportwithmenu"); 

     } 
     catch(Exception e) 
     { 
      e.printStackTrace(); 
     } 
     return mav; 
    } 
} 

イムそれは私にnullポインタ例外をスローする SessionFactory sessionFactory = hibernatetemplate.getSessionFactory();

私の設定ファイルが

<?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:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context" 
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
     http://www.springframework.org/schema/beans/spring-beans-3.2.xsd 
     http://www.springframework.org/schema/mvc 
     http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd 
     http://www.springframework.org/schema/tx 
     http://www.springframework.org/schema/tx/spring-tx-3.2.xsd 
     http://www.springframework.org/schema/context 
     http://www.springframework.org/schema/context/spring-context-3.2.xsd"> 

    <context:annotation-config /> 
    <context:component-scan base-package="cgg.gov.in.*" annotation-config="true"/> 


    <bean id="tiles" class="org.springframework.web.servlet.view.UrlBasedViewResolver"> 
     <property name="viewClass"> 
      <value> 
       org.springframework.web.servlet.view.tiles3.TilesView 
      </value> 
     </property> 
    </bean> 

    <bean id="tilesConfigurer" class="org.springframework.web.servlet.view.tiles3.TilesConfigurer"> 
     <property name="definitions"> 
      <list> 
       <value>/WEB-INF/tiles.xml</value> 
      </list> 
     </property> 
    </bean> 

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

    <bean name="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
     <property name="driverClassName" value="org.postgresql.Driver" /> 
     <property name="url" value="jdbc:postgresql://x.x.x.x/test" /> 
     <property name="username" value="postgres" /> 
     <property name="password" value="postgres" /> 
    </bean> 

    <bean class="org.springframework.orm.hibernate4.LocalSessionFactoryBean" name="sessionFactory"> 
     <property name="dataSource" ref="dataSource" /> 
     <property name="hibernateProperties"> 
      <props> 
       <prop key="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</prop> 
       <prop key="hibernate.show_sql">false</prop> 
       <prop key="hibernate.hbm2ddl.auto">update</prop> 
       <prop key="hibernate.autocommit">false</prop> 
      </props> 
     </property> 
     <property name="annotatedClasses" > 
      <list> 
       <value>cgg.gov.in.model.login.LoginForm</value> 
      </list> 
     </property> 
    </bean> 

     <bean class="org.springframework.orm.hibernate4.HibernateTemplate" name="hibernatetemplate"> 
     <property name="sessionFactory" ref="sessionFactory"/> 
     </bean> 

    <mvc:default-servlet-handler /> 
    <mvc:annotation-driven /> 

</beans> 
+1

あなたは 'new GeneralQueries()'を実行しています。これは、基本的に自動配線が動作しないようにするために、スプリングマネージインスタンスを使用します。その次に、あなたのDAOの 'HIbernateTemplate'フィールドに' @ Autowired'がありません。また、あなたのコードには欠陥があります。あなたが奇妙な問題に遭遇しない限り、 'openSession'を使用しないでください。' openSession'は新しいセッションを開き、必要に応じて 'Connection'を開きます。リークとメモリリークが始まる)。 –

+2

また、 'Session'と' SessionFactory'を使って作業しているので、私は 'HibernateTemplate'の使用を止め、' SessionFactory'を直接注入することを提案します。 –

答えて

0

あなたはhibernatetemplate Beanが定義されています。しかし、GeneralQueriesクラスの変数hibernatetemplateが定義されたbeanを指すように指示していません。次の2つの方法でこれを行うことができます

1)

XMLで GeneralQueriesためのBeanを作成し、以下のようにプロパティを定義し、

<bean name="generalQueries" class="package.GeneralQueries"> 
    <property name="hibernatetemplate" ref="hibernatetemplate" /> 
</bean> 

はすでにセッターを定義しています。 @RepositoryGeneralQueriesから削除することを忘れないでください。xmlのBeanとして定義する場合はです。

2)hibernatetemplateGeneralQueriesに以下のように入力します。

@Repository("genObj") 
public class GeneralQueries { 
    @Autowired 
    HibernateTemplate hibernatetemplate; 
    //rest of code 
} 

GeneralQueriesは、コンポーネントスキャンの対象でなければなりません。

注:また、@ m-deinumは、new GeneralQueries()SchoolStudentsConfirmationContrlから削除することを推奨します。

関連する問題