Class FTPClientConfig
- java.lang.Object
-
- org.apache.commons.net.ftp.FTPClientConfig
-
public class FTPClientConfig extends java.lang.Object
This class implements an alternate means of configuring the
FTPClient
object and also subordinate objects which it uses. Any class implementing theConfigurable
interface can be configured by this object.In particular this class was designed primarily to support configuration of FTP servers which express file timestamps in formats and languages other than those for the US locale, which although it is the most common is not universal. Unfortunately, nothing in the FTP spec allows this to be determined in an automated way, so manual configuration such as this is necessary.
This functionality was designed to allow existing clients to work exactly as before without requiring use of this component. This component should only need to be explicitly invoked by the user of this package for problem cases that previous implementations could not solve.
Examples of use of FTPClientConfig
Use cases: You are trying to access a server that- lists files with timestamps that use month names in languages other than English
- lists files with timestamps that use date formats other
than the American English "standard"
MM dd yyyy
- is in different timezone and you need accurate timestamps for dependency checking as in Ant
Unpaged (whole list) access on a UNIX server that uses French month names but uses the "standard"
MMM d yyyy
date formattingFTPClient f=FTPClient(); FTPClientConfig conf = new FTPClientConfig(FTPClientConfig.SYST_UNIX); conf.setServerLanguageCode("fr"); f.configure(conf); f.connect(server); f.login(username, password); FTPFile[] files = listFiles(directory);
Paged access on a UNIX server that uses Danish month names and "European" date formatting in Denmark's time zone, when you are in some other time zone.
FTPClient f=FTPClient(); FTPClientConfig conf = new FTPClientConfig(FTPClientConfig.SYST_UNIX); conf.setServerLanguageCode("da"); conf.setDefaultDateFormat("d MMM yyyy"); conf.setRecentDateFormat("d MMM HH:mm"); conf.setTimeZoneId("Europe/Copenhagen"); f.configure(conf); f.connect(server); f.login(username, password); FTPListParseEngine engine = f.initiateListParsing("com.whatever.YourOwnParser", directory); while (engine.hasNext()) { FTPFile[] files = engine.getNext(25); // "page size" you want //do whatever you want with these files, display them, etc. //expensive FTPFile objects not created until needed. }
Unpaged (whole list) access on a VMS server that uses month names in a language not
supported
by the system. but uses the "standard"MMM d yyyy
date formattingFTPClient f=FTPClient(); FTPClientConfig conf = new FTPClientConfig(FTPClientConfig.SYST_VMS); conf.setShortMonthNames( "jan|feb|mar|apr|maí|jún|júl|ágú|sep|okt|nóv|des"); f.configure(conf); f.connect(server); f.login(username, password); FTPFile[] files = listFiles(directory);
Unpaged (whole list) access on a Windows-NT server in a different time zone. (Note, since the NT Format uses numeric date formatting, language issues are irrelevant here).
FTPClient f=FTPClient(); FTPClientConfig conf = new FTPClientConfig(FTPClientConfig.SYST_NT); conf.setTimeZoneId("America/Denver"); f.configure(conf); f.connect(server); f.login(username, password); FTPFile[] files = listFiles(directory);
Unpaged (whole list) access on a Windows-NT server in a different time zone but which has been configured to use a unix-style listing format.FTPClient f=FTPClient(); FTPClientConfig conf = new FTPClientConfig(FTPClientConfig.SYST_UNIX); conf.setTimeZoneId("America/Denver"); f.configure(conf); f.connect(server); f.login(username, password); FTPFile[] files = listFiles(directory);
- Since:
- 1.4
- See Also:
Configurable
,FTPClient
,FTPTimestampParserImpl.configure(FTPClientConfig)
,ConfigurableFTPFileEntryParserImpl
-
-
Field Summary
Fields Modifier and Type Field Description static java.lang.String
SYST_AS400
Identifier by which an AS/400-based ftp server is known throughout the commons-net ftp system.static java.lang.String
SYST_L8
Some servers return an "UNKNOWN Type: L8" message in response to the SYST command.static java.lang.String
SYST_MACOS_PETER
Identifier by which a Mac pre OS-X -based ftp server is known throughout the commons-net ftp system.static java.lang.String
SYST_MVS
Identifier by which an MVS-based ftp server is known throughout the commons-net ftp system.static java.lang.String
SYST_NETWARE
Identifier by which an Netware-based ftp server is known throughout the commons-net ftp system.static java.lang.String
SYST_NT
Identifier by which a WindowsNT-based ftp server is known throughout the commons-net ftp system.static java.lang.String
SYST_OS2
Identifier by which an OS/2-based ftp server is known throughout the commons-net ftp system.static java.lang.String
SYST_OS400
Identifier by which an OS/400-based ftp server is known throughout the commons-net ftp system.static java.lang.String
SYST_UNIX
Identifier by which a unix-based ftp server is known throughout the commons-net ftp system.static java.lang.String
SYST_UNIX_TRIM_LEADING
Identifier for alternate UNIX parser; same asSYST_UNIX
but leading spaces are trimmed from file names.static java.lang.String
SYST_VMS
Identifier by which a vms-based ftp server is known throughout the commons-net ftp system.
-
Constructor Summary
Constructors Constructor Description FTPClientConfig()
Convenience constructor mainly for use in testing.FTPClientConfig(java.lang.String systemKey)
The main constructor for an FTPClientConfig objectFTPClientConfig(java.lang.String systemKey, java.lang.String defaultDateFormatStr, java.lang.String recentDateFormatStr)
Constructor which allows setting of the format string member fieldsFTPClientConfig(java.lang.String systemKey, java.lang.String defaultDateFormatStr, java.lang.String recentDateFormatStr, java.lang.String serverLanguageCode, java.lang.String shortMonthNames, java.lang.String serverTimeZoneId)
Constructor which allows setting of most member fieldsFTPClientConfig(java.lang.String systemKey, java.lang.String defaultDateFormatStr, java.lang.String recentDateFormatStr, java.lang.String serverLanguageCode, java.lang.String shortMonthNames, java.lang.String serverTimeZoneId, boolean lenientFutureDates, boolean saveUnparseableEntries)
Constructor which allows setting of all member fieldsFTPClientConfig(FTPClientConfig config)
Copy constructor
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static java.text.DateFormatSymbols
getDateFormatSymbols(java.lang.String shortmonths)
Returns a DateFormatSymbols object configured with short month names as in the supplied stringjava.lang.String
getDefaultDateFormatStr()
getter for thedefaultDateFormatStr
property.java.lang.String
getRecentDateFormatStr()
getter for therecentDateFormatStr
property.java.lang.String
getServerLanguageCode()
getter for theserverLanguageCode
property.java.lang.String
getServerSystemKey()
Getter for the serverSystemKey property.java.lang.String
getServerTimeZoneId()
getter for theserverTimeZoneId
property.java.lang.String
getShortMonthNames()
getter for theshortMonthNames
property.static java.util.Collection<java.lang.String>
getSupportedLanguageCodes()
Returns a Collection of all the language codes currently supported by this class.boolean
getUnparseableEntries()
boolean
isLenientFutureDates()
getter for thelenientFutureDates
property.static java.text.DateFormatSymbols
lookupDateFormatSymbols(java.lang.String languageCode)
Looks up the supplied language code in the internally maintained table of language codes.void
setDefaultDateFormatStr(java.lang.String defaultDateFormatStr)
setter for the defaultDateFormatStr property.void
setLenientFutureDates(boolean lenientFutureDates)
setter for the lenientFutureDates property.void
setRecentDateFormatStr(java.lang.String recentDateFormatStr)
setter for the recentDateFormatStr property.void
setServerLanguageCode(java.lang.String serverLanguageCode)
setter for the serverLanguageCode property.void
setServerTimeZoneId(java.lang.String serverTimeZoneId)
setter for the serverTimeZoneId property.void
setShortMonthNames(java.lang.String shortMonthNames)
setter for the shortMonthNames property.void
setUnparseableEntries(boolean saveUnparseable)
Allow list parsing methods to create basic FTPFile entries if parsing fails.
-
-
-
Field Detail
-
SYST_UNIX
public static final java.lang.String SYST_UNIX
Identifier by which a unix-based ftp server is known throughout the commons-net ftp system.- See Also:
- Constant Field Values
-
SYST_UNIX_TRIM_LEADING
public static final java.lang.String SYST_UNIX_TRIM_LEADING
Identifier for alternate UNIX parser; same asSYST_UNIX
but leading spaces are trimmed from file names. This is to maintain backwards compatibility with the original behaviour of the parser which ignored multiple spaces between the date and the start of the file name.- Since:
- 3.4
- See Also:
- Constant Field Values
-
SYST_VMS
public static final java.lang.String SYST_VMS
Identifier by which a vms-based ftp server is known throughout the commons-net ftp system.- See Also:
- Constant Field Values
-
SYST_NT
public static final java.lang.String SYST_NT
Identifier by which a WindowsNT-based ftp server is known throughout the commons-net ftp system.- See Also:
- Constant Field Values
-
SYST_OS2
public static final java.lang.String SYST_OS2
Identifier by which an OS/2-based ftp server is known throughout the commons-net ftp system.- See Also:
- Constant Field Values
-
SYST_OS400
public static final java.lang.String SYST_OS400
Identifier by which an OS/400-based ftp server is known throughout the commons-net ftp system.- See Also:
- Constant Field Values
-
SYST_AS400
public static final java.lang.String SYST_AS400
Identifier by which an AS/400-based ftp server is known throughout the commons-net ftp system.- See Also:
- Constant Field Values
-
SYST_MVS
public static final java.lang.String SYST_MVS
Identifier by which an MVS-based ftp server is known throughout the commons-net ftp system.- See Also:
- Constant Field Values
-
SYST_L8
public static final java.lang.String SYST_L8
Some servers return an "UNKNOWN Type: L8" message in response to the SYST command. We set these to be a Unix-type system. This may happen if the ftpd in question was compiled without system information. NET-230 - Updated to be UPPERCASE so that the check done in createFileEntryParser will succeed.- Since:
- 1.5
- See Also:
- Constant Field Values
-
SYST_NETWARE
public static final java.lang.String SYST_NETWARE
Identifier by which an Netware-based ftp server is known throughout the commons-net ftp system.- Since:
- 1.5
- See Also:
- Constant Field Values
-
SYST_MACOS_PETER
public static final java.lang.String SYST_MACOS_PETER
Identifier by which a Mac pre OS-X -based ftp server is known throughout the commons-net ftp system.- Since:
- 3.1
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
FTPClientConfig
public FTPClientConfig(java.lang.String systemKey)
The main constructor for an FTPClientConfig object- Parameters:
systemKey
- key representing system type of the server being connected to. SeeserverSystemKey
If set to the empty string, then FTPClient uses the system type returned by the server. However this is not recommended for general use; the correct system type should be set if it is known.
-
FTPClientConfig
public FTPClientConfig()
Convenience constructor mainly for use in testing. Constructs a UNIX configuration.
-
FTPClientConfig
public FTPClientConfig(java.lang.String systemKey, java.lang.String defaultDateFormatStr, java.lang.String recentDateFormatStr)
Constructor which allows setting of the format string member fields- Parameters:
systemKey
- key representing system type of the server being connected to. SeeserverSystemKey
defaultDateFormatStr
- SeedefaultDateFormatStr
recentDateFormatStr
- SeerecentDateFormatStr
- Since:
- 3.6
-
FTPClientConfig
public FTPClientConfig(java.lang.String systemKey, java.lang.String defaultDateFormatStr, java.lang.String recentDateFormatStr, java.lang.String serverLanguageCode, java.lang.String shortMonthNames, java.lang.String serverTimeZoneId)
Constructor which allows setting of most member fields- Parameters:
systemKey
- key representing system type of the server being connected to. SeeserverSystemKey
defaultDateFormatStr
- SeedefaultDateFormatStr
recentDateFormatStr
- SeerecentDateFormatStr
serverLanguageCode
- SeeserverLanguageCode
shortMonthNames
- SeeshortMonthNames
serverTimeZoneId
- SeeserverTimeZoneId
-
FTPClientConfig
public FTPClientConfig(java.lang.String systemKey, java.lang.String defaultDateFormatStr, java.lang.String recentDateFormatStr, java.lang.String serverLanguageCode, java.lang.String shortMonthNames, java.lang.String serverTimeZoneId, boolean lenientFutureDates, boolean saveUnparseableEntries)
Constructor which allows setting of all member fields- Parameters:
systemKey
- key representing system type of the server being connected to. SeeserverSystemKey
defaultDateFormatStr
- SeedefaultDateFormatStr
recentDateFormatStr
- SeerecentDateFormatStr
serverLanguageCode
- SeeserverLanguageCode
shortMonthNames
- SeeshortMonthNames
serverTimeZoneId
- SeeserverTimeZoneId
lenientFutureDates
- SeelenientFutureDates
saveUnparseableEntries
- SeesaveUnparseableEntries
-
FTPClientConfig
public FTPClientConfig(FTPClientConfig config)
Copy constructor- Parameters:
config
- source- Since:
- 3.6
-
-
Method Detail
-
getServerSystemKey
public java.lang.String getServerSystemKey()
Getter for the serverSystemKey property. This property specifies the general type of server to which the client connects. Should be either one of theFTPClientConfig.SYST_*
codes or else the fully qualified class name of a parser implementing both theFTPFileEntryParser
andConfigurable
interfaces.- Returns:
- Returns the serverSystemKey property.
-
getDefaultDateFormatStr
public java.lang.String getDefaultDateFormatStr()
getter for thedefaultDateFormatStr
property.- Returns:
- Returns the defaultDateFormatStr property.
-
getRecentDateFormatStr
public java.lang.String getRecentDateFormatStr()
getter for therecentDateFormatStr
property.- Returns:
- Returns the recentDateFormatStr property.
-
getServerTimeZoneId
public java.lang.String getServerTimeZoneId()
getter for theserverTimeZoneId
property.- Returns:
- Returns the serverTimeZoneId property.
-
getShortMonthNames
public java.lang.String getShortMonthNames()
getter for the
shortMonthNames
property.- Returns:
- Returns the shortMonthNames.
-
getServerLanguageCode
public java.lang.String getServerLanguageCode()
getter for the
serverLanguageCode
property.- Returns:
- Returns the serverLanguageCode property.
-
isLenientFutureDates
public boolean isLenientFutureDates()
getter for the
lenientFutureDates
property.- Returns:
- Returns the lenientFutureDates.
- Since:
- 1.5
-
setDefaultDateFormatStr
public void setDefaultDateFormatStr(java.lang.String defaultDateFormatStr)
setter for the defaultDateFormatStr property. This property specifies the main date format that will be used by a parser configured by this configuration to parse file timestamps. If this is not specified, such a parser will use as a default value, the most commonly used format which will be in as used in
en_US
locales.This should be in the format described for
java.text.SimpleDateFormat
. property.- Parameters:
defaultDateFormatStr
- The defaultDateFormatStr to set.
-
setRecentDateFormatStr
public void setRecentDateFormatStr(java.lang.String recentDateFormatStr)
setter for the recentDateFormatStr property. This property specifies a secondary date format that will be used by a parser configured by this configuration to parse file timestamps, typically those less than a year old. If this is not specified, such a parser will not attempt to parse using an alternate format.
This is used primarily in unix-based systems.
This should be in the format described for
java.text.SimpleDateFormat
.- Parameters:
recentDateFormatStr
- The recentDateFormatStr to set.
-
setLenientFutureDates
public void setLenientFutureDates(boolean lenientFutureDates)
setter for the lenientFutureDates property. This boolean property (default: false) only has meaning when a
recentDateFormatStr
property has been set. In that case, if this property is set true, then the parser, when it encounters a listing parseable with the recent date format, will only consider a date to belong to the previous year if it is more than one day in the future. This will allow all out-of-synch situations (whether based on "slop" - i.e. servers simply out of synch with one another or because of time zone differences - but in the latter case it is highly recommended to use theserverTimeZoneId
property instead) to resolve correctly.This is used primarily in unix-based systems.
- Parameters:
lenientFutureDates
- set true to compensate for out-of-synch conditions.
-
setServerTimeZoneId
public void setServerTimeZoneId(java.lang.String serverTimeZoneId)
setter for the serverTimeZoneId property. This property allows a time zone to be specified corresponding to that known to be used by an FTP server in file listings. This might be particularly useful to clients such as Ant that try to use these timestamps for dependency checking.
This should be one of the identifiers used by
java.util.TimeZone
to refer to time zones, for example,America/Chicago
orAsia/Rangoon
.- Parameters:
serverTimeZoneId
- The serverTimeZoneId to set.
-
setShortMonthNames
public void setShortMonthNames(java.lang.String shortMonthNames)
setter for the shortMonthNames property. This property allows the user to specify a set of month names used by the server that is different from those that may be specified using the
serverLanguageCode
property.This should be a string containing twelve strings each composed of three characters, delimited by pipe (|) characters. Currently, only 8-bit ASCII characters are known to be supported. For example, a set of month names used by a hypothetical Icelandic FTP server might conceivably be specified as
"jan|feb|mar|apr|maí|jún|júl|ágú|sep|okt|nóv|des"
.- Parameters:
shortMonthNames
- The value to set to the shortMonthNames property.
-
setServerLanguageCode
public void setServerLanguageCode(java.lang.String serverLanguageCode)
setter for the serverLanguageCode property. This property allows user to specify a two-letter ISO-639 language code that will be used to configure the set of month names used by the file timestamp parser. If neither this nor the
shortMonthNames
is specified, parsing will assume English month names, which may or may not be significant, depending on whether the date format(s) specified viadefaultDateFormatStr
and/orrecentDateFormatStr
are using numeric or alphabetic month names.If the code supplied is not supported here,
en_US
month names will be used. We are supporting here those language codes which, when ajava.util.Locale
is constucted using it, and ajava.text.SimpleDateFormat
is constructed using that Locale, the array returned by the SimpleDateFormat'sgetShortMonths()
method consists solely of three 8-bit ASCII character strings. Additionally, languages which do not meet this requirement are included if a common alternative set of short month names is known to be used. This means that users who can tell us of additional such encodings may get them added to the list of supported languages by contacting the Apache Commons Net team.Please note that this attribute will NOT be used to determine a locale-based date format for the language. Experience has shown that many if not most FTP servers outside the United States employ the standard
en_US
date format orderings ofMMM d yyyy
andMMM d HH:mm
and attempting to deduce this automatically here would cause more problems than it would solve. The date format must be changed via thedefaultDateFormatStr
and/orrecentDateFormatStr
parameters.- Parameters:
serverLanguageCode
- The value to set to the serverLanguageCode property.
-
lookupDateFormatSymbols
public static java.text.DateFormatSymbols lookupDateFormatSymbols(java.lang.String languageCode)
Looks up the supplied language code in the internally maintained table of language codes. Returns a DateFormatSymbols object configured with short month names corresponding to the code. If there is no corresponding entry in the table, the object returned will be that forLocale.US
- Parameters:
languageCode
- SeeserverLanguageCode
- Returns:
- a DateFormatSymbols object configured with short month names
corresponding to the supplied code, or with month names for
Locale.US
if there is no corresponding entry in the internal table.
-
getDateFormatSymbols
public static java.text.DateFormatSymbols getDateFormatSymbols(java.lang.String shortmonths)
Returns a DateFormatSymbols object configured with short month names as in the supplied string- Parameters:
shortmonths
- This should be as described inshortMonthNames
- Returns:
- a DateFormatSymbols object configured with short month names as in the supplied string
-
getSupportedLanguageCodes
public static java.util.Collection<java.lang.String> getSupportedLanguageCodes()
Returns a Collection of all the language codes currently supported by this class. SeeserverLanguageCode
for a functional descrption of language codes within this system.- Returns:
- a Collection of all the language codes currently supported by this class
-
setUnparseableEntries
public void setUnparseableEntries(boolean saveUnparseable)
Allow list parsing methods to create basic FTPFile entries if parsing fails.In this case, the FTPFile will contain only the unparsed entry
FTPFile.getRawListing()
andFTPFile.isValid()
will returnfalse
- Parameters:
saveUnparseable
- if true, then create FTPFile entries if parsing fails- Since:
- 3.4
-
getUnparseableEntries
public boolean getUnparseableEntries()
- Returns:
- true if list parsing should return FTPFile entries even for unparseable response lines
If true, the FTPFile for any unparseable entries will contain only the unparsed entry
FTPFile.getRawListing()
andFTPFile.isValid()
will returnfalse
- Since:
- 3.4
-
-