Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  *  Copyright 2010, 2013, 2014 Chris Pheby
  *  Licensed under the Apache License, Version 2.0 (the "License");
  *  you may not use this file except in compliance with the License.
  *  You may obtain a copy of the License at
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
package org.jadira.jms.mdp;
import  javax.jms.Message;
import  javax.jms.MessageListener;
import  org.springframework.beans.factory.InitializingBean;
import  org.springframework.jms.core.JmsTemplate;

Provides a base implementation for a Message Driven POJO. The key benefit of extending this class is that a standard error handling pattern is 'baked in'. This class should be configured by setting the appropriate JmsTemplate for handling Fatal JMS failures.
public abstract class AbstractMessageDriven implements MessageListener, InitializingBean {
    private JmsTemplate fatalJmsExceptionHandler;
    public JmsTemplate getFatalJmsExceptionHandler() {
        return ;
    public void setFatalJmsExceptionHandler(JmsTemplate fatalJmsExceptionHandler) {
        this. = fatalJmsExceptionHandler;
    public void onMessage(final Message message) {
        if ( == null) {
        } else {
            try {
            } catch (final FatalJmsException e) {
                .send(new FatalJmsExceptionMessageCreator(messagee));

Implements message handling functionality

message Message to be read
FatalJmsException Exception thrown to indicate a processing failure that cannot be recovered from
    protected abstract void doOnMessage(Message messagethrows FatalJmsException;
New to GrepCode? Check out our FAQ X