MessageHandler.java 1.5 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
/*
 * Copyright 2002-2013 the original author or authors.
 *
 * 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
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * 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.springframework.messaging;

/**
 * Base interface for any component that handles Messages.
 *
 * @author Mark Fisher
 * @author Iwein Fuld
 * @since 4.0
 */
26
public interface MessageHandler {
27 28 29

	/**
	 * Handles the message if possible. If the handler cannot deal with the
P
Phillip Webb 已提交
30
	 * message this will result in a {@code MessageRejectedException} e.g.
31
	 * in case of a Selective Consumer. When a consumer tries to handle a
P
Phillip Webb 已提交
32
	 * message, but fails to do so, a {@code MessageHandlingException} is
33 34 35 36 37
	 * thrown. In the last case it is recommended to treat the message as tainted
	 * and go into an error scenario.
	 * <p>
	 * When the handling results in a failure of another message being sent
	 * (e.g. a "reply" message), that failure  will trigger a
P
Phillip Webb 已提交
38
	 * {@code MessageDeliveryException}.
39 40
	 *
	 * @param message the message to be handled
P
Phillip Webb 已提交
41 42 43 44
	 * reply related to the handling of the message
	 */
	void handleMessage(Message<?> message) throws MessagingException;

45
}