- java.lang.Object
- 
- java.util.logging.Handler
- 
- java.util.logging.StreamHandler
- 
- java.util.logging.FileHandler
 
 
 
- 
 public class FileHandler extends StreamHandler Simple file loggingHandler.The FileHandlercan either write to a specified file, or it can write to a rotating set of files.For a rotating set of files, as each file reaches a given size limit, it is closed, rotated out, and a new file opened. Successively older files are named by adding "0", "1", "2", etc. into the base filename. By default buffering is enabled in the IO libraries but each log record is flushed out when it is complete. By default the XMLFormatterclass is used for formatting.Configuration: By default each FileHandleris initialized using the followingLogManagerconfiguration 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 toLevel.ALL).
-    <handler-name>.filter
        specifies the name of a Filterclass to use (defaults to noFilter).
-    <handler-name>.formatter
        specifies the name of a Formatterclass to use (defaults tojava.util.logging.XMLFormatter)
- <handler-name>.encoding the name of the character set encoding to use (defaults to the default platform encoding).
- <handler-name>.limit specifies an approximate maximum amount to write (in bytes) to any one file. If this is zero, then there is no limit. (Defaults to no limit).
- <handler-name>.count specifies how many output files to cycle through (defaults to 1).
- <handler-name>.pattern specifies a pattern for generating the output file name. See below for details. (Defaults to "%h/java%u.log").
- <handler-name>.append specifies whether the FileHandler should append onto any existing files (defaults to false).
- <handler-name>.maxLocks specifies the maximum number of concurrent locks held by FileHandler (defaults to 100).
 For example, the properties for FileHandlerwould be:- java.util.logging.FileHandler.level=INFO
- java.util.logging.FileHandler.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
 A pattern consists of a string that includes the following special components that will be replaced at runtime: - "/" the local pathname separator
- "%t" the system temporary directory
- "%h" the value of the "user.home" system property
- "%g" the generation number to distinguish rotated logs
- "%u" a unique number to resolve conflicts
- "%%" translates to a single percent sign "%"
 Thus for example a pattern of "%t/java%g.log" with a count of 2 would typically cause log files to be written on Solaris to /var/tmp/java0.log and /var/tmp/java1.log whereas on Windows 95 they would be typically written to C:\TEMP\java0.log and C:\TEMP\java1.log Generation numbers follow the sequence 0, 1, 2, etc. Normally the "%u" unique field is set to 0. However, if the FileHandlertries to open the filename and finds the file is currently in use by another process it will increment the unique number field and try again. This will be repeated untilFileHandlerfinds a file name that is not currently in use. If there is a conflict and no "%u" field has been specified, it will be added at the end of the filename after a dot. (This will be after any automatically added generation number.)Thus if three processes were all trying to log to fred%u.%g.txt then they might end up using fred0.0.txt, fred1.0.txt, fred2.0.txt as the first file in their rotating sequences. Note that the use of unique ids to avoid conflicts is only guaranteed to work reliably when using a local disk file system. - Since:
- 1.4
 
-    <handler-name>.level
        specifies the default level for the 
- 
- 
Constructor SummaryConstructors Constructor Description FileHandler()Construct a defaultFileHandler.FileHandler(String pattern)Initialize aFileHandlerto write to the given filename.FileHandler(String pattern, boolean append)Initialize aFileHandlerto write to the given filename, with optional append.FileHandler(String pattern, int limit, int count)Initialize aFileHandlerto write to a set of files.FileHandler(String pattern, int limit, int count, boolean append)Initialize aFileHandlerto write to a set of files with optional append.FileHandler(String pattern, long limit, int count, boolean append)Initialize aFileHandlerto write to a set of files with optional append.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()Close all the files.voidpublish(LogRecord record)Format and publish aLogRecord.- 
Methods declared in class java.util.logging.StreamHandlerflush, isLoggable, setEncoding, setOutputStream
 - 
Methods declared in class java.util.logging.HandlergetEncoding, getErrorManager, getFilter, getFormatter, getLevel, reportError, setErrorManager, setFilter, setFormatter, setLevel
 
- 
 
- 
- 
- 
Constructor Detail- 
FileHandlerpublic FileHandler() throws IOException, SecurityExceptionConstruct a defaultFileHandler. This will be configured entirely fromLogManagerproperties (or their default values).- Throws:
- IOException- if there are IO problems opening the files.
- SecurityException- if a security manager exists and if the caller does not have- LoggingPermission("control")).
- NullPointerException- if pattern property is an empty String.
 
 - 
FileHandlerpublic FileHandler(String pattern) throws IOException, SecurityException Initialize aFileHandlerto write to the given filename.The FileHandleris configured based onLogManagerproperties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to no limit, and the file count is set to one.There is no limit on the amount of data that may be written, so use this with care. - Parameters:
- pattern- the name of the output file
- Throws:
- IOException- if there are IO problems opening the files.
- SecurityException- if a security manager exists and if the caller does not have- LoggingPermission("control").
- IllegalArgumentException- if pattern is an empty string
 
 - 
FileHandlerpublic FileHandler(String pattern, boolean append) throws IOException, SecurityException Initialize aFileHandlerto write to the given filename, with optional append.The FileHandleris configured based onLogManagerproperties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to no limit, the file count is set to one, and the append mode is set to the givenappendargument.There is no limit on the amount of data that may be written, so use this with care. - Parameters:
- pattern- the name of the output file
- append- specifies append mode
- Throws:
- IOException- if there are IO problems opening the files.
- SecurityException- if a security manager exists and if the caller does not have- LoggingPermission("control").
- IllegalArgumentException- if pattern is an empty string
 
 - 
FileHandlerpublic FileHandler(String pattern, int limit, int count) throws IOException, SecurityException Initialize aFileHandlerto write to a set of files. When (approximately) the given limit has been written to one file, another file will be opened. The output will cycle through a set of count files.The FileHandleris configured based onLogManagerproperties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to the limit argument, and the file count is set to the given count argument.The count must be at least 1. - Parameters:
- pattern- the pattern for naming the output file
- limit- the maximum number of bytes to write to any one file
- count- the number of files to use
- Throws:
- IOException- if there are IO problems opening the files.
- SecurityException- if a security manager exists and if the caller does not have- LoggingPermission("control").
- IllegalArgumentException- if- limit < 0, or- count < 1.
- IllegalArgumentException- if pattern is an empty string
 
 - 
FileHandlerpublic FileHandler(String pattern, int limit, int count, boolean append) throws IOException, SecurityException Initialize aFileHandlerto write to a set of files with optional append. When (approximately) the given limit has been written to one file, another file will be opened. The output will cycle through a set of count files.The FileHandleris configured based onLogManagerproperties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to the limit argument, and the file count is set to the given count argument, and the append mode is set to the givenappendargument.The count must be at least 1. - Parameters:
- pattern- the pattern for naming the output file
- limit- the maximum number of bytes to write to any one file
- count- the number of files to use
- append- specifies append mode
- Throws:
- IOException- if there are IO problems opening the files.
- SecurityException- if a security manager exists and if the caller does not have- LoggingPermission("control").
- IllegalArgumentException- if- limit < 0, or- count < 1.
- IllegalArgumentException- if pattern is an empty string
 
 - 
FileHandlerpublic FileHandler(String pattern, long limit, int count, boolean append) throws IOException Initialize aFileHandlerto write to a set of files with optional append. When (approximately) the given limit has been written to one file, another file will be opened. The output will cycle through a set of count files.The FileHandleris configured based onLogManagerproperties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to the limit argument, and the file count is set to the given count argument, and the append mode is set to the givenappendargument.The count must be at least 1. - Parameters:
- pattern- the pattern for naming the output file
- limit- the maximum number of bytes to write to any one file
- count- the number of files to use
- append- specifies append mode
- Throws:
- IOException- if there are IO problems opening the files.
- SecurityException- if a security manager exists and if the caller does not have- LoggingPermission("control").
- IllegalArgumentException- if- limit < 0, or- count < 1.
- IllegalArgumentException- if pattern is an empty string
- Since:
- 9
 
 
- 
 - 
Method Detail- 
publishpublic void publish(LogRecord record) Format and publish aLogRecord.- Overrides:
- publishin class- StreamHandler
- Parameters:
- record- description of the log event. A null record is silently ignored and is not published
 
 - 
closepublic void close() throws SecurityExceptionClose all the files.- Overrides:
- closein class- StreamHandler
- Throws:
- SecurityException- if a security manager exists and if the caller does not have- LoggingPermission("control").
 
 
- 
 
-