Erro na hora de persistir Webservice JAX-RS

Olá, estou tendo um problema na hora de configurar a persistência, bem oque ocorre é que quando vou realizar a persistência sempre acontece um erro, bom já usei o Tomcat, WildFly, Glassfish e todos dão um erro acredito que seja meu código porém não sei onde seja. Enfim vou enviar para poderem dar uma olhada.

*Obs: Quando eu realizo a persistência por Java Applicantion é persistido…

O persistence.xml que está src\main\resources\META-INF:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"
	xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
	<persistence-unit name="testedb-persistence" transaction-type="RESOURCE_LOCAL">
		<provider>org.hibernate.ejb.HibernatePersistence</provider>

		<class>br.com.teste.models.Product</class>

		<properties>
			<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5InnoDBDialect" />
			<property name="hibernate.show_sql" value="true" />
			<property name="hibernate.format_sql" value="true" />
			<property name="hibernate.cache.provider_class" value="org.hibernate.cache.NoCacheProvider" />
			<property name="hibernate.hbm2ddl.auto" value="update"/> 
			<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
			<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/testedb" />
			<property name="javax.persistence.jdbc.user" value="root" />
			<property name="javax.persistence.jdbc.password" value="root" />
		</properties>
	</persistence-unit>
</persistence>'

A Factory do EntityManager

public class EMFactory {
	private EntityManagerFactory emf;

	private EntityManager fabrica() {
		if (emf == null) {
			emf = Persistence.createEntityManagerFactory("testedb-persistence");
		}
		return emf.createEntityManager();
	}

	public EntityManager getEntityManager() {
		return fabrica();
	}
}

O dao:

public class ProductDAO {
	EntityManager em =  new EMFactory().getEntityManager();
	
	public Product product(){
		return new Product("Produto");
	}
	
	
	public String adicionar(){
		this.em.getTransaction().begin();
		this.em.merge(this.product());
		this.em.getTransaction().commit();		
		this.em.close();
		return "Ok.";
	}
}

E o serviço:

@Path("/teste")
public class ProductResource
{

   @Path("persistir")
   @GET
   public String persistir()
   {
      return new ProductDAO().adicionar();
   }
}

E este é o erro que recebo quando acesso a url : http://localhost:8080/teste/teste/persistir

2017-06-28T10:30:29.426-0300|Advertência: StandardWrapperValve[br.com.teste.resources.ApplicationConf]: Servlet.service() for servlet br.com.teste.resources.ApplicationConf threw exception
javax.persistence.PersistenceException: No Persistence provider for EntityManager named testedb-persistence
	at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:85)
	at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:54)
	at br.com.teste.factory.EMFactory.fabrica(EMFactory.java:12)
	at br.com.teste.factory.EMFactory.getEntityManager(EMFactory.java:22)
	at br.com.teste.dao.ProductDAO.<init>(ProductDAO.java:9)
	at br.com.teste.resources.ProductResource.nada(ProductResource.java:47)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.glassfish.jersey.server.model.internal.ResourceMethodInvocationHandlerFactory$1.invoke(ResourceMethodInvocationHandlerFactory.java:81)
	at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.invoke(AbstractJavaResourceMethodDispatcher.java:125)
	at org.glassfish.jersey.server.model.internal.JavaResourceMethodDispatcherProvider$TypeOutInvoker.doDispatch(JavaResourceMethodDispatcherProvider.java:195)
	at org.glassfish.jersey.server.model.internal.AbstractJavaResourceMethodDispatcher.dispatch(AbstractJavaResourceMethodDispatcher.java:91)
	at org.glassfish.jersey.server.model.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:346)
	at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:341)
	at org.glassfish.jersey.server.model.ResourceMethodInvoker.apply(ResourceMethodInvoker.java:101)
	at org.glassfish.jersey.server.ServerRuntime$1.run(ServerRuntime.java:224)
	at org.glassfish.jersey.internal.Errors$1.call(Errors.java:271)
	at org.glassfish.jersey.internal.Errors$1.call(Errors.java:267)
	at org.glassfish.jersey.internal.Errors.process(Errors.java:315)
	at org.glassfish.jersey.internal.Errors.process(Errors.java:297)
	at org.glassfish.jersey.internal.Errors.process(Errors.java:267)
	at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:317)
	at org.glassfish.jersey.server.ServerRuntime.process(ServerRuntime.java:198)
	at org.glassfish.jersey.server.ApplicationHandler.handle(ApplicationHandler.java:946)
	at org.glassfish.jersey.servlet.WebComponent.service(WebComponent.java:323)
	at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:372)
	at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:335)
	at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:218)
	at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1682)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:318)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:160)
	at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:734)
	at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:673)
	at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:99)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:174)
	at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:357)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:260)
	at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:188)
	at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:191)
	at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:168)
	at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:189)
	at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)
	at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:288)
	at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:206)
	at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:136)
	at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:114)
	at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
	at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:838)
	at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:113)
	at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:115)
	at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:55)
	at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:135)
	at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:564)
	at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:544)
	at java.lang.Thread.run(Thread.java:745)

Estou usando o Glassfish 4.0;

<provider>org.hibernate.ejb.HibernatePersistence</provider>

Essa classe está deprecated. Use isso:

<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>

Se você tá usando o GlassFish, o provider que tem no classpath é o TopLink por default. Tá colocando o jar do Hibernate dentro do war?

2 curtidas

Se não me engano ficou deprecated a partir da versão 5.2.x.

2 curtidas

Bom pessoal obrigado pela ajuda, mas depois de muito fuçar, descobri que tem que colocar o seguinte código dentro do .classpath:

<classpathentry kind="con" path="org.maven.ide.eclipse.MAVEN2_CLASSPATH_CONTAINER">
<attributes>
    <attribute name="org.eclipse.jst.component.dependency" value="/WEB-INF/lib"/>
</attributes>
</classpathentry>

Bem eu não entendi o porque se puderem me ajudar a entender vou ficar muito grato :slight_smile:

Cara, essa é nova pra mim. Nunca precisei acrescentar nada no classpath pra trabalhar com hibernate.
Das vezes que tive essa exception que postou, a sugestão do @lvbarbosa resolveu.

Então, eu estou começando agora, e tipo criei o projeto maven, mas não sei oque deu de errado que o deploy estava indo sem os jar’s então encontrei isto e foi oque resolveu.

Como estava declarando suas dependências???
Por acaso declarou <scope>provided</scope>?

Não coloquei, aqui está meu pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
  <groupId>br.com</groupId>
  <artifactId>teste</artifactId>
  <version>1.0.0-SNAPSHOT</version>
  <packaging>war</packaging>
  <properties>
    <maven.compiler.source>1.8</maven.compiler.source>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.target>1.8</maven.compiler.target>
  </properties>
  <dependencyManagement />
  <dependencies>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.35</version>
    </dependency>
    <dependency>
      <groupId>javax</groupId>
      <artifactId>javaee-api</artifactId>
      <version>7.0</version>
      <scope>provided</scope>
    </dependency>
    <dependency>
   		<groupId>org.hibernate</groupId>
   		<artifactId>hibernate-core</artifactId>
   		<version>5.1.0.Final</version>
	</dependency> 
	<dependency>
		<groupId>org.hibernate</groupId>
		<artifactId>hibernate-entitymanager</artifactId>
		<version>5.1.0.Final</version>
	</dependency>
  </dependencies>
  <build>
    <plugins>
      <plugin>
        <artifactId>maven-war-plugin</artifactId>
        <version>2.4</version>
        <configuration>
          <failOnMissingWebXml>false</failOnMissingWebXml>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>
  1. substitua

    org.hibernate hibernate-core 5.1.0.Final

por

<dependency>
   		<groupId>org.hibernate</groupId>
   		<artifactId>hibernate-core</artifactId>
   		<version>5.2.10.Final</version>
	</dependency> 
  1. remova do seu pom.xml

    org.hibernate hibernate-entitymanager 5.1.0.Final
  2. remova tb a instrução do classpath que vc colocou.
    Certifique-se de usar o provider que o @lvbarbosa indicou.

com estas alterações, tudo deve funcionar normalmente e sem alteração do classpath.

1 curtida

Então amigo, fiz exatamente oque falou, porém sem a alteração no .claspath o erro continua devido os .jar não estarem no deploy no servidor.

Vc está usando qual servidor? Muito estranho :frowning:
Tenta forçar o empacotamento dos JARs

<dependency>
	<groupId>org.hibernate</groupId>
	<artifactId>hibernate-core</artifactId>
	<version>5.2.10.Final</version>
	<scope>compile</scope>
</dependency>

Em seguida, executa um

mvn clean install

Abra o artefato war gerado com um WinRAR da vida, navegue até a pasta WEB-INF/lib e confirma se os jars do hibernate estão lá. Se estiverem, faz o deploy pra testar.

Eu ja fiz isso :(, e tipo continuou o erro, tanto no Glassfish como no Wildfly, Quer que eu te envie o projeto para dar uma olhada?

Sim, por favor!

testando.rar (16,5 KB)

Vou olhar e já te falo

Rodou sem problemas aqui num JB Wildfly 8 Final.