Solved

How to  access EJB:s between apps? (test source valid)

Posted on 2004-09-16
2
265 Views
Last Modified: 2010-04-01
Hello!

I got a problem with accessing EJB:s from a different application than they are running under.

My idea is to have 3 apps running on 1 app server:

main.ear
admin.ear
ejb.ear

The idea is that tasks that may be performed by both the main-app and the admin-app are located as EJB:s in the ejb-app. The reason is that if I need to update an EJB I just need to update it at one place, instead of updating all EJB in every app. Do you get my point?

The problem is of course that I can't figure out how to access any EJB:s in the ejb-app from the admin-app or the main-app.

When I execute this code from a Servlet in the main.ear, for example, that tries to locate a EJB in ejb.ear I get the exception below:

      Context context = new InitialContext();

      Object object = context.lookup("java:comp/env/ejb/ejb/beans");

      TestHome testHome = (TestHome)PortableRemoteObject.narrow(object, TestHome.class);

      TestRemote testRemote = (TestRemote)PortableRemoteObject.narrow(testHome.create(), TestRemote.class);

      String output = testRemote.getStringFromFile("applications/ejb/ejb/outputs/output.html");

Communication error: ejb/ejb/beans not found in main, there are no bound values
javax.naming.NameNotFoundException: ejb/ejb/beans not found in main, there are n
o bound values
        at com.evermind._jj.lookup(.:78)
        at com.evermind._bq._ex(.:121)
        at com.evermind._bq.lookup(.:63)
        at javax.naming.InitialContext.lookup(InitialContext.java:347)
        at main.servlets.EjbCallerServlet.start(EjbCallerServlet.java:44)
        at main.servlets.EjbCallerServlet.doGet(EjbCallerServlet.java:34)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:195)
       
When I execute that code from a Servlet in the ejb.ear it works perfect.

So the problem is how to get access to EJB:s between applications inside a app server.

I have created a zip file with my 3 apps that is ready to use in any server (I hope) if you would like to try it out for your self.

It is possible to download at:
http://hem.passagen.se/millhills/admin_main_ejb.zip

If you are using orion do not forget to add these lines in default-web-site.xml:
      <web-app application="main" name="main" root="/main" />
      
      <web-app application="admin" name="admin" root="/admin" />
      
      <web-app application="ejb" name="ejb" root="/ejb" />
...and these lines in server.xml:
      <application name="main" path="../applications/main.ear" />
      
      <application name="admin" path="../applications/admin.ear" />
      
      <application name="ejb" path="../applications/ejb.ear" />

When unzip my zip-file with the 3 apps you will find a build.bat file for Windows for each one of the apps. You may need to change the paths depending on where you unzip it if you would like to use the build.bat-files.
My file System looks like:
D:/admin
D:/ejb
D:/main
D:/orion_test
D:/orion_test/applications

When everything is installed you should be able to locate your browser to:

localhost/admin/index.html
localhost/ejb/index.html
localhost/main/index.html

Each index.html got a link to a EjbCallerServlet but only the one in the ejb.ear works and response with a output: THAT CALL WORKED!!


In the zip file is also a overview image of files in the 3 apps.

So if you would take the time to test it and try to see if you can find out how to get access to EJB:s in an other app it would be great!

I guess that I just have missed something but I can't figure out what.

BTW if you think that my architecture with shared EJB:s is totaly crazy please tell me why!

Best reagards
Fredrik


0
Comment
Question by:fredand44
2 Comments
 
LVL 11

Accepted Solution

by:
sompol_kiatkamolchai earned 80 total points
ID: 12081920
I think yor problem is how to lookup EJB that deploy on another application

Context context = new InitialContext();

From the code like this, you will the context environment on that application which does not contains EJB you want to use.

You should use this api

public InitialContext(Hashtable environment)
               throws NamingException


Hashtable env = new Hashtable();    
env.put(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory"); // you have to alter this to web server you use.
env.put(Context.PROVIDER_URL, "http://somehost:port");    
env.put(Context.SECURITY_PRINCIPAL, username);    
env.put(Context.SECURITY_CREDENTIALS, password);
Context context = new InitialContext(env);

So this api can connect to any ejb deploy in any server on the network.
0
 

Author Comment

by:fredand44
ID: 12092000
Hello!

I finally solved how to connect to EJB:s in apps outside the app where they are located. Perhaps I should say that these apps are located at the same webserver.

On the way I received alot of exceptions, but I tracked them down one by one.

I have created a ZIP file that you can download at:
http://hem.passagen.se/millhills/HOW_TO_CONNECT_TO_EJBS.zip

It will be avialible for at least a month, after that you can email me if you would like me to send it to you. fredand44@hotmail.com

Best regards
Fredrik

0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Large Outlook files lead to various unwanted errors and corruption issues. Furthermore, large outlook files can also make Outlook take longer to start-up, search, navigate, and shut-down. So, In this article, i will discuss a method to make your Out…
This article shows gives you an overview on SQL Server 2016 row level security. You will also get to know the usages of row-level-security and how it works
This Micro Tutorial hows how you can integrate  Mac OSX to a Windows Active Directory Domain. Apple has made it easy to allow users to bind their macs to a windows domain with relative ease. The following video show how to bind OSX Mavericks to …
As a trusted technology advisor to your customers you are likely getting the daily question of, ‘should I put this in the cloud?’ As customer demands for cloud services increases, companies will see a shift from traditional buying patterns to new…

920 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

17 Experts available now in Live!

Get 1:1 Help Now