Class Socket
java.lang.Object
org.apache.tomcat.jni.Socket
Deprecated.
The scope of the APR/Native Library will be reduced in Tomcat
              9.1.x / Tomcat Native 2.x and has been reduced in Tomcat
              10.1.x / Tomcat Native 2.x onwards to only include those
              components required to provide OpenSSL integration with the NIO
              and NIO2 connectors.
Socket
- Author:
- Mladen Turk
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intDeprecated.Set on non-blocking sockets (timeout !static final intDeprecated.like APR_INCOMPLETE_READ, but for writestatic final intDeprecated.static final intDeprecated.static final intDeprecated.static final intDeprecated.static final intDeprecated.Don't accept IPv4 connections on an IPv6 listening socket.static final intDeprecated.Enum to tell us if we're interested in remote or local socket apr_interface_estatic final intDeprecated.SCTPstatic final intDeprecated.TCPstatic final intDeprecated.UDPstatic final intDeprecated.static final intDeprecated.This flag is ONLY set internally when we set APR_TCP_NOPUSH with APR_TCP_NODELAY set to tell us that APR_TCP_NODELAY should be turned on again when NOPUSH is turned offstatic final intDeprecated.no longer allow read requeststatic final intDeprecated.no longer allow read or write requestsstatic final intDeprecated.no longer allow write requestsstatic final intDeprecated.Debugstatic final intDeprecated.Disconnectedstatic final intDeprecated.Keepalivestatic final intDeprecated.Lingerstatic final intDeprecated.Non-blocking IOstatic final intDeprecated.Receive bufferstatic final intDeprecated.Reuse addressesstatic final intDeprecated.Send bufferstatic final intDeprecated.Delay accepting of new connections until data is available.static final intDeprecated.For SCTP sockets, this is mapped to STCP_NODELAY internally.static final intDeprecated.No pushstatic final intDeprecated.static final intDeprecated.static final intDeprecated.static final intDeprecated.static final intDeprecated.static final intDeprecated.static final intDeprecated.static final intDeprecated.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic longaccept(long sock) Deprecated.Accept a new connection requeststatic intacceptfilter(long sock, String name, String args) Deprecated.Set an OS level accept filter.static longacceptx(long sock, long pool) Deprecated.Accept a new connection requeststatic booleanatmark(long sock) Deprecated.Query the specified socket if at the OOB/Urgent data markstatic intbind(long sock, long sa) Deprecated.Bind the socket to its associated portstatic intclose(long thesocket) Deprecated.Close a socket.static intconnect(long sock, long sa) Deprecated.Issue a connection request to a socket either on the same machine or a different one.static longcreate(int family, int type, int protocol, long cont) Deprecated.Create a socket.static ObjectDeprecated.Return the data associated with the current socketstatic intDeprecated.Set the data associated with the current socket.static voiddestroy(long thesocket) Deprecated.Destroy a pool associated with socketstatic intlisten(long sock, int backlog) Deprecated.Listen to a bound socket for connections.static intoptGet(long sock, int opt) Deprecated.Query socket options for the specified socketstatic intoptSet(long sock, int opt, int on) Deprecated.Setup socket options for the specified socketstatic longpool(long thesocket) Deprecated.Create a child pool from associated socket pool.static intrecv(long sock, byte[] buf, int offset, int nbytes) Deprecated.Read data from a network.static intrecvb(long sock, ByteBuffer buf, int offset, int nbytes) Deprecated.Read data from a network.static intrecvbb(long sock, int offset, int nbytes) Deprecated.Read data from a network using internally set ByteBuffer.static intrecvbbt(long sock, int offset, int nbytes, long timeout) Deprecated.Read data from a network with timeout using internally set ByteBufferstatic intrecvbt(long sock, ByteBuffer buf, int offset, int nbytes, long timeout) Deprecated.Read data from a network with timeout.static intrecvfrom(long from, long sock, int flags, byte[] buf, int offset, int nbytes) Deprecated.static intrecvt(long sock, byte[] buf, int offset, int nbytes, long timeout) Deprecated.Read data from a network with timeout.static intsend(long sock, byte[] buf, int offset, int len) Deprecated.Send data over a network.static intsendb(long sock, ByteBuffer buf, int offset, int len) Deprecated.Send data over a network.static intsendbb(long sock, int offset, int len) Deprecated.Send data over a network using internally set ByteBufferstatic longsendfile(long sock, long file, byte[][] headers, byte[][] trailers, long offset, long len, int flags) Deprecated.Send a file from an open file descriptor to a socket, along with optional headers and trailers.static longsendfilen(long sock, long file, long offset, long len, int flags) Deprecated.Send a file without header and trailer arrays.static intsendib(long sock, ByteBuffer buf, int offset, int len) Deprecated.Send data over a network without retrystatic intsendibb(long sock, int offset, int len) Deprecated.Send data over a network using internally set ByteBuffer without internal retry.static intsendto(long sock, long where, int flags, byte[] buf, int offset, int len) Deprecated.static intsendv(long sock, byte[][] vec) Deprecated.Send multiple packets of data over a network.static voidsetrbb(long sock, ByteBuffer buf) Deprecated.Set internal receive ByteBuffer.static voidsetsbb(long sock, ByteBuffer buf) Deprecated.Set internal send ByteBuffer.static intshutdown(long thesocket, int how) Deprecated.Shutdown either reading, writing, or both sides of a socket.static longtimeoutGet(long sock) Deprecated.Query socket timeout for the specified socketstatic inttimeoutSet(long sock, long t) Deprecated.Setup socket timeout for the specified socket
- 
Field Details- 
SOCK_STREAMpublic static final int SOCK_STREAMDeprecated.- See Also:
 
- 
SOCK_DGRAMpublic static final int SOCK_DGRAMDeprecated.- See Also:
 
- 
APR_SO_LINGERpublic static final int APR_SO_LINGERDeprecated.Linger- See Also:
 
- 
APR_SO_KEEPALIVEpublic static final int APR_SO_KEEPALIVEDeprecated.Keepalive- See Also:
 
- 
APR_SO_DEBUGpublic static final int APR_SO_DEBUGDeprecated.Debug- See Also:
 
- 
APR_SO_NONBLOCKpublic static final int APR_SO_NONBLOCKDeprecated.Non-blocking IO- See Also:
 
- 
APR_SO_REUSEADDRpublic static final int APR_SO_REUSEADDRDeprecated.Reuse addresses- See Also:
 
- 
APR_SO_SNDBUFpublic static final int APR_SO_SNDBUFDeprecated.Send buffer- See Also:
 
- 
APR_SO_RCVBUFpublic static final int APR_SO_RCVBUFDeprecated.Receive buffer- See Also:
 
- 
APR_SO_DISCONNECTEDpublic static final int APR_SO_DISCONNECTEDDeprecated.Disconnected- See Also:
 
- 
APR_TCP_NODELAYpublic static final int APR_TCP_NODELAYDeprecated.For SCTP sockets, this is mapped to STCP_NODELAY internally.- See Also:
 
- 
APR_TCP_NOPUSHpublic static final int APR_TCP_NOPUSHDeprecated.No push- See Also:
 
- 
APR_RESET_NODELAYpublic static final int APR_RESET_NODELAYDeprecated.This flag is ONLY set internally when we set APR_TCP_NOPUSH with APR_TCP_NODELAY set to tell us that APR_TCP_NODELAY should be turned on again when NOPUSH is turned off- See Also:
 
- 
APR_INCOMPLETE_READpublic static final int APR_INCOMPLETE_READDeprecated.Set on non-blocking sockets (timeout != 0) on which the previous read() did not fill a buffer completely. the next apr_socket_recv() will first call select()/poll() rather than going straight into read(). (Can also be set by an application to force a select()/poll() call before the next read, in cases where the app expects that an immediate read would fail.)- See Also:
 
- 
APR_INCOMPLETE_WRITEpublic static final int APR_INCOMPLETE_WRITEDeprecated.like APR_INCOMPLETE_READ, but for write- See Also:
 
- 
APR_IPV6_V6ONLYpublic static final int APR_IPV6_V6ONLYDeprecated.Don't accept IPv4 connections on an IPv6 listening socket.- See Also:
 
- 
APR_TCP_DEFER_ACCEPTpublic static final int APR_TCP_DEFER_ACCEPTDeprecated.Delay accepting of new connections until data is available.- See Also:
 
- 
APR_SHUTDOWN_READpublic static final int APR_SHUTDOWN_READDeprecated.no longer allow read request- See Also:
 
- 
APR_SHUTDOWN_WRITEpublic static final int APR_SHUTDOWN_WRITEDeprecated.no longer allow write requests- See Also:
 
- 
APR_SHUTDOWN_READWRITEpublic static final int APR_SHUTDOWN_READWRITEDeprecated.no longer allow read or write requests- See Also:
 
- 
APR_IPV4_ADDR_OKpublic static final int APR_IPV4_ADDR_OKDeprecated.- See Also:
 
- 
APR_IPV6_ADDR_OKpublic static final int APR_IPV6_ADDR_OKDeprecated.- See Also:
 
- 
APR_UNSPECpublic static final int APR_UNSPECDeprecated.- See Also:
 
- 
APR_INETpublic static final int APR_INETDeprecated.- See Also:
 
- 
APR_INET6public static final int APR_INET6Deprecated.- See Also:
 
- 
APR_UNIXpublic static final int APR_UNIXDeprecated.- See Also:
 
- 
APR_PROTO_TCPpublic static final int APR_PROTO_TCPDeprecated.TCP- See Also:
 
- 
APR_PROTO_UDPpublic static final int APR_PROTO_UDPDeprecated.UDP- See Also:
 
- 
APR_PROTO_SCTPpublic static final int APR_PROTO_SCTPDeprecated.SCTP- See Also:
 
- 
APR_LOCALpublic static final int APR_LOCALDeprecated.Enum to tell us if we're interested in remote or local socket apr_interface_e- See Also:
 
- 
APR_REMOTEpublic static final int APR_REMOTEDeprecated.- See Also:
 
- 
SOCKET_GET_POOLpublic static final int SOCKET_GET_POOLDeprecated.- See Also:
 
- 
SOCKET_GET_IMPLpublic static final int SOCKET_GET_IMPLDeprecated.- See Also:
 
- 
SOCKET_GET_APRSpublic static final int SOCKET_GET_APRSDeprecated.- See Also:
 
- 
SOCKET_GET_TYPEpublic static final int SOCKET_GET_TYPEDeprecated.- See Also:
 
 
- 
- 
Constructor Details- 
Socketpublic Socket()Deprecated.
 
- 
- 
Method Details- 
createDeprecated.Create a socket.- Parameters:
- family- The address family of the socket (e.g., APR_INET).
- type- The type of the socket (e.g., SOCK_STREAM).
- protocol- The protocol of the socket (e.g., APR_PROTO_TCP).
- cont- The parent pool to use
- Returns:
- The new socket that has been set up.
- Throws:
- Exception- Error creating socket
 
- 
shutdownpublic static int shutdown(long thesocket, int how) Deprecated.Shutdown either reading, writing, or both sides of a socket.
 This does not actually close the socket descriptor, it just controls which calls are still valid on the socket.- Parameters:
- thesocket- The socket to close
- how- How to shutdown the socket. One of:- APR_SHUTDOWN_READ no longer allow read requests APR_SHUTDOWN_WRITE no longer allow write requests APR_SHUTDOWN_READWRITE no longer allow read or write requests 
- Returns:
- the operation status
 
- 
closepublic static int close(long thesocket) Deprecated.Close a socket.- Parameters:
- thesocket- The socket to close
- Returns:
- the operation status
 
- 
destroypublic static void destroy(long thesocket) Deprecated.Destroy a pool associated with socket- Parameters:
- thesocket- The destroy
 
- 
bindpublic static int bind(long sock, long sa) Deprecated.Bind the socket to its associated port- Parameters:
- sock- The socket to bind
- sa- The socket address to bind to This may be where we will find out if there is any other process using the selected port.
- Returns:
- the operation status
 
- 
listenpublic static int listen(long sock, int backlog) Deprecated.Listen to a bound socket for connections.- Parameters:
- sock- The socket to listen on
- backlog- The number of outstanding connections allowed in the sockets listen queue. If this value is less than zero, the listen queue size is set to zero.
- Returns:
- the operation status
 
- 
acceptxDeprecated.Accept a new connection request- Parameters:
- sock- The socket we are listening on.
- pool- The pool for the new socket.
- Returns:
- A copy of the socket that is connected to the socket that made the connection request. This is the socket which should be used for all future communication.
- Throws:
- Exception- Socket accept error
 
- 
acceptDeprecated.Accept a new connection request- Parameters:
- sock- The socket we are listening on.
- Returns:
- A copy of the socket that is connected to the socket that made the connection request. This is the socket which should be used for all future communication.
- Throws:
- Exception- Socket accept error
 
- 
acceptfilterDeprecated.Set an OS level accept filter.- Parameters:
- sock- The socket to put the accept filter on.
- name- The accept filter
- args- Any extra args to the accept filter. Passing NULL here removes the accept filter.
- Returns:
- the operation status
 
- 
atmarkpublic static boolean atmark(long sock) Deprecated.Query the specified socket if at the OOB/Urgent data mark- Parameters:
- sock- The socket to query
- Returns:
- trueif socket is at the OOB/urgent mark, otherwise- false.
 
- 
connectpublic static int connect(long sock, long sa) Deprecated.Issue a connection request to a socket either on the same machine or a different one.- Parameters:
- sock- The socket we wish to use for our side of the connection
- sa- The address of the machine we wish to connect to.
- Returns:
- the operation status
 
- 
sendpublic static int send(long sock, byte[] buf, int offset, int len) Deprecated.Send data over a network.This functions acts like a blocking write by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. It is possible for both bytes to be sent and an error to be returned. APR_EINTR is never returned. - Parameters:
- sock- The socket to send the data over.
- buf- The buffer which contains the data to be sent.
- offset- Offset in the byte buffer.
- len- The number of bytes to write; (-1) for full array.
- Returns:
- The number of bytes sent
 
- 
sendbDeprecated.Send data over a network.This functions acts like a blocking write by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. It is possible for both bytes to be sent and an error to be returned. APR_EINTR is never returned. - Parameters:
- sock- The socket to send the data over.
- buf- The Byte buffer which contains the data to be sent.
- offset- The offset within the buffer array of the first buffer from which bytes are to be retrieved; must be non-negative and no larger than buf.length
- len- The maximum number of buffers to be accessed; must be non-negative and no larger than buf.length - offset
- Returns:
- The number of bytes sent
 
- 
sendibDeprecated.Send data over a network without retryThis functions acts like a blocking write by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. It is possible for both bytes to be sent and an error to be returned. - Parameters:
- sock- The socket to send the data over.
- buf- The Byte buffer which contains the data to be sent.
- offset- The offset within the buffer array of the first buffer from which bytes are to be retrieved; must be non-negative and no larger than buf.length
- len- The maximum number of buffers to be accessed; must be non-negative and no larger than buf.length - offset
- Returns:
- The number of bytes sent
 
- 
sendbbpublic static int sendbb(long sock, int offset, int len) Deprecated.Send data over a network using internally set ByteBuffer- Parameters:
- sock- The socket to send the data over.
- offset- The offset within the buffer array of the first buffer from which bytes are to be retrieved; must be non-negative and no larger than buf.length
- len- The maximum number of buffers to be accessed; must be non-negative and no larger than buf.length - offset
- Returns:
- The number of bytes sent
 
- 
sendibbpublic static int sendibb(long sock, int offset, int len) Deprecated.Send data over a network using internally set ByteBuffer without internal retry.- Parameters:
- sock- The socket to send the data over.
- offset- The offset within the buffer array of the first buffer from which bytes are to be retrieved; must be non-negative and no larger than buf.length
- len- The maximum number of buffers to be accessed; must be non-negative and no larger than buf.length - offset
- Returns:
- The number of bytes sent
 
- 
sendvpublic static int sendv(long sock, byte[][] vec) Deprecated.Send multiple packets of data over a network.This functions acts like a blocking write by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. The number of bytes actually sent is stored in argument 3. It is possible for both bytes to be sent and an error to be returned. APR_EINTR is never returned. - Parameters:
- sock- The socket to send the data over.
- vec- The array from which to get the data to send.
- Returns:
- The number of bytes sent
 
- 
sendtopublic static int sendto(long sock, long where, int flags, byte[] buf, int offset, int len) Deprecated.- Parameters:
- sock- The socket to send from
- where- The apr_sockaddr_t describing where to send the data
- flags- The flags to use
- buf- The data to send
- offset- Offset in the byte buffer.
- len- The length of the data to send
- Returns:
- The number of bytes sent
 
- 
recvpublic static int recv(long sock, byte[] buf, int offset, int nbytes) Deprecated.Read data from a network.This functions acts like a blocking read by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. The number of bytes actually received is stored in argument 3. It is possible for both bytes to be received and an APR_EOF or other error to be returned. APR_EINTR is never returned. - Parameters:
- sock- The socket to read the data from.
- buf- The buffer to store the data in.
- offset- Offset in the byte buffer.
- nbytes- The number of bytes to read (-1) for full array.
- Returns:
- the number of bytes received.
 
- 
recvtpublic static int recvt(long sock, byte[] buf, int offset, int nbytes, long timeout) Deprecated.Read data from a network with timeout.This functions acts like a blocking read by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. The number of bytes actually received is stored in argument 3. It is possible for both bytes to be received and an APR_EOF or other error to be returned. APR_EINTR is never returned. - Parameters:
- sock- The socket to read the data from.
- buf- The buffer to store the data in.
- offset- Offset in the byte buffer.
- nbytes- The number of bytes to read (-1) for full array.
- timeout- The socket timeout in microseconds.
- Returns:
- the number of bytes received.
 
- 
recvbDeprecated.Read data from a network.This functions acts like a blocking read by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. The number of bytes actually received is stored in argument 3. It is possible for both bytes to be received and an APR_EOF or other error to be returned. APR_EINTR is never returned. - Parameters:
- sock- The socket to read the data from.
- buf- The buffer to store the data in.
- offset- Offset in the byte buffer.
- nbytes- The number of bytes to read (-1) for full array.
- Returns:
- If ≥ 0, the return value is the number of bytes read. Note a
         non-blocking read with no data current available will return
         Status.EAGAINand EOF will returnStatus.APR_EOF.
 
- 
recvbbpublic static int recvbb(long sock, int offset, int nbytes) Deprecated.Read data from a network using internally set ByteBuffer.- Parameters:
- sock- The socket to read the data from.
- offset- Offset in the byte buffer.
- nbytes- The number of bytes to read (-1) for full array.
- Returns:
- If > 0, the return value is the number of bytes read. If == 0,
         the return value indicates EOF and if < 0 the return value is the
         error code. Note a non-blocking read with no data current
         available will return Status.EAGAINnot zero.
 
- 
recvbtDeprecated.Read data from a network with timeout.This functions acts like a blocking read by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. The number of bytes actually received is stored in argument 3. It is possible for both bytes to be received and an APR_EOF or other error to be returned. APR_EINTR is never returned. - Parameters:
- sock- The socket to read the data from.
- buf- The buffer to store the data in.
- offset- Offset in the byte buffer.
- nbytes- The number of bytes to read (-1) for full array.
- timeout- The socket timeout in microseconds.
- Returns:
- the number of bytes received.
 
- 
recvbbtpublic static int recvbbt(long sock, int offset, int nbytes, long timeout) Deprecated.Read data from a network with timeout using internally set ByteBuffer- Parameters:
- sock- The socket to read the data from.
- offset- Offset in the byte buffer.
- nbytes- The number of bytes to read (-1) for full array.
- timeout- The socket timeout in microseconds.
- Returns:
- the number of bytes received.
 
- 
recvfrompublic static int recvfrom(long from, long sock, int flags, byte[] buf, int offset, int nbytes) Deprecated.- Parameters:
- from- The apr_sockaddr_t to fill in the recipient info
- sock- The socket to use
- flags- The flags to use
- buf- The buffer to use
- offset- Offset in the byte buffer.
- nbytes- The number of bytes to read (-1) for full array.
- Returns:
- the number of bytes received.
 
- 
optSetpublic static int optSet(long sock, int opt, int on) Deprecated.Setup socket options for the specified socket- Parameters:
- sock- The socket to set up.
- opt- The option we would like to configure. One of:- APR_SO_DEBUG -- turn on debugging information APR_SO_KEEPALIVE -- keep connections active APR_SO_LINGER -- lingers on close if data is present APR_SO_NONBLOCK -- Turns blocking on/off for socket When this option is enabled, use the APR_STATUS_IS_EAGAIN() macro to see if a send or receive function could not transfer data without blocking. APR_SO_REUSEADDR -- The rules used in validating addresses supplied to bind should allow reuse of local addresses. APR_SO_SNDBUF -- Set the SendBufferSize APR_SO_RCVBUF -- Set the ReceiveBufferSize
- on- Value for the option.
- Returns:
- the operation status
 
- 
optGetDeprecated.Query socket options for the specified socket- Parameters:
- sock- The socket to query
- opt- The option we would like to query. One of:- APR_SO_DEBUG -- turn on debugging information APR_SO_KEEPALIVE -- keep connections active APR_SO_LINGER -- lingers on close if data is present APR_SO_NONBLOCK -- Turns blocking on/off for socket APR_SO_REUSEADDR -- The rules used in validating addresses supplied to bind should allow reuse of local addresses. APR_SO_SNDBUF -- Set the SendBufferSize APR_SO_RCVBUF -- Set the ReceiveBufferSize APR_SO_DISCONNECTED -- Query the disconnected state of the socket. (Currently only used on Windows)
- Returns:
- Socket option returned on the call.
- Throws:
- Exception- An error occurred
 
- 
timeoutSetpublic static int timeoutSet(long sock, long t) Deprecated.Setup socket timeout for the specified socket- Parameters:
- sock- The socket to set up.
- t- Value for the timeout in microseconds.- t > 0 -- read and write calls return APR_TIMEUP if specified time elapses with no data read or written t == 0 -- read and write calls never block t < 0 -- read and write calls block
- Returns:
- the operation status
 
- 
timeoutGet
- 
sendfilepublic static long sendfile(long sock, long file, byte[][] headers, byte[][] trailers, long offset, long len, int flags) Deprecated.Send a file from an open file descriptor to a socket, along with optional headers and trailers.
 This functions acts like a blocking write by default. To change this behavior, use apr_socket_timeout_set() or the APR_SO_NONBLOCK socket option. The number of bytes actually sent is stored in the len parameter. The offset parameter is passed by reference for no reason; its value will never be modified by the apr_socket_sendfile() function.- Parameters:
- sock- The socket to which we're writing
- file- The open file from which to read
- headers- Array containing the headers to send
- trailers- Array containing the trailers to send
- offset- Offset into the file where we should begin writing
- len- Number of bytes to send from the file
- flags- APR flags that are mapped to OS specific flags
- Returns:
- Number of bytes actually sent, including headers, file, and trailers
 
- 
sendfilenpublic static long sendfilen(long sock, long file, long offset, long len, int flags) Deprecated.Send a file without header and trailer arrays.- Parameters:
- sock- The socket to which we're writing
- file- The open file from which to read
- offset- Offset into the file where we should begin writing
- len- Number of bytes to send from the file
- flags- APR flags that are mapped to OS specific flags
- Returns:
- Number of bytes actually sent
 
- 
pool
- 
setsbbDeprecated.Set internal send ByteBuffer. This function will preset internal Java ByteBuffer for consecutive sendbb calls.- Parameters:
- sock- The socket to use
- buf- The ByteBuffer
 
- 
setrbbDeprecated.Set internal receive ByteBuffer. This function will preset internal Java ByteBuffer for consecutive revcvbb/recvbbt calls.- Parameters:
- sock- The socket to use
- buf- The ByteBuffer
 
- 
dataSet
- 
dataGet
 
-