2016-04-09 48 views
1

我有兩臺WebSphere服務器。 第一個(v.8.5.5)託管我的EJB Bean本地(RunsAS'Admin'角色,映射到'domain_user') 第二個(v.7)託管FileNet ContentEngine 5.1。 當我將Ejb bean部署到第二個Websphere並使用iiop:// localhost:2809/FileNet/Engine進行連接時可以。與Filenet Content Engine的遠程iiop連接

但是,當我從1ND遠程連接它越來越錯誤是IIOP://第二是:2809 /凡納/發動機

我已經設置theese CONFIGS:

System.setProperty(」 java.security.auth.login.config「, 」c:\ eq \ config \ jaas.conf.WebSphere「); System.setProperty(「com.ibm.CORBA.ConfigURL」,「file:c:\ ea \ config \ sas.client.props」);

...然後做PushSubject

[4/9/16 21:50:04:038 YEKT] 0000022f BusinessExcep E CNTR0020E: EJB threw an unexpected (non-declared) exception during invocation of method "getDocumentContent" on bean "BeanId(web-services-bni#ejb-1.0.1-SNAPSHOT.jar#CeServiceImpl, null)". Exception data: com.filenet.api.exception.EngineRuntimeException: FNRCS0001E: SECURITY_ANONYMOUS_DISALLOWED: Access to Content Engine was not allowed because the request was made anonymously instead of by an authenticated user. The application server reported that the user was anonymous. errorStack={ 
    at com.filenet.engine.context.SecurityContext.<init>(SecurityContext.java:75) 
    at com.filenet.engine.context.ServerCallContext.<init>(ServerCallContext.java:107) 
    at com.filenet.engine.context.ServerCallContext.newInstance(ServerCallContext.java:1115) 
    at com.filenet.engine.jca.impl.RequestBrokerImpl.executeSearch(RequestBrokerImpl.java:814) 
    at com.filenet.engine.ejb.EngineCoreBean._executeSearch(EngineCoreBean.java:318) 

我EJB代碼:

@DeclareRoles({"Everyone", "Admin"}) 
@RolesAllowed({"Everyone", "Admin"}) 
@RunAs("Admin") 
@Stateless 
public class CeServiceImpl implements CeServiceLocal { 
    private static final Logger logger = Logger.getLogger(CeServiceImpl.class.getName()); 

    private CeServiceHelper serviceHelper; 
    private Subject subject; 

    @PostConstruct 
    public void init() { 
     logger.info("CeServiceImpl init started"); 

     String ceUri = ConfigHelper.getCeUri(); 
     if (ceUri == null) { 
      logger.log(Level.SEVERE, "ceUri can not be null"); 
      throw new NullPointerException("ceUri can not be null"); 
     } 
     logger.info("ceUri: " + ceUri); 


     System.setProperty("java.security.auth.login.config", "c:\\ea\\config\\jaas.conf.WebSphere"); 
     System.setProperty("com.ibm.CORBA.ConfigURL", "file:c:\\ea\\config\\sas.client.props"); 


     Connection connection = Factory.Connection.getConnection(ceUri); 

     subject = UserContext.createSubject(connection, "os_user", "password", "FileNetP8"); 
     try { 
      UserContext.get().pushSubject(subject); 
     } catch (Exception e) { 
      logger.warning(e.getMessage()); 
     } 


     serviceHelper = new CeServiceHelper(connection); 

    } 

順便說一句,我的最終目標是建立透明的遠程連接(不pushSubject,popSubject ..)

回答

0

您可以檢查兩臺服務器的日期時間:兩者必須在最長5分鐘內同步到UTC時間。希望這個幫助。