[Resolvido]Gerar arquivo .jar no Eclipse com o Maven, aplicação faz conexão com o MySql

9 respostas Resolvido
javafx
T

Boa tarde galera,

Estou com a seguinte duvida, ao gerar o arquivo .jar, tenho uma aplicação feita usando o Maven que faz conexão com o banco de dados MySql e estou usando o Eclipse, até consigo gerar o arquivo .jar, mas quando executo ele simplesmente trava na tela de login, parece que não conecta no banco, para gerar o arquivo .jar estou fazendo da seguinte maneira:

Clico com o botão direito em cima do meu projeto > Run As > Maven Install

meu arquivo pom.xlm esta da seguinte maneira:

<project xmlns="http://maven.apache.org/POM/4.0.0" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>Projeto</groupId>
  <artifactId>Relatorio_Visitas</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>Relatorio_Visitas</name>
  <url>http://maven.apache.org</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
    <dependency>
	    <groupId>mysql</groupId>
	    <artifactId>mysql-connector-java</artifactId>
	    <version>8.0.11</version>
    </dependency>
  </dependencies>
  <build>
    	<plugins>
	    	<plugin>
		    	<groupId>org.apache.maven.plugins</groupId>
			    <artifactId>maven-jar-plugin</artifactId>
			    <version>3.1.0</version>
			    <configuration>
				<archive>
					<manifest>
						<mainClass>Relatorio_Visitas.Main</mainClass>
					</manifest>
				</archive>
			</configuration>
		</plugin>
	</plugins>
</build>

Desde já agradeço.

9 Respostas

darlan_machado

Deixa eu adivinhar: não existe log no projeto.
Você está executando com duplo clique?
Tenta executar pelo prompt/terminal e vê quais mensagens de erro aparecem.

T

Deu a seguinte mensagem de erro:

Exception in thread JavaFX Application Thread java.lang.RuntimeException: java

.lang.reflect.InvocationTargetException

at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1774)

at javafx.fxml.FXMLLoader$ControllerMethodEventHandler.handle(FXMLLoader

.java:1657)

at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(Comp

ositeEventHandler.java:86)

at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventH

andlerManager.java:238)

at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventH

andlerManager.java:191)

at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(C

ompositeEventDispatcher.java:59)

at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDis

patcher.java:58)

at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispat

chChainImpl.java:114)

at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDis

patcher.java:56)

at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispat

chChainImpl.java:114)

at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDis

patcher.java:56)

at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispat

chChainImpl.java:114)

at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)

at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:49)

at javafx.event.Event.fireEvent(Event.java:198)

at javafx.scene.Node.fireEvent(Node.java:8411)

at javafx.scene.control.Button.fire(Button.java:185)

at com.sun.javafx.scene.control.behavior.ButtonBehavior.mouseReleased(Bu

ttonBehavior.java:182)

at com.sun.javafx.scene.control.skin.BehaviorSkinBase$1.handle(BehaviorS

kinBase.java:96)

at com.sun.javafx.scene.control.skin.BehaviorSkinBase$1.handle(BehaviorS

kinBase.java:89)

at com.sun.javafx.event.CompositeEventHandler$NormalEventHandlerRecord.h

andleBubblingEvent(CompositeEventHandler.java:218)

at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(Comp

ositeEventHandler.java:80)

at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventH

andlerManager.java:238)

at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventH

andlerManager.java:191)

at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(C

ompositeEventDispatcher.java:59)

at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDis

patcher.java:58)

at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispat

chChainImpl.java:114)

at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDis

patcher.java:56)

at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispat

chChainImpl.java:114)

at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDis

patcher.java:56)

at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispat

chChainImpl.java:114)

at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)

at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54)

at javafx.event.Event.fireEvent(Event.java:198)

at javafx.scene.Scene$MouseHandler.process(Scene.java:3757)

at javafx.scene.Scene$MouseHandler.access$1500(Scene.java:3485)

at javafx.scene.Scene.impl_processMouseEvent(Scene.java:1762)

at javafx.scene.Scene$ScenePeerListener.mouseEvent(Scene.java:2494)

at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotificatio

n.run(GlassViewEventHandler.java:394)

at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotificatio

n.run(GlassViewEventHandler.java:295)

at java.security.AccessController.doPrivileged(Native Method)

at com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda$handleMouseEve

nt$353(GlassViewEventHandler.java:432)

at com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(Quantum

Toolkit.java:389)

at com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(Glas

sViewEventHandler.java:431)

at com.sun.glass.ui.View.handleMouseEvent(View.java:555)

at com.sun.glass.ui.View.notifyMouse(View.java:937)

at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)

at com.sun.glass.ui.win.WinApplication.lambda$null$147(WinApplication.ja

va:177)

at java.lang.Thread.run(Unknown Source)

Caused by: java.lang.reflect.InvocationTargetException

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 sun.reflect.misc.Trampoline.invoke(Unknown Source)

at sun.reflect.GeneratedMethodAccessor1.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at sun.reflect.misc.MethodUtil.invoke(Unknown Source)

at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1769)

 48 more

Caused by: java.lang.ExceptionInInitializerError

at br.coop.sicoobcredicenm.dao.db.ConexaoBD.openConnection(ConexaoBD.jav

a:28)

at br.coop.sicoobcredicenm.controllers.ControllerSenha.logar(ControllerS

enha.java:49)

 58 more

Caused by: java.nio.file.FileSystemNotFoundException

at com.sun.nio.zipfs.ZipFileSystemProvider.getFileSystem(ZipFileSystemPr

ovider.java:171)

at com.sun.nio.zipfs.ZipFileSystemProvider.getPath(ZipFileSystemProvider

.java:157)

at java.nio.file.Paths.get(Unknown Source)

at br.coop.sicoobcredicenm.dao1.DAOProperties.(DAOProperties.jav

a:22)

 60 more
darlan_machado

Fundamental analisar estas classes e as linhas apresentadas nelas.
Creio que seja algo com a conexão ao banco de dados. Parece-me que algo com um arquivo não encontrado ou algo assim.

T

Quando executo direto pelo Eclipse, roda normalmente, somente quando tento gerar o arquivo .jar e executo que da esse erro, será que a forma de gerar o arquivo .jar esta correta?

Obrigado pela atenção

darlan_machado

Veja, normalmente o primeiro “Caused by” nos dá a principal razão do problema.
Eu não sei nada do teu projeto, mas, pela mensagem, parece que você lê alguma coisa para fazer a conexão com o banco de dados e isso não está ocorrendo. Será que é um arquivo de propriedades ou o driver do MySQL?

T

Correto, eu utilizo um arquivo txt, que contem os dados para conexão, vou tentar fazer a conexão direta, sem o arquivo para ver se vai funcionar, o que acha?

darlan_machado
Solucao aceita

Eu tentaria averiguar a questão do caminho do arquivo, parece que o jar não consegue encontrar o mesmo.

T

Alterei os plugins do meu arquivo pom.xml para:

<plugins>
<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.7.0</version>
    <configuration>
        <source>${jdkVersion}</source>
        <target>${jdkVersion}</target>
    </configuration>
</plugin>
<plugin>
    <artifactId>maven-assembly-plugin</artifactId>
    <configuration>
        <archive>
            <manifest>
                <mainClass>Relatorio_Visitas.Main</mainClass>
            </manifest>
        </archive>
        <descriptorRefs>
            <descriptorRef>jar-with-dependencies</descriptorRef>
        </descriptorRefs>
    </configuration>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>single</goal>
            </goals>
        </execution>
    </executions>
</plugin>

E mudei o tipo de conexão, para fazer direta, funcionou.

Muito obrigado pela atenção.

T

Você poderia me ajudar nesse tópico por favor, até agora não encontrei uma solução:

JavaFX - TableView trazer data, do banco de dados mysql

Desde já agradeço.

Criado 13 de setembro de 2018
Ultima resposta 14 de set. de 2018
Respostas 9
Participantes 2