提交 e188b442 编写于 作者: J Juergen Hoeller

Polishing

上级 94753b5e
/* /*
* Copyright 2002-2015 the original author or authors. * Copyright 2002-2016 the original author or authors.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
...@@ -26,15 +26,14 @@ import org.springframework.util.Assert; ...@@ -26,15 +26,14 @@ import org.springframework.util.Assert;
/** /**
* Base class for STOMP client implementations. * Base class for STOMP client implementations.
* *
* <p>Subclasses can connect over WebSocket or TCP using any library. * <p>Subclasses can connect over WebSocket or TCP using any library. When creating
* When creating a new connection a sub-class can create an instance of * a new connection, a subclass can create an instance of @link DefaultStompSession}
* {@link DefaultStompSession} which extends * which extends {@link org.springframework.messaging.tcp.TcpConnectionHandler}
* {@link org.springframework.messaging.tcp.TcpConnectionHandler * whose lifecycle methods the subclass must then invoke.
* TcpConnectionHandler} whose lifecycle methods the sub-class must then invoke.
* *
* <p>In effect {@code TcpConnectionHandler} and {@code TcpConnection} are the * <p>In effect, {@code TcpConnectionHandler} and {@code TcpConnection} are the
* contracts any sub-class must adapt to while using {@link StompEncoder} and * contracts that any subclass must adapt to while using {@link StompEncoder}
* {@link StompDecoder} to encode and decode STOMP messages. * and {@link StompDecoder} to encode and decode STOMP messages.
* *
* @author Rossen Stoyanchev * @author Rossen Stoyanchev
* @since 4.2 * @since 4.2
...@@ -58,7 +57,7 @@ public abstract class StompClientSupport { ...@@ -58,7 +57,7 @@ public abstract class StompClientSupport {
* @param messageConverter the message converter to use * @param messageConverter the message converter to use
*/ */
public void setMessageConverter(MessageConverter messageConverter) { public void setMessageConverter(MessageConverter messageConverter) {
Assert.notNull(messageConverter, "'messageConverter' must not be null"); Assert.notNull(messageConverter, "MessageConverter must not be null");
this.messageConverter = messageConverter; this.messageConverter = messageConverter;
} }
...@@ -92,7 +91,7 @@ public abstract class StompClientSupport { ...@@ -92,7 +91,7 @@ public abstract class StompClientSupport {
* CONNECT frame. The first number represents how often the client will write * CONNECT frame. The first number represents how often the client will write
* or send a heart-beat. The second is how often the server should write. * or send a heart-beat. The second is how often the server should write.
* A value of 0 means no heart-beats. * A value of 0 means no heart-beats.
* <p>By default this is set to "10000,10000" but sub-classes may override * <p>By default this is set to "10000,10000" but subclasses may override
* that default and for example set it to "0,0" if they require a * that default and for example set it to "0,0" if they require a
* TaskScheduler to be configured first. * TaskScheduler to be configured first.
* @param heartbeat the value for the CONNECT "heart-beat" header * @param heartbeat the value for the CONNECT "heart-beat" header
...@@ -100,22 +99,23 @@ public abstract class StompClientSupport { ...@@ -100,22 +99,23 @@ public abstract class StompClientSupport {
* http://stomp.github.io/stomp-specification-1.2.html#Heart-beating</a> * http://stomp.github.io/stomp-specification-1.2.html#Heart-beating</a>
*/ */
public void setDefaultHeartbeat(long[] heartbeat) { public void setDefaultHeartbeat(long[] heartbeat) {
Assert.notNull(heartbeat); if (heartbeat == null || heartbeat.length != 2 || heartbeat[0] < 0 || heartbeat[1] < 0) {
Assert.isTrue(heartbeat[0] >= 0 && heartbeat[1] >=0 , "Invalid heart-beat: " + Arrays.toString(heartbeat)); throw new IllegalArgumentException("Invalid heart-beat: " + Arrays.toString(heartbeat));
}
this.defaultHeartbeat = heartbeat; this.defaultHeartbeat = heartbeat;
} }
/** /**
* Return the configured default heart-beat value, never {@code null}. * Return the configured default heart-beat value (never {@code null}).
*/ */
public long[] getDefaultHeartbeat() { public long[] getDefaultHeartbeat() {
return this.defaultHeartbeat; return this.defaultHeartbeat;
} }
/** /**
* Whether heartbeats are enabled. Returns {@code false} if * Determine whether heartbeats are enabled.
* {@link #setDefaultHeartbeat defaultHeartbeat} is set to "0,0", and * <p>Returns {@code false} if {@link #setDefaultHeartbeat defaultHeartbeat}
* {@code true} otherwise. * is set to "0,0", and {@code true} otherwise.
*/ */
public boolean isDefaultHeartbeatEnabled() { public boolean isDefaultHeartbeatEnabled() {
return (getDefaultHeartbeat() != null && getDefaultHeartbeat()[0] != 0 && getDefaultHeartbeat()[1] != 0); return (getDefaultHeartbeat() != null && getDefaultHeartbeat()[0] != 0 && getDefaultHeartbeat()[1] != 0);
......
...@@ -18,7 +18,6 @@ package org.springframework.messaging.simp.stomp; ...@@ -18,7 +18,6 @@ package org.springframework.messaging.simp.stomp;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
import java.nio.ByteBuffer; import java.nio.ByteBuffer;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
......
...@@ -20,7 +20,7 @@ import java.io.ByteArrayOutputStream; ...@@ -20,7 +20,7 @@ import java.io.ByteArrayOutputStream;
import java.io.DataOutputStream; import java.io.DataOutputStream;
import java.io.IOException; import java.io.IOException;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.Arrays; import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Map.Entry; import java.util.Map.Entry;
...@@ -47,7 +47,7 @@ public final class StompEncoder { ...@@ -47,7 +47,7 @@ public final class StompEncoder {
private static final byte COLON = ':'; private static final byte COLON = ':';
private final Log logger = LogFactory.getLog(StompEncoder.class); private static final Log logger = LogFactory.getLog(StompEncoder.class);
/** /**
...@@ -79,6 +79,7 @@ public final class StompEncoder { ...@@ -79,6 +79,7 @@ public final class StompEncoder {
} }
output.write(StompDecoder.HEARTBEAT_PAYLOAD); output.write(StompDecoder.HEARTBEAT_PAYLOAD);
} }
else { else {
StompCommand command = StompHeaderAccessor.getCommand(headers); StompCommand command = StompHeaderAccessor.getCommand(headers);
if (command == null) { if (command == null) {
...@@ -100,8 +101,8 @@ public final class StompEncoder { ...@@ -100,8 +101,8 @@ public final class StompEncoder {
} }
} }
private void writeHeaders(StompCommand command, Map<String, Object> headers, byte[] payload, DataOutputStream output) private void writeHeaders(StompCommand command, Map<String, Object> headers, byte[] payload,
throws IOException { DataOutputStream output) throws IOException {
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
Map<String,List<String>> nativeHeaders = Map<String,List<String>> nativeHeaders =
...@@ -125,7 +126,7 @@ public final class StompEncoder { ...@@ -125,7 +126,7 @@ public final class StompEncoder {
List<String> values = entry.getValue(); List<String> values = entry.getValue();
if (StompCommand.CONNECT.equals(command) && if (StompCommand.CONNECT.equals(command) &&
StompHeaderAccessor.STOMP_PASSCODE_HEADER.equals(entry.getKey())) { StompHeaderAccessor.STOMP_PASSCODE_HEADER.equals(entry.getKey())) {
values = Arrays.asList(StompHeaderAccessor.getPasscode(headers)); values = Collections.singletonList(StompHeaderAccessor.getPasscode(headers));
} }
byte[] encodedKey = encodeHeaderString(entry.getKey(), shouldEscape); byte[] encodedKey = encodeHeaderString(entry.getKey(), shouldEscape);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册