ActiveMQ授权 - 如何从数据库中读取授权条目

时间:2017-12-11 06:04:38

标签: authorization activemq customization

我正在使用自定义身份验证和授权部署ActiveMQ。我有关于自定义授权地图的查询。

问题 我希望从数据库而不是activemq.xml读取授权条目。我们不想在activemq.xml文件中编写授权条目。我不想更改默认授权插件中提供的通配符队列名称层次结构。 我需要重写什么代码组件?

1 个答案:

答案 0 :(得分:1)

我已经找到了上述问题的答案。我只需要连接我的自定义类,以便我能够从activemq.xml以外的源加载授权条目。我还可以每1分钟重新加载一次授权,这样如果创建了一个新的角色或授权条目,它就会重新加载到系统而不重新启动。

解决方案配置

  1. 创建一个与AuthorizationMap接口的类。        在我的例子中,我从DefaultAuthorizationMap.java扩展了我的类。一世 想要类似的功能,并希望只更改授权条目的输入。我的代码从数据库中读取角色。请参阅" Code-CustomAuthorizationMap"下方。

  2. 将CustomAuthorizationMap类配置为activemq.xml中的bean

    <plugins>
        <jaasAuthenticationPlugin configuration="activemq"/>
    
        <authorizationPlugin>
            <map>
                <bean xmlns="" class="com.test.CustomAuthorizationMap"
            </map>
        </authorizationPlugin
    </plugins>
    
  3. 将lib添加到classpath

    a. Create the jar file. Place it in "%ActiveMQ-Home%/lib" folder. E.g. custom-authorization.jar
    b. Modify "%ActiveMQ-Home%/bin/activemq.bat".
       **Replace** 
           set ACTIVEMQ_CLASSPATH=%ACTIVEMQ_CONF%;%ACTIVEMQ_BASE%/conf;%ACTIVEMQ_HOME%/conf;%ACTIVEMQ_CLASSPATH%;
       **With**
           set ACTIVEMQ_CLASSPATH=%ACTIVEMQ_CONF%;%ACTIVEMQ_BASE%/conf;%ACTIVEMQ_HOME%/conf;%ACTIVEMQ_CLASSPATH%;%ACTIVEMQ_HOME%/lib/custom-authorization.jar;
    
  4. 代码CustomAuthorizationMap

    package com.test.authorization.map;
    
    import java.util.ArrayList;
    import java.util.List;
    
    import org.apache.activemq.command.ActiveMQQueue;
    import org.apache.activemq.command.ActiveMQTempQueue;
    import org.apache.activemq.command.ActiveMQTopic;
    import org.apache.activemq.filter.DefaultDestinationMapEntry;
    import org.apache.activemq.filter.DestinationMapEntry;
    import org.apache.activemq.security.AuthorizationEntry;
    import org.apache.activemq.security.DefaultAuthorizationMap;
    
    public class SecGwAuthorizationMap extends DefaultAuthorizationMap {
    
        public SecGwAuthorizationMap() throws Exception {
            super();
    
            List<DestinationMapEntry> authorizationEntries = 
           loadAuthorizationEntriesFromPropFiles();
    
    //  For information. After loading I populate 
    //authorization entries like below
    //          AuthorizationEntry entry = new AuthorizationEntry();
    //          entry.setTopic(">");
    //          entry.setAdmin("admins");
    //          entry.setRead("admins");
    //          entry.setWrite("admins");
    //          authorizationEntries.add(entry);
    
    //          entry = new AuthorizationEntry();
    //          entry.setQueue(">");
    //          entry.setAdmin("admins");
    //          entry.setRead("admins");
    //          entry.setWrite("admins");
    //          authorizationEntries.add(entry);
    
    //          entry= new AuthorizationEntry();
    //          entry.setTopic("ActiveMQ.Advisory.>");
    //          entry.setAdmin("gcabrokerusers,admins,users");
    //          entry.setRead("gcabrokerusers");
    //          entry.setWrite("gcabrokerusers");
    //          authorizationEntries.add(entry);
    
    //          entry = new AuthorizationEntry();
    //          entry.setQueue("gcaa.test.jms.>");
    //          entry.setAdmin("gcabrokerusers");
    //          entry.setRead("gcabrokerusers");
    //          entry.setWrite("gcabrokerusers");
    //          authorizationEntries.add(entry);
                setAuthorizationEntries(authorizationEntries);
            }
    
        public SecGwAuthorizationMap(List<DestinationMapEntry> 
        authorizationEntries) {
    
            super(authorizationEntries);
            // TODO Auto-generated constructor stub
        }
    
     }
    

    注意: - 下面是一个示例roles.properties文件,用于说明我们如何创建授权角色。

    roles.properties文件

    //commentedLine      Destination     Read-ACLs    Write-ACLs    AdminAcls     Type
    ActiveMQ.Advisory.>::admins,appUsr::admins,appusr::admins,appUsr::TOPIC
    test.accounts.queue::appClientId::appClientId::admins::QUEUE
    >::admins::admins::admins::QUEUE
    >::admins::admins::admins::TOPIC