Added in API level 1

SocketHandler

open class SocketHandler : StreamHandler

Simple network logging Handler.

LogRecords are published to a network stream connection. By default the XMLFormatter class is used for formatting.

Configuration: By default each SocketHandler is initialized using the following LogManager configuration properties where <handler-name> refers to the fully-qualified class name of the handler. If properties are not defined (or have invalid values) then the specified default values are used.

  • <handler-name>.level specifies the default level for the Handler (defaults to Level.ALL).
  • <handler-name>.filter specifies the name of a Filter class to use (defaults to no Filter).
  • <handler-name>.formatter specifies the name of a Formatter class to use (defaults to java.util.logging.XMLFormatter).
  • <handler-name>.encoding the name of the character set encoding to use (defaults to the default platform encoding).
  • <handler-name>.host specifies the target host name to connect to (no default).
  • <handler-name>.port specifies the target TCP port to use (no default).

For example, the properties for SocketHandler would be:

  • java.util.logging.SocketHandler.level=INFO
  • java.util.logging.SocketHandler.formatter=java.util.logging.SimpleFormatter

For a custom handler, e.g. com.foo.MyHandler, the properties would be:

  • com.foo.MyHandler.level=INFO
  • com.foo.MyHandler.formatter=java.util.logging.SimpleFormatter

The output IO stream is buffered, but is flushed after each LogRecord is written.

Summary

Public constructors

Create a SocketHandler, using only LogManager properties (or their defaults).

SocketHandler(host: String!, port: Int)

Construct a SocketHandler using a specified host and port.

Public methods
open Unit

Close this output stream.

open Unit
publish(record: LogRecord!)

Format and publish a LogRecord.

Inherited functions
Unit flush()

Flush any buffered messages.

Boolean isLoggable(record: LogRecord!)

Check if this Handler would actually log a given LogRecord.

This method checks if the LogRecord has an appropriate level and whether it satisfies any Filter. It will also return false if no output stream has been assigned yet or the LogRecord is null.

Unit setEncoding(encoding: String!)

Set (or change) the character encoding used by this Handler.

The encoding should be set before any LogRecords are written to the Handler.

Unit setOutputStream(out: OutputStream!)

Change the output stream.

If there is a current output stream then the Formatter's tail string is written and the stream is flushed and closed. Then the output stream is replaced with the new output stream.

String! getEncoding()

Return the character encoding for this Handler.

ErrorManager! getErrorManager()

Retrieves the ErrorManager for this Handler.

Filter! getFilter()

Get the current Filter for this Handler.

Formatter! getFormatter()

Return the Formatter for this Handler.

Level! getLevel()

Get the log level specifying which messages will be logged by this Handler. Message levels lower than this level will be discarded.

Unit reportError(msg: String!, ex: Exception!, code: Int)

Protected convenience method to report an error to this Handler's ErrorManager. Note that this method retrieves and uses the ErrorManager without doing a security check. It can therefore be used in environments where the caller may be non-privileged.

Unit setErrorManager(em: ErrorManager!)

Define an ErrorManager for this Handler.

The ErrorManager's "error" method will be invoked if any errors occur while using this Handler.

Unit setFilter(newFilter: Filter!)

Set a Filter to control output on this Handler.

For each call of publish the Handler will call this Filter (if it is non-null) to check if the LogRecord should be published or discarded.

Unit setFormatter(newFormatter: Formatter!)

Set a Formatter. This Formatter will be used to format LogRecords for this Handler.

Some Handlers may not use Formatters, in which case the Formatter will be remembered, but not used.

Unit setLevel(newLevel: Level!)

Set the log level specifying which message levels will be logged by this Handler. Message levels lower than this value will be discarded.

The intention is to allow developers to turn on voluminous logging, but to limit the messages that are sent to certain Handlers.

Public constructors

SocketHandler

Added in API level 1
SocketHandler()

Create a SocketHandler, using only LogManager properties (or their defaults).

Exceptions
java.lang.IllegalArgumentException if the host or port are invalid or are not specified as LogManager properties.
java.io.IOException if we are unable to connect to the target host and port.

SocketHandler

Added in API level 1
SocketHandler(
    host: String!,
    port: Int)

Construct a SocketHandler using a specified host and port. The SocketHandler is configured based on LogManager properties (or their default values) except that the given target host and port arguments are used. If the host argument is empty, but not null String then the localhost is used.

Parameters
host String!: target host.
port Int: target port.
Exceptions
java.lang.IllegalArgumentException if the host or port are invalid.
java.io.IOException if we are unable to connect to the target host and port.

Public methods

close

Added in API level 1
open fun close(): Unit

Close this output stream.

Exceptions
java.lang.SecurityException if a security manager exists and if the caller does not have LoggingPermission("control").

publish

Added in API level 1
open fun publish(record: LogRecord!): Unit

Format and publish a LogRecord.

Parameters
record LogRecord!: description of the log event. A null record is silently ignored and is not published