activemq消息权限策略

  1. 在ActiveMQ发送消息的时候,可以通过MessageAuthorizationPolicy验证消息是否可以发送到消息消费者。  
  2. package org.apache.activemq.security;  
  3.   
  4. import org.apache.activemq.broker.ConnectionContext;  
  5. import org.apache.activemq.command.Message;  
  6.   
  7. /** 
  8.  * A plugin to allow custom message-level security checks to be performed before 
  9.  * a message is consumed. 
  10.  *  
  11.  *  
  12.  */  
  13. public interface MessageAuthorizationPolicy {  
  14.   
  15.     /** 
  16.      * Returns true if the given message is able to be dispatched to the connection 
  17.      * performing any user 
  18.      *  
  19.      * @return true if the context is allowed to consume the message 
  20.      */  
  21.     boolean isAllowedToConsume(ConnectionContext context, Message message);  
  22.   
  23. }  
  24. 设置消息生产者启动时候设置验证规则:  
  25.         在消息生产者创建消息的时候创建消息的时候,设置消息的相关权限验证字段,便于发送消息。  
  26. @Override  
  27.     protected BrokerService createBroker() throws Exception {  
  28.         BrokerService answer = new BrokerService();  
  29.         answer.setPersistent(false);  
  30.         //设置消息权限验证策略  
  31.         answer.setMessageAuthorizationPolicy(new MessageAuthorizationPolicy() {  
  32.             public boolean isAllowedToConsume(ConnectionContext context, Message message) {  
  33.                 try {  
  34.                     Object value = message.getProperty("myHeader");  
  35.                     return "abc".equals(value);  
  36.                 }  
  37.                 catch (IOException e) {  
  38.                     System.out.println("Caught: " + e);  
  39.                     e.printStackTrace();  
  40.                     return false;  
  41.                 }  
  42.             }  
  43.         });  
  44.         answer.addConnector(bindAddress);  
  45.         return answer;  
  46. }  

你可能感兴趣的:(activemq消息权限策略)