2012-12-14 8 views
6

In meiner Anwendung verwende ich das Hibernate-Core-4.1.8 jar und möchte ein ehCache als 2nd-Level-Cache nehmen. Das Glas, das ich derzeit verwende, ist ehcache-core-2.5.0. Ich habe es in meinen Ordner WebContetn/WEB-INF/lib gestellt und es auch in den Klassenpfad eingefügt.ehcache hibernate 4

Mein hibernate.cfg.xml sieht wie folgt aus:

<hibernate-configuration> 
    <session-factory> 
    ....  
     <property name="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</property> 
     <property name="hibernate.cache.use_second_level_cache">true</property> 
     <property name="hibernate.cache.use_query_cache">true</property> 
    </session-factory> 
</hibernate-configuration> 

die ehcache.xml die im JavaResources/src-Ordner abgelegt wird:

<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
     xsi:noNamespaceSchemaLocation="ehcache.xsd" updateCheck="true" 
     monitoring="autodetect" dynamicConfig="true"> 

    <defaultCache 
       maxElementsInMemory="100000" 
       eternal="false" 
       timeToIdleSeconds="1000" 
       timeToLiveSeconds="1000" 
       overflowToDisk="false" 
       /> 
</ehcache> 

Wenn meine Anwendung die Klasse org läuft. hibernate.cache.ehcache.EhCacheRegionFactory nicht gefunden wird:

java.lang.ClassNotFoundException: Could not load requested class : org.hibernate.cache.ehcache.EhCacheRegionFactory 
    at org.hibernate.service.classloading.internal.ClassLoaderServiceImpl$1.findClass(ClassLoaderServiceImpl.java:99) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:423) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:356) 
    at java.lang.Class.forName0(Native Method) 
    at java.lang.Class.forName(Class.java:264) 
    at org.hibernate.service.classloading.internal.ClassLoaderServiceImpl.classForName(ClassLoaderServiceImpl.java:138) 
    at org.hibernate.cfg.SettingsFactory.createRegionFactory(SettingsFactory.java:444) 
    at org.hibernate.cfg.SettingsFactory.buildSettings(SettingsFactory.java:275) 
    at org.hibernate.cfg.Configuration.buildSettingsInternal(Configuration.java:2283) 
    at org.hibernate.cfg.Configuration.buildSettings(Configuration.java:2279) 
    at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1748) 
    at creator.controllers.MyFactory.<clinit>(MyFactory.java:18) 
    at creator.controllers.SchoolDAO.getList(SchoolDAO.java:98) 
    ..... 

Antwort

7

Sieaufnehmen müssenvon downloading it oder Sie verwenden Maven stecken es in die Abhängigkeiten wie diese

<dependency> 
<artifactId>hibernate-ehcache</artifactId> 
<groupId>org.hibernate</groupId> 
<version>4.0.0.CR6</version> 
</dependency> 
+1

nach dem Hinzufügen Ihr Glas sowie die Feinarbeiten slf4-api-1.7.2 scheint es (von http zu verlangen: // www.slf4j.org/download.html) zum Projekt :) danke! – chris

+0

+1 Stimme für die Lösung meines Problems auch. –

+0

jetzt funktioniert es auch für mich –