2014-10-23 4 views
0

최대 절전 모드 초보자에게 Spring을 사용하고 있습니다. 단계별 자습서를 따라했으며 mysql이 작동하지만 Firebird로 변경하면 다음 오류가 발생합니다.Estado HTTP 500 ... 연결을 열 수 없습니다.

Estado HTTP 500 - 요청 처리에 실패했습니다. 중첩 예외는 org.springframework.transaction.CannotCreateTransactionException : 트랜잭션을 위해 Hibernate Session을 열 수 없습니다. 중첩 예외는 org.hibernate.exception.GenericJDBCException : 연결을 열 수 없습니다.

서버가 계정 데이터 데스크탑 프로그램이므로 로컬입니다. 누구든지 나를 도울 수 있습니까? (나는. 쓰기 클래스 (EmpresasDAO이 EmpresasDAOIMPL, EmpresasService, EmpresasServiceIMPL가) 아주 감사 작동하기 때문에 내 영어

미안하지는 않으나 나는 배우고 있습니다.

전체 오류

에스 타도의 HTTP 500 - 요청 처리에 실패; 중첩 된 예외는 org.springframework.transaction.CannotCreateTransactionException입니다 : 열 수 없습니다 최대 절전 모드 세션 거래, 상자의 예외가 org.hibernate.exception.GenericJDBCException입니다 : 열 수 없습니다 연결

type Informe de Excepción 

mensaje Request processing failed; nested exception is org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.exception.GenericJDBCException: Could not open connection 

descripción El servidor encontró un error interno que hizo que no pudiera rellenar este requerimiento. 

excepción 

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.exception.GenericJDBCException: Could not open connection 
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:948) 
    org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:827) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:621) 
    org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:812) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:728) 
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) 


causa raíz 

org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.exception.GenericJDBCException: Could not open connection 
    org.springframework.orm.hibernate4.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:514) 
    org.springframework.transaction.support.AbstractPlatformTransactionManager.getTransaction(AbstractPlatformTransactionManager.java:372) 
    org.springframework.transaction.interceptor.TransactionAspectSupport.createTransactionIfNecessary(TransactionAspectSupport.java:417) 
    org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:255) 
    org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:94) 
    org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) 
    org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204) 
    com.sun.proxy.$Proxy17.findAll(Unknown Source) 
    com.atorresbr.springapp.EmpresasController.list(EmpresasController.java:33) 
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    java.lang.reflect.Method.invoke(Method.java:606) 
    org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219) 
    org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132) 
    org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104) 
    org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:745) 
    org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:686) 
    org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80) 
    org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:925) 
    org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856) 
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:936) 
    org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:827) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:621) 
    org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:812) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:728) 
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) 


causa raíz 

org.hibernate.exception.GenericJDBCException: Could not open connection 
    org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:54) 
    org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:125) 
    org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:110) 
    org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.obtainConnection(LogicalConnectionImpl.java:221) 
    org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.getConnection(LogicalConnectionImpl.java:157) 
    org.hibernate.internal.SessionImpl.connection(SessionImpl.java:550) 
    org.springframework.orm.hibernate4.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:428) 
    org.springframework.transaction.support.AbstractPlatformTransactionManager.getTransaction(AbstractPlatformTransactionManager.java:372) 
    org.springframework.transaction.interceptor.TransactionAspectSupport.createTransactionIfNecessary(TransactionAspectSupport.java:417) 
    org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:255) 
    org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:94) 
    org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) 
    org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204) 
    com.sun.proxy.$Proxy17.findAll(Unknown Source) 
    com.atorresbr.springapp.EmpresasController.list(EmpresasController.java:33) 
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    java.lang.reflect.Method.invoke(Method.java:606) 
    org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219) 
    org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132) 
    org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104) 
    org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:745) 
    org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:686) 
    org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80) 
    org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:925) 
    org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856) 
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:936) 
    org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:827) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:621) 
    org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:812) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:728) 
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) 


causa raíz 

org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (GDS Exception. 335544569. Dynamic SQL Error 

SQL error code = -104 

Unexpected end of command - line 1, column 8) 
    org.apache.commons.dbcp.BasicDataSource.createPoolableConnectionFactory(BasicDataSource.java:1549) 
    org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1388) 
    org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:1044) 
    org.hibernate.service.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:141) 
    org.hibernate.internal.AbstractSessionImpl$NonContextualJdbcConnectionAccess.obtainConnection(AbstractSessionImpl.java:292) 
    org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.obtainConnection(LogicalConnectionImpl.java:214) 
    org.hibernate.engine.jdbc.internal.LogicalConnectionImpl.getConnection(LogicalConnectionImpl.java:157) 
    org.hibernate.internal.SessionImpl.connection(SessionImpl.java:550) 
    org.springframework.orm.hibernate4.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:428) 
    org.springframework.transaction.support.AbstractPlatformTransactionManager.getTransaction(AbstractPlatformTransactionManager.java:372) 
    org.springframework.transaction.interceptor.TransactionAspectSupport.createTransactionIfNecessary(TransactionAspectSupport.java:417) 
    org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:255) 
    org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:94) 
    org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) 
    org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204) 
    com.sun.proxy.$Proxy17.findAll(Unknown Source) 
    com.atorresbr.springapp.EmpresasController.list(EmpresasController.java:33) 
    sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    java.lang.reflect.Method.invoke(Method.java:606) 
    org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:219) 
    org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132) 
    org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104) 
    org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:745) 
    org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:686) 
    org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:80) 
    org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:925) 
    org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856) 
    org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:936) 
    org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:827) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:621) 
    org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:812) 
    javax.servlet.http.HttpServlet.service(HttpServlet.java:728) 
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51) 

앱 config.xml에

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

    <!-- Scans the classpath of this application for @Components @Service @Repository to deploy as 
     beans --> 
    <context:component-scan base-package="com.atorresbr.springapp" /> 

    <!-- Configures the @Controller programming model --> 
    <mvc:annotation-driven /> 

     <!-- Map simple view name such as "test" into /WEB-INF/test.jsp --> 
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
    <property name="prefix" value="/WEB-INF/" /> 
    <property name="suffix" value=".jsp" /> 
    </bean> 

    <bean id="propertyConfigurer" 
     class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer" 
     p:location="/WEB-INF/jdbc.properties" /> 

    <!-- JDBC Data Source. It is assumed you have MySQL running on localhost port 3306 with 
     username root and blank password. Change below if it's not the case --> 

     <bean id="myDataSource" 
     class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close" 
     p:driverClassName="${jdbc.driverClassName}" 
     p:url="${jdbc.databaseurl}" 
     p:username="${jdbc.username}" 
     p:password="${jdbc.password}" 
     p:validationQuery="${jdbc.validationQuery}" /> 
<!--  
    <bean id="myDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> 
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/> 
    <property name="url" value="jdbc:mysql://localhost:3306/pizzashop"/> 
    <property name="username" value="root"/> 
    <property name="password" value=""/> 
    <property name="validationQuery" value="SELECT 1"/> 
    </bean> --> 

    <!-- Hibernate Session Factory --> 
    <bean id="mySessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> 
    <property name="dataSource" ref="myDataSource"/> 
    <property name="packagesToScan"> 
     <array> 
     <value>com.atorresbr.springapp</value> 
     </array> 
    </property> 
    <property name="hibernateProperties"> 
    <props> 
       <prop key="hibernate.dialect">${jdbc.dialect}</prop> 
       <prop key="hibernate.show_sql">true</prop> 
      </props> 

    </property> 
    </bean> 

    <!-- Hibernate Transaction Manager --> 
    <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager"> 
    <property name="sessionFactory" ref="mySessionFactory"/> 
    </bean> 

    <!-- Activates annotation based transaction management --> 
    <tx:annotation-driven transaction-manager="transactionManager"/> 
</beans> 

jdbc.propierties

jdbc.driverClassName= org.firebirdsql.jdbc.FBDriver 
jdbc.dialect=org.hibernate.dialect.FirebirdDialect 
jdbc.databaseurl=jdbc:firebirdsql:PROSYTH-PC/3050:C:/aplifisa/contcs/CONTBD 
jdbc.username=SYSDBA 
jdbc.password=masterkey 
jdbc.validationQuery=SELECT 1 

package com.atorresbr.springapp; 
// imports .. 
import javax.persistence.Entity; 
import javax.persistence.GeneratedValue; 
import javax.persistence.Id; 
import javax.persistence.Table; 

import java.sql.Blob; 
import java.util.Date; 

@Entity 
@Table(name = "empresas") 
public class Empresas { 

@Id @GeneratedValue private long CLAVE; 
private String NOMBRE; 
private String DNICIF; 
private String SIGLA; 
private String VIAPUBLICA; 
private String NUMERO; 
private String PISO; 
private String PUERTA; 
private String MUNICIPIO; 
private String CODPOSTAL; 
private String PROVINCIA; 
private String TELEFONO; 
private String FAX; 
private String ADMON; 
private long NIVEL; 
private String EJERCICIO; 
private Date FECHAINI; 
private Date FECHAFIN; 
private String PAG_ASIEN; 
private String COBROS; 
private String OCUPADO; 
private String CONTRASE; 
private String ACT_CONTRASE; 
private String BALANCE; 
private String COOPERA; 
private String WEB; 
private String CORREO; 
private String IGIC_IVA; 
private String OBSERVACIONES; 
private String CONTACTO; 
private String TELEFONO_CONT; 
private String CODPAIS; 
private String TIPO_EMP; 
private String BALANCE_UE; 
private String E_RETEN; 
private Date FECHA_BAJA; 
private String GES_PROYECTOS; 
private String TOMO_R; 
private String LIBRO_R; 
private String SECCION_R; 
private String FOLIO_R; 
private String TIPO_R; 
private String HOJA_R; 
private String OTROS_R; 
private String REGMER; 
private Blob SUB_TYPE; 
private String ILOGO; 
private String INUMERO; 
private String WEBCONTACTO; 
private String MOVILCONTACTO; 
private String REGVENTAS; 
private String REGCOMPRAS; 
private String SUBC_DESP1; 
private String SUBC_DESP2; 
private String SUBC_DESP3; 
private String SUBC_DESP4; 
private String SUBC_DESPI1; 
private String SUBC_DESPI2; 
private String SUBC_DESPI3; 
private String SUBC_DESPI4; 
private String SUBC_DESPI5; 
private String SUBC_DESPI6; 
private String SUBC_DESPC1; 
private String SUBC_DESP7; 
private String GES_DOCU; 
private String CRITERIOCAJA; 
private String DOC3W_REFURL; 
private String DOC3W_AUTOGESTION; 
    /* getters & setters */ 

    public long getCLAVE() { 
    return CLAVE; 
} 
public void setCLAVE(long CLAVE) { 
    this.CLAVE = CLAVE; 
} 
public String getNOMBRE() { 
    return NOMBRE; 
} 
public void setNOMBRE(String NOMBRE) { 
    this.NOMBRE = NOMBRE; 
} 
. 
. 
. 
Empresas.java 0

기타 등등 // setters.

+0

예외 다, 당신은 데이터베이스에 대한 연결을 설정할 수 없습니다 말했다. 데이터베이스 서버가 실행 중이고 올바른 URL로 연결되어 있는지 확인하십시오. – Tobb

+0

저는 sqlexplorer이고 테이블과 날짜를 볼 수 있습니다. 드라이버 Firebird, URL jdbc : firebirdsql : PROSYTH-PC/3050 : C :/aplifisa/contcs/CONTBD, 사용자 SYSDBA, 암호 마스터 키 – ProSyth

+0

@tobb 연결 식별자가 실제로 작동하는지, 문제는 유효성 확인 쿼리입니다. 내 대답 참조 –

답변

1

유효성 확인 쿼리가 유효하지 않습니다 : 파이어 버드는 항상 선택에서 from 절을 요구합니다. 에

변경을 :

Select 1 from rdb$database 
+0

Thx, 지금 나는 다른 오류가 있지만 이것은 해결책이다 :) – ProSyth

+0

내가 봄 + 최대 절전 모드 + 파이어 버드, thx에 대한 더 많은 정보를 찾을 수있는 곳은? – ProSyth

관련 문제