public class TFTP extends DatagramSocketClient
open(), and
close(), methods. Additionally,the a
setDefaultTimeout() method may be of importance for performance tuning.
Details regarding the TFTP protocol and the format of TFTP packets can be found in RFC 783. But the point of these classes is to keep you from having to worry about the internals.
DatagramSocketClient,
TFTPPacket,
TFTPPacketException,
TFTPClient| Modifier and Type | Field and Description |
|---|---|
static int |
ASCII_MODE
The ASCII transfer mode.
|
static int |
BINARY_MODE
The binary transfer mode.
|
static int |
DEFAULT_PORT
The default TFTP port according to RFC 783 is 69.
|
static java.time.Duration |
DEFAULT_TIMEOUT_DURATION
The default duration to wait to receive a datagram before timing out.
|
static int |
IMAGE_MODE
The image transfer mode.
|
static int |
NETASCII_MODE
The netascii transfer mode.
|
static int |
OCTET_MODE
The octet transfer mode.
|
(package private) static int |
PACKET_SIZE
The size to use for TFTP packet buffers.
|
(package private) byte[] |
sendBuffer
A buffer used to accelerate sends in bufferedSend().
|
_isOpen_, _socket_, _socketFactory_, _timeout_| Constructor and Description |
|---|
TFTP()
Creates a TFTP instance with a default timeout of
DEFAULT_TIMEOUT_DURATION, a null socket, and buffered operations disabled. |
| Modifier and Type | Method and Description |
|---|---|
void |
beginBufferedOps()
Initializes the internal buffers.
|
TFTPPacket |
bufferedReceive()
This is a special method to perform a more efficient packet receive.
|
void |
bufferedSend(TFTPPacket packet)
This is a special method to perform a more efficient packet send.
|
void |
discardPackets()
This method synchronizes a connection by discarding all packets that may be in the local socket buffer.
|
void |
endBufferedOps()
Releases the resources used to perform buffered sends and receives.
|
static String |
getModeName(int mode)
Returns the TFTP string representation of a TFTP transfer mode.
|
int |
getPacketSize()
Gets the buffer size of the buffered used by
bufferedSend(TFTPPacket) and bufferedReceive(). |
TFTPPacket |
receive()
Receives a TFTPPacket.
|
void |
resetBuffersToSize(int packetSize)
Sets the size of the buffers used to receive and send packets.
|
void |
send(TFTPPacket packet)
Sends a TFTP packet to its destination.
|
protected void |
trace(String direction,
TFTPPacket packet)
Trace facility; this implementation does nothing.
|
checkOpen, close, getCharset, getDefaultTimeout, getLocalAddress, getLocalPort, getSoTimeoutDuration, isOpen, open, open, open, setCharset, setDatagramSocketFactory, setDefaultTimeout, setSoTimeoutpublic static final int ASCII_MODE
public static final int BINARY_MODE
public static final int DEFAULT_PORT
public static final java.time.Duration DEFAULT_TIMEOUT_DURATION
public static final int IMAGE_MODE
public static final int NETASCII_MODE
public static final int OCTET_MODE
static final int PACKET_SIZE
byte[] sendBuffer
public TFTP()
DEFAULT_TIMEOUT_DURATION, a null socket, and buffered operations disabled.public final void beginBufferedOps()
bufferedSend() and bufferedReceive(). This method
must be called before calling either one of those two methods. When you finish using buffered operations, you must call endBufferedOps().public final TFTPPacket bufferedReceive() throws IOException, InterruptedIOException, SocketException, TFTPPacketException
beginBufferedOps().
beginBufferedOps() initializes a set of buffers used internally that prevent the new allocation of a DatagramPacket and byte array for each send and
receive. To use these buffers you must call the bufferedReceive() and bufferedSend() methods instead of send() and receive(). You must also be certain
that you don't manipulate the resulting packet in such a way that it interferes with future buffered operations. For example, a TFTPDataPacket received
with bufferedReceive() will have a reference to the internal byte buffer. You must finish using this data before calling bufferedReceive() again, or else
the data will be overwritten by the call.InterruptedIOException - If a socket timeout occurs. The Java documentation claims an InterruptedIOException is thrown on a DatagramSocket timeout,
but in practice we find a SocketException is thrown. You should catch both to be safe.SocketException - If a socket timeout occurs. The Java documentation claims an InterruptedIOException is thrown on a DatagramSocket timeout,
but in practice we find a SocketException is thrown. You should catch both to be safe.IOException - If some other I/O error occurs.TFTPPacketException - If an invalid TFTP packet is received.public final void bufferedSend(TFTPPacket packet) throws IOException
beginBufferedOps().
beginBufferedOps() initializes a set of buffers used internally that prevent the new allocation of a DatagramPacket and byte array for each send and
receive. To use these buffers you must call the bufferedReceive() and bufferedSend() methods instead of send() and receive(). You must also be certain
that you don't manipulate the resulting packet in such a way that it interferes with future buffered operations. For example, a TFTPDataPacket received
with bufferedReceive() will have a reference to the internal byte buffer. You must finish using this data before calling bufferedReceive() again, or else
the data will be overwritten by the call.packet - The TFTP packet to send.IOException - If some I/O error occurs.public final void discardPackets()
throws IOException
IOException - if an I/O error occurs.public final void endBufferedOps()
public static final String getModeName(int mode)
mode - The TFTP transfer mode. One of the MODE constants.public int getPacketSize()
bufferedSend(TFTPPacket) and bufferedReceive().public final TFTPPacket receive() throws IOException, InterruptedIOException, SocketException, TFTPPacketException
InterruptedIOException - If a socket timeout occurs. The Java documentation claims an InterruptedIOException is thrown on a DatagramSocket timeout,
but in practice we find a SocketException is thrown. You should catch both to be safe.SocketException - If a socket timeout occurs. The Java documentation claims an InterruptedIOException is thrown on a DatagramSocket timeout,
but in practice we find a SocketException is thrown. You should catch both to be safe.IOException - If some other I/O error occurs.TFTPPacketException - If an invalid TFTP packet is received.public final void resetBuffersToSize(int packetSize)
packetSize - The size of the data octets not including 4 octets for the header.public final void send(TFTPPacket packet) throws IOException
packet - The TFTP packet to send.IOException - If some I/O error occurs.protected void trace(String direction, TFTPPacket packet)
Override it to trace the data, for example:
System.out.println(direction + " " + packet.toString());
direction - > or <packet - the packet to be sent or that has been received respectively