将从数据库中查询出的数据,按照字段排序,数据之间以 "|"分隔,存储到文本文件中,上传到指定的服务器

下面分两种方法来进行实现:SFTP 和 FTP,一般使用 SFTP

SFTP

SFTP 需要引入包

<dependency>
    <groupId>commons-net</groupId>
    <artifactId>commons-net</artifactId>
    <version>3.8.0</version>
</dependency>

<dependency>
	<groupId>com.jcraft</groupId>
	<artifactId>jsch</artifactId>
	<version>0.1.55</version>
</dependency>
public static void main(String[] args) {
	// sb 为查询出来的数据转换成的字符串
    ByteArrayInputStream inputStream = new ByteArrayInputStream(sb.toString().getBytes());
    boolean success = uploadFileSFTP("xxx.xxx.xxx.xxx", 22, "root", "root", "/home/data", "/20210626", "test.txt", inputStream);
    log.info("文件上传成功");
}
/**
 * 向FTP服务器上传文件
 *
 * @param host     FTP服务器ip
 * @param port     FTP服务器端口
 * @param username FTP登录账号
 * @param password FTP登录密码
 * @param basePath FTP服务器基础目录,/home/data
 * @param filePath FTP服务器文件存放路径
 * @param filename 上传到FTP服务器上的文件名
 * @param input    输入流
 * @return 成功返回true,否则返回false
 */
private boolean uploadFileSFTP(String host, int port, String username, String password, String basePath,
                               String filePath, String filename, InputStream inputStream) {
    boolean result;
    FTPClient ftp = new FTPClient();
    try {
        JSch jsch = new JSch();
        // 获取sshSession  账号-ip-端口
        Session sshSession = jsch.getSession(username, host, port);
        // 添加密码
        sshSession.setPassword(password);
        Properties sshConfig = new Properties();
        // 严格主机密钥检查
        sshConfig.put("StrictHostKeyChecking", "no");
        sshSession.setConfig(sshConfig);
        // 开启sshSession链接
        sshSession.connect();
        // 获取sftp通道
        Channel channel = sshSession.openChannel("sftp");
        // 开启
        channel.connect();
        ChannelSftp sftp = (ChannelSftp) channel;
        // 设置为被动模式
        ftp.enterLocalPassiveMode();
        // 设置上传文件的类型为二进制类型
        ftp.setFileType(FTPClient.BINARY_FILE_TYPE);
        // 进入到要上传的目录  然后上传文件
        sftp.cd(basePath + filePath);
        // sftp put为上传,get为下载,之后会出一篇下载的代码
        sftp.put(inputStream, filename);
        inputStream.close();
        result = true;
    } catch (Exception e) {
        log.error("FTP服务器 文件上传失败 失败原因:{}", e.getMessage(), e);
        result = false;
    } finally {
        if (ftp.isConnected()) {
            try {
                ftp.disconnect();
            } catch (IOException e) {
                log.error("FTP服务器 关闭失败 失败原因:{}", e.getMessage(), e);
            }
        }
    }
    return result;
}

FTP

FTP需要引入的包

<dependency>
    <groupId>commons-net</groupId>
    <artifactId>commons-net</artifactId>
    <version>3.8.0</version>
</dependency>
/**
 * @param url      FTP服务器hostname
 * @param port     FTP服务器端口
 * @param username FTP登录账号
 * @param password FTP登录密码
 * @param path     FTP服务器保存目录
 * @param filename 文件名 6403_APP_YYYYMMDD_渠道标志_批次号.txt
 * @param input    输入流
 * @return
 */
private boolean uploadFileFTP(String url, int port, String username, String password,
                              String path, String filename, InputStream inputStream) {
    boolean success;
    FTPClient ftp = new FTPClient();
    try {
        int reply;
        // 链接 FTP 服务器
        // 如果采用默认端口,可以使用ftp.connect(url)的方式直接连接FTP服务器
        ftp.connect(url, port);
        // 登录
        ftp.login(username, password);
        // 返回链接码
        reply = ftp.getReplyCode();
        // 设置文件格式为二进制类型
        ftp.setFileType(FTPClient.BINARY_FILE_TYPE);
        if (!FTPReply.isPositiveCompletion(reply)) {
            ftp.disconnect();
            log.info("FTP服务器 拒绝连接");
            return false;
        }
        // 跳转到指定的目录路径
        ftp.changeWorkingDirectory(path);
        // 存储文件
        ftp.storeFile(filename, inputStream);
        inputStream.close();
        ftp.logout();
        success = true;
    } catch (IOException e) {
        log.error("FTP服务器 文件上传失败 失败原因:{}", e.getMessage(), e);
        return false;
    } finally {
        if (ftp.isConnected()) {
            try {
                ftp.disconnect();
            } catch (IOException e) {
                log.error("FTP服务器 关闭失败 失败原因:{}", e.getMessage(), e);
            }
        }
    }
    return success;
}

FTP上传会出现一个

MalformedServerReplyException: Could not parse response code