You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@commons.apache.org by "Nicolas Leclerc (JIRA)" <ji...@apache.org> on 2015/06/18 13:59:00 UTC
[jira] [Created] (NET-574) FTPClient.mlistFile returns null
timestamps in FTPFile.getTimestamp
Nicolas Leclerc created NET-574:
-----------------------------------
Summary: FTPClient.mlistFile returns null timestamps in FTPFile.getTimestamp
Key: NET-574
URL: https://issues.apache.org/jira/browse/NET-574
Project: Commons Net
Issue Type: Bug
Components: FTP
Affects Versions: 3.3
Environment: On Debian linux with proftpd server
Reporter: Nicolas Leclerc
In FTPClient mlistFile("test.txt") :
{code:title=FTPClient.java|borderStyle=solid}
public FTPFile mlistFile(String pathname) throws IOException
{
boolean success = FTPReply.isPositiveCompletion(sendCommand(FTPCmd.MLST, pathname));
if (success){
String entry = getReplyStrings()[1].substring(1); // skip leading space for parser
return MLSxEntryParser.parseEntry(entry);
} else {
return null;
}
}
{code}
getReplyStrings() return :
250-Start of list for test.txt
250-modify=20150616133640;perm=adfrw;size=83752220;type=file;unique=23U8FE039C;UNIX.group=32;UNIX.mode=0644;UNIX.owner=2005; /data/test.txt
250 End of list
So getReplyStrings()[1].substring(1) return
50-modify=20150616133640;perm=adfrw;size=83752220;type=file;unique=23U8FE039C;UNIX.group=32;UNIX.mode=0644;UNIX.owner=2005; /data/test.txt
{code:title=MLSxEntryParser.java|borderStyle=solid}
public FTPFile parseFTPEntry(String entry) {
String parts[] = entry.split(" ",2); // Path may contain space
if (parts.length != 2) {
return null;
}
FTPFile file = new FTPFile();
file.setRawListing(entry);
file.setName(parts[1]);
String[] facts = parts[0].split(";");
boolean hasUnixMode = parts[0].toLowerCase(Locale.ENGLISH).contains("unix.mode=");
for(String fact : facts) {
String []factparts = fact.split("=");
// Sample missing permission
// drwx------ 2 mirror mirror 4096 Mar 13 2010 subversion
// modify=20100313224553;perm=;type=dir;unique=811U282598;UNIX.group=500;UNIX.mode=0700;UNIX.owner=500; subversion
if (factparts.length != 2) {
continue; // nothing to do here
}
String factname = factparts[0].toLowerCase(Locale.ENGLISH);
String factvalue = factparts[1];
String valueLowerCase = factvalue.toLowerCase(Locale.ENGLISH);
if ("size".equals(factname)) {
file.setSize(Long.parseLong(factvalue));
}
else if ("sizd".equals(factname)) { // Directory size
file.setSize(Long.parseLong(factvalue));
}
else if ("modify".equals(factname)) {
(...)
{code}
50-modify not correspond to modify, so the parser not find the date
Possible patch :
{code:title=FTPClient.java|borderStyle=solid}
public FTPFile mlistFile(String pathname) throws IOException
{
boolean success = FTPReply.isPositiveCompletion(sendCommand(FTPCmd.MLST, pathname));
if (success){
String entry = getReplyStrings()[1].substring(4); // skip leading
(...)
{code}
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)