2016-04-09 20 views
1

İki WebSphere sunucum var. 1-st (v.8.5.5) EJB Bean'i yerel olarak barındırıyor ('domain_user' ile eşleştirilen RunsAS 'Yöneticisi' rolü) 2. (v.7) bir dosya, FileNet ContentEngine 5.1'i barındırıyor. EjB fasulyemi 2. Web Alanı'na yerleştirdiğimde ve iiop: // localhost: 2809/FileNet/Engine ile bağlantı kurarken sorun yok mu?Filenet Content Engine ile uzak iiop bağlantısı

Ama 1ND uzaktan bağlandığınızda o hatayı oluyor iiop WAS: // ikinci oldu: 2809/FileNet/Motor

Ben belirledik Postadölesan yapılandırmaları: (

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

... sonra do 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) 

benim EJB kodu:

arada
@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); 

    } 

, benim nihai amacı olmaksızın (şeffaf uzaktan bağlantı oluşturmak olduğunu pushSubject, popSubject ..)

cevap

0

İki sunucunun tarih saatini kontrol edebilirsiniz: her ikisi de maksimum 5 dakika içinde UTC zamanına eşitlenmelidir. Umarım bu yardım.

İlgili konular