2

EJB を定義しましたが、それを別の war から使用しようとしています:

ejb-api.jar

@Remote
public interface Example {
    // ...
}

ejb-impl.war(を使用ejb-api.jar):

@Stateless(mappedName = "ExampleEjb")
public class ExampleBean implements Example {
    // ...
}

ejb-user.war(を使用ejb-api.jar):

@WebServlet("/ejbuser")
public class UserServlet extends HttpServlet {

    @Override
    public void doGet(...) throws Exception {
        Example example = null;
        try {
            InitialContext context = new InitialContext();
            example = (Example)context.lookup("ExampleEjb");
        } catch (NamingException e) {
            e.printStackTrace();
        }
    }
}

JBoss AS 7.1 のインスタンスにデプロイしましたejb-impl.warejb-user.warすべてのクラスを同じ war ファイルに入れると、EJB が見つかります。しかし、この方法ではそうではありません (私は を取得しますNamingException)。

jndi.propertiesさらに、これらの内容のファイルを追加すると...

java.naming.factory.initial = org.jboss.naming.remote.client.InitialContextFactory
java.naming.provider.url = remote://localhost:4447
jboss.naming.client.ejb.context = true
java.naming.factory.url.pkgs = org.jboss.ejb.client.naming

...次に、この種の警告が表示されます。

16:55:46,268 WARNING [javax.enterprise.resource.webcontainer.jsf.config] (MSC service thread 1-7) javax.naming.NamingException: JBAS011843: Failed instantiate InitialContextFactory org.jnp.interfaces.NamingContextFactory from classloader ModuleClassLoader for Module "deployment.example.war:main" from Service Module Loader: javax.naming.NamingException: JBAS011843: Failed instantiate InitialContextFactory org.jnp.interfaces.NamingContextFactory from classloader ModuleClassLoader for Module "deployment.example.war:main" from Service Module Loader
    at org.jboss.as.naming.InitialContextFactoryBuilder.createInitialContextFactory(InitialContextFactoryBuilder.java:64)
    at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:681) [rt.jar:1.7.0_03]
    at javax.naming.InitialContext.getDefaultInitCtx(InitialContext.java:307) [rt.jar:1.7.0_03]
    at javax.naming.InitialContext.init(InitialContext.java:242) [rt.jar:1.7.0_03]
    at javax.naming.InitialContext.<init>(InitialContext.java:192) [rt.jar:1.7.0_03]
    at com.sun.faces.config.WebConfiguration.processJndiEntries(WebConfiguration.java:687) [jsf-impl-2.1.7-jbossorg-2.jar:]
    at com.sun.faces.config.WebConfiguration.<init>(WebConfiguration.java:134) [jsf-impl-2.1.7-jbossorg-2.jar:]
    at com.sun.faces.config.WebConfiguration.getInstance(WebConfiguration.java:194) [jsf-impl-2.1.7-jbossorg-2.jar:]
    at com.sun.faces.config.ConfigureListener.contextInitialized(ConfigureListener.java:163) [jsf-impl-2.1.7-jbossorg-2.jar:]
    at org.apache.catalina.core.StandardContext.contextListenerStart(StandardContext.java:3392) [jbossweb-7.0.13.Final.jar:]
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:3850) [jbossweb-7.0.13.Final.jar:]
    at org.jboss.as.web.deployment.WebDeploymentService.start(WebDeploymentService.java:90) [jboss-as-web-7.1.1.Final.jar:7.1.1.Final]
    at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1811)
    at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1746)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) [rt.jar:1.7.0_03]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) [rt.jar:1.7.0_03]
    at java.lang.Thread.run(Thread.java:722) [rt.jar:1.7.0_03]

私が間違っていることを知っていますか?

4

2 に答える 2

4

@Stateless のドキュメントによると、「アプリケーション サーバーは、マップされた名前の特定の形式またはタイプをサポートする必要はなく、マップされた名前を使用する機能も必要ありません。」したがって、それを使用して Bean のマップされた名前 IMHO を変更することはお勧めできません。

やってみよう

  1. @Stateless から MappedName を削除する
  2. 編集: java:global 名前空間で ExampleBean の名前を使用: java:global[/application name]/module name/enterprise bean name[/interface name]

移植可能な JNDI 構文に関する詳細情報

編集: 両方のモジュールを同じアプリ サーバーにデプロイしていますね。では、jndi.properties ファイルは必要ありません。使用しないようにしましょう。

于 2012-08-29T14:57:05.277 に答える
0

「依存関係: org.jboss.remote-naming」を .WAR ファイルの META-INF/manifest.mf に追加します。これにより、org.jboss.remote-naming モジュールがロードされ、「InitialContextFactory のインスタンス化に失敗しました」という例外がなくなります。詳細はこちら

ここで見ることができる同じ問題の答え

于 2012-10-02T05:06:15.407 に答える