JAVA远程读取服务器文件

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: JAVA远程读取服务器文件
<dependency>
    <groupId>ch.ethz.ganymed</groupId>
    <artifactId>ganymed-ssh2</artifactId>
    <version>build210</version>
</dependency>
  • 登录远程服务器
public boolean login(){
  //创建远程连接,默认连接端口为22,如果不使用默认,可以使用方法
  //new Connection(ip, port)创建对象
  Connection conn = new Connection(ip);        
  try {
    //连接远程服务器
    conn.connect();
    //使用用户名和密码登录
        return conn.authenticateWithPassword(usr, psword);
  } catch (IOException e) {   
    System.err.printf("用户%s密码%s登录服务器%s失败!", usr, psword, ip);
    e.printStackTrace();
  }
  return false;
}
/**
  * 上传本地文件到服务器目录下
  * @param conn Connection对象
  * @param fileName 本地文件
  * @param remotePath 服务器目录
  */
public void putFile(Connection conn, String fileName, String remotePath){
  SCPClient sc = new SCPClient(conn);
  try {
    //将本地文件放到远程服务器指定目录下,默认的文件模式为 0600,即 rw,
    //如要更改模式,可调用方法 put(fileName, remotePath, mode),模式须是4位数字且以0开头
    sc.put(fileName, remotePath);
  } catch (IOException e) {
    e.printStackTrace();
  }
}
/**
  * 下载服务器文件到本地目录
  * @param fileName 服务器文件
  * @param localPath 本地目录
  */
public void copyFile(Connection conn, String fileName,String localPath){
  SCPClient sc = new SCPClient(conn);
  try {
    sc.get(fileName, localPath);
  } catch (IOException e) {
    e.printStackTrace();
  }
}
/**
     * 获得远程服务器文件夹下所有文件
     *
     * @param remoteDir
     * @param localTargetDirectory
     */
    public void getFiles(String remoteDir, String localTargetDirectory) {
        Connection conn = new Connection(ip, port);
        Connection conn2 = getConn2(ip, port, username, password);
        SFTPv3Client sft = null;
        try {
            conn.connect();
            boolean isAuthenticated = conn.authenticateWithPassword(username, password);
            if (!isAuthenticated) {
                System.err.println("authentication failed");
            }
            SCPClient client = new SCPClient(conn);
            sft = new SFTPv3Client(conn2);
            //获取远程目录下文件列表
            Vector<?> v = sft.ls(remoteDir);
            for (int i = 0; i < v.size(); i++) {
                SFTPv3DirectoryEntry s = (SFTPv3DirectoryEntry) v.get(i);
                if (fileType(s.filename)) {
                    client.get(remoteDir + "/" + s.filename, localTargetDirectory);
                }
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        } finally {
            if (sft != null) {
                sft.close();
            }
            if (conn != null) {
                conn.close();
            }
        }
    }
/**
 * 在远程LINUX服务器上,在指定目录下,获取文件各个属性
 * @param[in] conn Conncetion对象
 * @param[in] remotePath 远程主机的指定目录
 */
public void getFileProperties(Conncetion conn, String remotePath){
  try {
    SFTPv3Client sft = new SFTPv3Client(conn);
    Vector<?> v = sft.ls(remotePath);
    for(int i=0;i<v.size();i++){
      SFTPv3DirectoryEntry s = new SFTPv3DirectoryEntry();
      s = (SFTPv3DirectoryEntry) v.get(i);
      //文件名
      String filename = s.filename;
      //文件的大小
      Long fileSize = s.attributes.size;
    }
    sft.close();
  } catch (Exception e1) {
    e1.printStackTrace();
  }
}
/**
 * 在远程LINUX服务器上,在指定目录下,删除指定文件
 * @param[in] fileName 文件名
 * @param[in] remotePath 远程主机的指定目录
 * @return
 */
public void delFile(String remotePath, String fileName){
  try {
    SFTPv3Client sft = new SFTPv3Client(conn);
    //获取远程目录下文件列表
    Vector<?> v = sft.ls(remotePath);
    for(int i=0;i<v.size();i++){
      SFTPv3DirectoryEntry s = new SFTPv3DirectoryEntry();
      s = (SFTPv3DirectoryEntry) v.get(i);
      //判断列表中文件是否与指定文件名相同
      if(s.filename.equals(fileName)){
        //rm()方法中,须是文件绝对路径+文件名称
        sft.rm(remotePath + s.filename);
      }
    sft.close();
  } catch (Exception e1) {
    e1.printStackTrace();
  }
}
/**
 * 执行脚本
 * @param conn Connection对象
 * @param cmds 要在linux上执行的指令
 */
public int exec(Connection conn, String cmds){
  InputStream stdOut = null;
  InputStream stdErr = null;
  int ret = -1;
  try {
    //在connection中打开一个新的会话
    Session session = conn.openSession();
    //在远程服务器上执行linux指令
    session.execCommand(cmds);
    //指令执行结束后的输出
    stdOut = new StreamGobbler(session.getStdout());
    //指令执行结束后的错误
    stdErr = new StreamGobbler(session.getStderr());
    //等待指令执行结束
    session.waitForCondition(ChannelCondition.EXIT_STATUS, TIME_OUT);
      //取得指令执行结束后的状态
    ret = session.getExitStatus(); 
    conn.close();
  }catch(Exception e){
     e.printStackTrace();
  }
  return ret;
}
  • controller
package com.sun.redis.controller;
import java.io.IOException;
import java.util.Map;
import javax.servlet.http.HttpServletResponse;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.sun.redis.util.FileUtil;
import com.sun.redis.util.LinuxLogin;
@RestController
@RequestMapping("/fileDownCtl")
public class FileDownController {
  @Autowired
  private FileUtil fileUtil;
  @Autowired
  private LinuxLogin linuxLogin;
  @RequestMapping(value="/getFile",method=RequestMethod.GET)
  public void getFile(HttpServletResponse response){
    String path = "D:/Games/WarCraft/BeeWind软件站说明.txt";
    fileUtil.getListFileList(path, response);
  }
  @RequestMapping(value="/getLinuxFile",method=RequestMethod.GET)
  public void getLinuxFile(HttpServletResponse response) throws IOException{
    String fileName = "linux.txt";
    String path = "/home/hadoop/text/";
    linuxLogin.login();
    response.reset();
        response.setContentType("bin");
        response.setContentType("octets/stream");
        response.addHeader("Content-Type", "text/html; charset=utf-8");
        response.addHeader("Content-Disposition", "attachment;filename="+new String(fileName.getBytes("UTF-8"),"ISO8859-1"));
    linuxLogin.copyFile(linuxLogin.conn, path+fileName,response.getOutputStream());
  }
}
  • 工具类
package com.sun.redis.util;
import java.io.IOException;
import java.util.Vector;
import javax.servlet.ServletOutputStream;
import org.springframework.stereotype.Component;
import ch.ethz.ssh2.Connection;
import ch.ethz.ssh2.SCPClient;
import ch.ethz.ssh2.SFTPv3Client;
import ch.ethz.ssh2.SFTPv3DirectoryEntry;
@Component
public class LinuxLogin {
  public static Connection conn = null;
  public  boolean login(){
    //创建远程连接,默认连接端口为22,如果不使用默认,可以使用方法
    //new Connection(ip, port)创建对象
    conn = new Connection("192.168.159.128");        
    try {
      //连接远程服务器
      conn.connect();
      //使用用户名和密码登录
          return conn.authenticateWithPassword("hadoop", "hadoop");
    } catch (IOException e) {   
      System.err.printf("用户%s密码%s登录服务器%s失败!", "hadoop", "hadoop", "192.168.159.128");
      e.printStackTrace();
    }
    return false;
  }
  /**
   * 复制到JAVA所在服务器
   * @param conn
   * @param fileName
   * @param localPath
   */
  public void copyFile(Connection conn, String fileName,String localPath){
    SCPClient sc = new SCPClient(conn);
    try {
      sc.get(fileName, localPath);
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
  /**
   * 流式输出,用于浏览器下载
   * @param conn
   * @param fileName
   * @param outputStream
   */
  public void copyFile(Connection conn, String fileName,ServletOutputStream outputStream){
    SCPClient sc = new SCPClient(conn);
    try {
      sc.get(fileName, outputStream);
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
  /**
   * 在远程LINUX服务器上,在指定目录下,获取文件各个属性
   * @param[in] conn Conncetion对象
   * @param[in] remotePath 远程主机的指定目录
   */
  public void getFileProperties(Connection conn, String remotePath){
    try {
      SFTPv3Client sft = new SFTPv3Client(conn);
      Vector<?> v = sft.ls(remotePath);
      for(int i=0;i<v.size();i++){
        SFTPv3DirectoryEntry s = new SFTPv3DirectoryEntry();
        s = (SFTPv3DirectoryEntry) v.get(i);
        //文件名
        String filename = s.filename;
        //文件的大小
        Long fileSize = s.attributes.size;
      }
      sft.close();
    } catch (Exception e1) {
      e1.printStackTrace();
    }
  }
  public static void main(String args[]){
    LinuxLogin log = new LinuxLogin();
    System.out.println(log.login());
  }
}


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
101 9
|
2月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
110 2
|
3天前
|
存储 安全 网络安全
服务器感染了.baxia勒索病毒,如何确保数据文件完整恢复?
近年来,勒索病毒如.baxia不断演变,利用漏洞、社交工程等手段加密文件,威胁范围扩大。加密货币的兴起使其支付方式更匿名,追踪困难。技术支持尤为重要,添加技术服务号(shuju315),专业团队提供数据恢复方案。面对复杂解密要求,包括赎金支付、个人信息提供和执行特定操作,需保持冷静并寻求帮助。防御措施包括加强安全意识、定期备份数据、安装杀毒软件、避免未知文件、更新系统及制定应急响应计划。
29 11
|
21天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
99 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
1月前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
103 34
|
2天前
|
前端开发 Java 开发工具
Git使用教程-将idea本地Java等文件配置到gitte上【保姆级教程】
本内容详细介绍了使用Git进行版本控制的全过程,涵盖从本地仓库创建到远程仓库配置,以及最终推送代码至远程仓库的步骤。
12 0
|
2月前
|
消息中间件 存储 Java
RocketMQ文件刷盘机制深度解析与Java模拟实现
【11月更文挑战第22天】在现代分布式系统中,消息队列(Message Queue, MQ)作为一种重要的中间件,扮演着连接不同服务、实现异步通信和消息解耦的关键角色。Apache RocketMQ作为一款高性能的分布式消息中间件,广泛应用于实时数据流处理、日志流处理等场景。为了保证消息的可靠性,RocketMQ引入了一种称为“刷盘”的机制,将消息从内存写入到磁盘中,确保消息持久化。本文将从底层原理、业务场景、概念、功能点等方面深入解析RocketMQ的文件刷盘机制,并使用Java模拟实现类似的功能。
55 3
|
2月前
|
Java 测试技术 Maven
Maven clean 提示文件 java.io.IOException
在使用Maven进行项目打包时,遇到了`Failed to delete`错误,尝试手动删除目标文件也失败,提示`java.io.IOException`。经过分析,发现问题是由于`sys-info.log`文件被其他进程占用。解决方法是关闭IDEA和相关Java进程,清理隐藏的Java进程后重新尝试Maven clean操作。最终问题得以解决。总结:遇到此类问题时,可以通过任务管理器清理相关进程或重启电脑来解决。
|
Java 大数据 Apache