Yas*_*svi 1 activemq-classic authorization
我正在尝试在activemq中使用授权,但是现在停滞了一段时间。
这是我的Java代码,删除授权插件后一切正常。我正在尝试创建一个名为“ room2”的主题。
Context jndiContext = new InitialContext();
ConnectionFactory connectionFactory;
connectionFactory = (ConnectionFactory) jndiContext
.lookup("ConnectionFactory");
connection = connectionFactory.createConnection("system", "manager");
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
Topic t = session.createTopic("room2");
Run Code Online (Sandbox Code Playgroud)
这是我的activemq.xml:
<plugins>
<simpleAuthenticationPlugin>
<users>
<authenticationUser username="system" password="manager"
groups="admins,publishers,consumers"/>
<authenticationUser username="user" password="password"
groups="admins,users,publishers"/>
<authenticationUser username="guest" password="password" groups="guests"/>
</users>
</simpleAuthenticationPlugin>
<authorizationPlugin>
<map>
<authorizationMap>
<authorizationEntries>
<authorizationEntry topic="room2" read="consumers" write="publishers" admin="admins" />
</authorizationEntries>
</authorizationMap>
</map>
</authorizationPlugin>
</plugins>
Run Code Online (Sandbox Code Playgroud)
这是我得到的错误:
User system is not authorized to create: topic://ActiveMQ.Advisory.Connection
Run Code Online (Sandbox Code Playgroud)
如果我使用<authorizationEntry topic=">" read="consumers" write="publishers" admin="admins" />,那么它可以正常工作,那么究竟是什么>意思呢?
您需要分配角色以允许创建咨询主题,除非您只是禁用它们。网站上的示例如下。
<authorizationEntry topic="ActiveMQ.Advisory.>" read="guests,users" write="guests,users" admin="guests,users"/>
Run Code Online (Sandbox Code Playgroud)
请参阅此处的文档。