public class SCPClient extends Object
SCPClient that can be used to copy files from/to
the SSH-2 server. On the server side, the "scp" program must be in the PATH.
This scp client is thread safe - you can download (and upload) different sets
of files concurrently without any troubles. The SCPClient is
actually mapping every request to a distinct Session.
| Constructor and Description |
|---|
SCPClient(Connection conn) |
| Modifier and Type | Method and Description |
|---|---|
void |
get(String[] remoteFiles,
String localTargetDirectory)
Download a set of files from the remote server to a local directory.
|
void |
get(String remoteFile,
OutputStream target)
Download a file from the remote server and pipe its contents into an
OutputStream. |
void |
get(String remoteFile,
String localTargetDirectory)
Download a file from the remote server to a local directory.
|
void |
put(byte[] data,
String remoteFileName,
String remoteTargetDirectory)
Create a remote file and copy the contents of the passed byte array into
it.
|
void |
put(byte[] data,
String remoteFileName,
String remoteTargetDirectory,
String mode)
Create a remote file and copy the contents of the passed byte array into
it.
|
void |
put(String[] localFiles,
String remoteTargetDirectory)
Copy a set of local files to a remote directory, uses mode 0600 when
creating files on the remote side.
|
void |
put(String[] localFiles,
String[] remoteFiles,
String remoteTargetDirectory,
String mode) |
void |
put(String[] localFiles,
String remoteTargetDirectory,
String mode)
Copy a set of local files to a remote directory, uses the specified mode
when creating the files on the remote side.
|
void |
put(String localFile,
String remoteTargetDirectory)
Copy a local file to a remote directory, uses mode 0600 when creating the
file on the remote side.
|
void |
put(String localFile,
String remoteTargetDirectory,
String mode)
Copy a local file to a remote directory, uses the specified mode when
creating the file on the remote side.
|
void |
put(String localFile,
String remoteFileName,
String remoteTargetDirectory,
String mode)
Copy a local file to a remote directory, uses the specified mode and
remote filename when creating the file on the remote side.
|
public SCPClient(Connection conn)
public void put(String localFile, String remoteTargetDirectory) throws IOException
localFile - Path and name of local file.remoteTargetDirectory - Remote target directory. Use an empty string to specify the
default directory.IOException - the io exceptionpublic void put(String[] localFiles, String remoteTargetDirectory) throws IOException
localFiles - Paths and names of local file names.remoteTargetDirectory - Remote target directory. Use an empty string to specify the
default directory.IOException - the io exceptionpublic void put(String localFile, String remoteTargetDirectory, String mode) throws IOException
localFile - Path and name of local file.remoteTargetDirectory - Remote target directory. Use an empty string to specify the
default directory.mode - a four digit string (e.g., 0644, see "man chmod", "man open")IOException - the io exceptionpublic void put(String localFile, String remoteFileName, String remoteTargetDirectory, String mode) throws IOException
localFile - Path and name of local file.remoteFileName - The name of the file which will be created in the remote
target directory.remoteTargetDirectory - Remote target directory. Use an empty string to specify the
default directory.mode - a four digit string (e.g., 0644, see "man chmod", "man open")IOException - the io exceptionpublic void put(byte[] data,
String remoteFileName,
String remoteTargetDirectory)
throws IOException
data - the data to be copied into the remote file.remoteFileName - The name of the file which will be created in the remote
target directory.remoteTargetDirectory - Remote target directory. Use an empty string to specify the
default directory.IOException - the io exceptionpublic void put(byte[] data,
String remoteFileName,
String remoteTargetDirectory,
String mode)
throws IOException
data - the data to be copied into the remote file.remoteFileName - The name of the file which will be created in the remote
target directory.remoteTargetDirectory - Remote target directory. Use an empty string to specify the
default directory.mode - a four digit string (e.g., 0644, see "man chmod", "man open")IOException - the io exceptionpublic void put(String[] localFiles, String remoteTargetDirectory, String mode) throws IOException
localFiles - Paths and names of the local files.remoteTargetDirectory - Remote target directory. Use an empty string to specify the
default directory.mode - a four digit string (e.g., 0644, see "man chmod", "man open")IOException - the io exceptionpublic void put(String[] localFiles, String[] remoteFiles, String remoteTargetDirectory, String mode) throws IOException
IOExceptionpublic void get(String remoteFile, String localTargetDirectory) throws IOException
remoteFile - Path and name of the remote file.localTargetDirectory - Local directory to put the downloaded file.IOException - the io exceptionpublic void get(String remoteFile, OutputStream target) throws IOException
OutputStream. Please note that, to enable flexible usage
of this method, the OutputStream will not be closed nor
flushed.remoteFile - Path and name of the remote file.target - OutputStream where the contents of the file will be sent to.IOException - the io exceptionpublic void get(String[] remoteFiles, String localTargetDirectory) throws IOException
remoteFiles - Paths and names of the remote files.localTargetDirectory - Local directory to put the downloaded files.IOException - the io exceptionCopyright © 2018. All rights reserved.