Доступ запрещен к ресурсу: type = <jms>, application = JMSModule, destinationType = queue, resource = test, action = receive - PullRequest
0 голосов
/ 17 октября 2019

Я пытаюсь получить weblogic сервер jms при весенней загрузке. Но я столкнулся с этой проблемой после успешного запуска приложения.

[]org.springframework.jms.listener.DefaultMessageListenerContainer:handleListenerSetupFailure(892): Setup of JMS message listener invoker failed for destination 'jms/test' - trying to recover. Cause: Access denied to resource: type=<jms>, application=JMSModule, destinationType=queue, resource=ns-alert-test, action=receive

И я обнаружил, что он может быть успешно подключен в потоке [main] при запуске. Похоже, что имя пользователя и пароль пропущены при изменении потока

[main] org.springframework.jndi.JndiObjectFactoryBean:lookup(112): Located object with JNDI name [jms/rtsConnectionFactory]

И я пытаюсь использовать wlfullclient.jar и wlclient.jar и wlthint3client.jar в моем проекте. Но проблема все еще существует. Можете ли вы дать мне несколько советов по этой проблеме. Ниже мой код Конфиг:

@Autowired
private JmsErrorHandler jmsErrorHandler;

@Autowired
private JMSPropertiesConfig jmsPropertiesConfig;

@Bean
public JndiTemplate jndiTemplate(){
    JndiTemplate jndiTemplate =new JndiTemplate();
    Properties properties = new Properties();
    properties.setProperty("java.naming.factory.initial","weblogic.jndi.WLInitialContextFactory");
    properties.setProperty("java.naming.provider.url", jmsPropertiesConfig.getUrl());
   if(jmsPropertiesConfig.getUname()!=null){
        properties.setProperty("username", jmsPropertiesConfig.getUname());
    }
    if(jmsPropertiesConfig.getUcert()!=null){
        properties.setProperty("password", jmsPropertiesConfig.getUcert());
    }
    jndiTemplate.setEnvironment(properties);
    return jndiTemplate;
}

@Bean
public JndiDestinationResolver jmsDestionationProvider() {
    JndiDestinationResolver destinationResolver = new JndiDestinationResolver();
    destinationResolver.setJndiTemplate(jndiTemplate());
    return destinationResolver;
}

@Bean
public JndiObjectFactoryBean connectionFactory(){
    JndiObjectFactoryBean cf = new JndiObjectFactoryBean();
    cf.setJndiTemplate(jndiTemplate());
    cf.setJndiName(jmsPropertiesConfig.getFactory());
    return cf;
}

@Bean
public JmsTemplate jmsTemplate(){
    JmsTemplate template = new JmsTemplate();
    template.setConnectionFactory((ConnectionFactory) connectionFactory().getObject());
    template.setSessionAcknowledgeModeName("AUTO_ACKNOWLEDGE");
    template.setSessionTransacted(true);
    template.setDestinationResolver(jmsDestionationProvider());
    return template;
}

@Bean
public DefaultJmsListenerContainerFactory jmsListenerContainerFactory() {
    DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();
    factory.setConnectionFactory((ConnectionFactory) connectionFactory().getObject());
    factory.setDestinationResolver(jmsDestionationProvider());
    factory.setErrorHandler(jmsErrorHandler);
    factory.setSessionAcknowledgeMode(0);
    return factory;
}

Получите:

 @JmsListener(destination = "jms/test")
public void receiveApplicationNotification(String input) throws Exception {
    log.info("Receiving message from jms.external.ExampleQueue.queue "+input);
}

1 Ответ

0 голосов
/ 18 октября 2019

Кажется, что это ошибка в Weblogic.

Можете ли вы попробовать применить приведенный ниже патч ..

Ошибка 22550927 - СОЕДИНЕНИЕ С WEBLOGIC JMS НЕ БЕЗОПАСНО ДЛЯ РЕЗЬБЫ

...