15

Weld-SE 2.1.2.Final を使用して Bean を取得し、それをスレッドから呼び出すと、次の例外が発生します。

スレッド「メイン」org.jboss.weld.context.ContextNotActiveException での例外: WELD-001303: スコープ タイプ javax.enterprise.context.RequestScoped のアクティブなコンテキストがありません

私の Bean には @RequestScooped のアノテーションが付けられています。@ApplicationScoped にアノテーションを付けると問題なく動作しますが、@RequestScooped を維持する必要があります。

ここに再現者があります:

public static void main(String[] args) throws Exception {
    Weld weld = new Weld();
    WeldContainer container = weld.initialize();
    final MyPojo pojo = container.instance().select(MyPojo.class).get();

    Thread t = new Thread() {
        public void run() {
            System.out.println(pojo.ping());   // This call fails
        }
    };
    t.start();
    t.join();
    System.out.println(pojo.ping()); // This call succeed
    weld.shutdown();

}

@RequestScoped
public class MyPojo {
 public String ping() {
    return "pong";
 }
}

この動作に遭遇しましたか? これを機能させるためのアイデアはありますか?

4

1 に答える 1

22

この場合、Weld は、スレッド ( RequestContext )に関連付けられたバインドされていない RequestContext を使用しています。作成しているスレッドで新しい RequestContext を手動で初期化する必要があります。これは私にとってはうまくいきます:

public static void main(String[] args) throws Exception {
    Weld weld = new Weld();
    final WeldContainer container = weld.initialize();
    RequestContext requestContext= container.instance().select(RequestContext.class, UnboundLiteral.INSTANCE).get();
    requestContext.activate();

    final MyPojo pojo = container.instance().select(MyPojo.class).get();

    Thread t = new Thread() {
        public void run() {
            RequestContext requestContext= container.instance().select(RequestContext.class, UnboundLiteral.INSTANCE).get();
            requestContext.activate();
            System.out.println("1" + pojo.ping()); 
        }
    };
    t.start();
    t.join();
    System.out.println("2" + pojo.ping());
    weld.shutdown();

}
于 2014-10-29T13:50:54.643 に答える