J'essaie de créer une classe d'usine EJB, qui fonctionne comme ceci: Vous avez une méthode qui prend comme argument une classe d'EJB, puis elle vérifie si l'EJB a une interface distante (sinon lancer une exception) et si c'est le cas, il renvoie l'EJB concerné.EJB Factory Class
Le code ci-dessous fait exactement cela. Cependant l'objet qu'il renvoie est du type de l'interface distante du bean concerné et non du haricot lui-même. Comment puis-je changer cela? Est-il possible de dire à Java que le type générique T est du même type que la classe transmise aux méthodes.
import java.util.Properties;
import javax.ejb.Remote;
import javax.ejb.Stateless;
import javax.naming.*;
public class EJBFactory
{
private InitialContext ctx;
public EJBFactory() throws NamingException {
ctx = new InitialContext();
}
public EJBFactory(String host, String port) throws NamingException {
Properties props = new Properties();
props.setProperty("org.omg.CORBA.ORBInitialHost", host);
props.setProperty("org.omg.CORBA.ORBInitialPort", port);
ctx = new InitialContext(props);
}
.
// To improve: The object returned should be of the type ejbClass
// instead of the remote interface, which it implements
public <T> T createEJB(Class ejbClass) throws NamingException
{
Class remoteInterface = null;
for(Class interface_: ejbClass.getInterfaces()) {
if(interface_.isAnnotationPresent(Remote.class))
remoteInterface = interface_;
}
if(remoteInterface == null)
throw new IllegalArgumentException(
"EJB Requires a remote interface");
// Get the stateless annotation, then get the jndiName
Stateless stateless =
(Stateless)ejbClass.getAnnotation(Stateless.class);
String jndiName = stateless.mappedName();
T ejbObj = (T) ctx.lookup(jndiName);
return ejbObj;
}
}
Exemple d'un test unitaire qui utilise l'usine.
import junit.framework.TestCase;
public class SimpleEJBTest extends TestCase
{
TestRemote testBean;
@Override
protected void setUp() throws Exception {
super.setUp();
EJBFactory ejbFactory = new EJBFactory();
testBean = ejbFactory.createEJB(TestBean.class);
}
public void testSayHello() {
assertEquals("Hello", testBean.sayHello());
}
}
Remarque: L'exemple fonctionne avec Glassfish, je ne l'ai pas testé avec un autre serveur d'applications.
Quelle sera l'utilité d'avoir l'objet du haricot lui-même? - vous serez toujours en interaction à travers l'interface droite? fondamentalement comme InterfaceType ref = (InterfaceType) jndiLookup; Ensuite, vous appelez les méthodes sur la réf. Essayer de comprendre le besoin de ceci. – OpenSource