javax.naming.NameNotFoundException:名称未绑定在此Context中.无法找到

den*_*ini 18 java orm jpa java-ee

我试图找出我的网络应用程序抛出的原因

javax.naming.NameNotFoundException: Name [flexeraDS] is not bound in this Context. Unable to find [flexeraDS].
Run Code Online (Sandbox Code Playgroud)

当我正在悄悄复制配置的姐妹悄悄运行时.

我有:

  1. 通过右键单击并选择"新持久性"从netbeans创建一个新的持久性,我不关心我给出的实际值,但我只需要在正确的目录中创建persistence.xml文件.
  2. 编辑了我的context.xml,如下所示匹配工作姐妹项目中的一个
  3. 编辑我的web.xml以包含资源DataSource,如下所示
  4. 编辑我的persistence.xml如下所示再次匹配姐妹项目工作中的相同值.
  5. 添加了我的lib文件夹中的其他项目中存在的所有库,并从NetBeans中添加它们以正确地置于战争中.

的context.xml

<?xml version="1.0" encoding="UTF-8"?>
<Context antiJARLocking="true" path="/PetLogin">
  <ResourceLink global="ds/flexeraDS" name="ds/flexeraDS" type="javax.sql.DataSource"/>
</Context>
Run Code Online (Sandbox Code Playgroud)

web.xml中

<?xml version="1.0" encoding="UTF-8"?>
<web-app ....>
<resource-ref>
        <description>DB Connection</description>
        <res-ref-name>ds/flexeraDS</res-ref-name>
        <res-type>javax.sql.DataSource</res-type>
        <res-auth>Container</res-auth>
    </resource-ref>
</web-app>
Run Code Online (Sandbox Code Playgroud)

persistence.xml中

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.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_1_0.xsd ">
    <persistence-unit name="flexerajpa">
        <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
        <non-jta-data-source>java:/comp/env/ds/flexeraDS</non-jta-data-source>
        <properties>

            <property name="eclipselink.ddl-generation" value="create-tables" />
            <property name="eclipselink.ddl-generation.output-mode"
                      value="database" />
            <property name="eclipselink.weaving" value="static" />
            <property name="eclipselink.logging.level" value="WARNING" />
        </properties>
    </persistence-unit>
</persistence>
Run Code Online (Sandbox Code Playgroud)

现在我的syster项目有些如何设法在启动时在apache-tomcat-7.0.40/bin/exampleDB中创建其数据库文件夹,而我的不创建它并如上所述抛出错误.

抛出错误的代码是我第一次连接到数据库时:

EntityManager entityManager = PersistenceProvider.createEntityManager();
Run Code Online (Sandbox Code Playgroud)

PersistenceProvider类的位置是:

public final class PersistenceProvider
{

    private static Map<String, Object> lOptions = new HashMap<String, Object>();

    static
    {
        lOptions.put(PersistenceUnitProperties.CACHE_SHARED_DEFAULT, "false");
    }
    private static EntityManagerFactory factory = Persistence
            .createEntityManagerFactory("flexerajpa", lOptions);

    private PersistenceProvider()
    {
    }

    /**
     * @return
     */
    public static EntityManager createEntityManager()
    {
        return factory.createEntityManager();
    }

    /**
     * @return
     */
    public static Metamodel getMetamodel()
    {
        return factory.getMetamodel();
    }
}
Run Code Online (Sandbox Code Playgroud)

我有可能的原因......如果有人有任何建议.谢谢

den*_*ini 12

好的发现必须配置Tomcat文件server.xml以使数据源正常工作.所以只需添加:

<Resource 
auth="Container" 
driverClassName="org.apache.derby.jdbc.EmbeddedDriver" 
maxActive="20" 
maxIdle="10" 
maxWait="-1" 
name="ds/flexeraDS" 
type="javax.sql.DataSource" 
url="jdbc:derby:flexeraDB;create=true" 
  />
Run Code Online (Sandbox Code Playgroud)

  • 我认为不建议将 &lt;Context&gt; 元素直接放置在 server.xml 文件中,如 Apache 文档中指定的那样? (2认同)

Rit*_*hik 5

你也可以添加

<Resource 
auth="Container" 
driverClassName="org.apache.derby.jdbc.EmbeddedDriver" 
maxActive="20" 
maxIdle="10" 
maxWait="-1" 
name="ds/flexeraDS" 
type="javax.sql.DataSource" 
url="jdbc:derby:flexeraDB;create=true" 
/> 
Run Code Online (Sandbox Code Playgroud)

META-INF/context.xml文件下(这将仅在应用程序级别).


小智 5

在 Tomcat 8.0.44 中,我这样做了:在 Tomcat 的 server.xml 标签“GlobalNamingResources”之间创建 JNDI 例如:

<GlobalNamingResources>
    <!-- Editable user database that can also be used by
         UserDatabaseRealm to authenticate users
    -->
  <!-- Other previus resouces -->
    <Resource auth="Container" driverClassName="org.postgresql.Driver" global="jdbc/your_jndi" 
    maxActive="100" maxIdle="20" maxWait="1000" minIdle="5" name="jdbc/your_jndi" password="your_password" 
    type="javax.sql.DataSource" url="jdbc:postgresql://localhost:5432/your_database?user=postgres" username="database_username"/>
  </GlobalNamingResources>
Run Code Online (Sandbox Code Playgroud)
在您的 Web 应用程序中,您需要该资源的链接 (ResourceLink):

项目探索

<?xml version="1.0" encoding="UTF-8"?>
<Context reloadable="true" >
		 <ResourceLink name="jdbc/your_jndi"
	 				global="jdbc/your_jndi"
	 				auth="Container"
	 				type="javax.sql.DataSource" />
</Context>
Run Code Online (Sandbox Code Playgroud)

因此,如果您将 Hiberte 与 spring 一起使用,您可以告诉他在 persistence.xml 中使用 JNDI

persistence.xml 位置

<?xml version="1.0" encoding="UTF-8"?>
<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"
	version="2.0" xmlns="http://java.sun.com/xml/ns/persistence">
	<persistence-unit name="UNIT_NAME" transaction-type="RESOURCE_LOCAL">
		<provider>org.hibernate.ejb.HibernatePersistence</provider>

		<properties>
			<property name="javax.persistence.jdbc.driver" 		value="org.postgresql.Driver" />
			<property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQL82Dialect" />
			
			<!--  <property name="hibernate.jdbc.time_zone" value="UTC"/>-->
			<property name="hibernate.hbm2ddl.auto" value="update" />
			<property name="hibernate.show_sql" value="false" />
			<property name="hibernate.format_sql" value="true"/>     
		</properties>
	</persistence-unit>
</persistence>
Run Code Online (Sandbox Code Playgroud)

所以在你的 spring.xml 中你可以这样做:

<bean id="postGresDataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
			<property name="jndiName" value="java:comp/env/jdbc/your_jndi" />
		</bean>
   		
        <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
              <property name="persistenceUnitName" value="UNIT_NAME" />
              <property name="dataSource" ref="postGresDataSource" />
              <property name="jpaVendorAdapter"> 
              	 	<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" />
              </property>
        </bean>
Run Code Online (Sandbox Code Playgroud)
上面的entityManagerFactory bean 引用了在持久性xml 中配置的UNIT_NAME,并且bean postGresDataSource 有一个属性指向Tomcat 中的JNDI 资源。

<property name="jndiName" value="java:comp/env/jdbc/your_jndi" />
Run Code Online (Sandbox Code Playgroud)

在此示例中,我将 spring 与 xml 结合使用,但如果您愿意,也可以通过编程方式执行此操作。

就是这样,希望有帮助。