1、Maven引入jar

 <dependency>
<groupId>com.jcraft</groupId>
<artifactId>jsch</artifactId>
<version>0.1.54</version>
</dependency>

2、Test类

package com.tandaima.pub;

import java.io.*;
import java.util.Properties; import com.jcraft.jsch.*; /**
* User longpizi
* Date: 2019/10/30
* Time: 14:40
*/
public class SftpUtil {
public static final String CHANNELTYPE_SFTP="sftp";
public static final String CHANNELTYPE_EXEC="exec";
private Session session;//会话
private Channel channel;//连接通道
private ChannelSftp sftp;// sftp操作类
private JSch jsch;
protected static String host=getLinuxParam()[0];
protected static String port=getLinuxParam()[1];
protected static String user=getLinuxParam()[2];
protected static String password=getLinuxParam()[3]; private static String[] getLinuxParam(){
Properties props=new Properties();//读取文件类型创建对象。
try {
ClassLoader classLoader = SftpUtil.class.getClassLoader();// 读取属性文件
InputStream in = classLoader.getResourceAsStream("linux.properties");
props.load(in); /// 加载属性列表
if(in!=null){
in.close();
}
} catch (Exception e) {
System.out.println("Linux连接参数异常:"+e.getMessage());
}
String[] str={"","","",""};
str[0]=props.getProperty("file.host");
str[1]=props.getProperty("file.port");
str[2]=props.getProperty("file.user");
str[3]=props.getProperty("file.password");
return str;
}
/**
* 断开连接
*/
public static void closeConnect(Session session, Channel channel, ChannelSftp sftp){
if (null != sftp) {
sftp.disconnect();
sftp.exit();
sftp = null;
}
if (null != channel) {
channel.disconnect();
channel = null;
}
if (null != session) {
session.disconnect();
session = null;
}
System.out.println("连接已关闭");
} /**
* 连接ftp/sftp服务器
*
* @param sftpUtil 类
*/
public static void getConnect(SftpUtil sftpUtil,String openChannelType) throws Exception {
Session session = null;
Channel channel = null; JSch jsch = new JSch();
session = jsch.getSession(user, host, Integer.parseInt(port));
session.setPassword(password);
// 设置第一次登陆的时候提示,可选值:(ask | yes | no)
// 不验证 HostKey
session.setConfig("StrictHostKeyChecking", "no");
try {
session.connect();
} catch (Exception e) {
if (session.isConnected())
session.disconnect();
System.out.println("连接服务器失败");
}
channel = session.openChannel(openChannelType);
try {
channel.connect();
} catch (Exception e) {
if (channel.isConnected())
channel.disconnect();
System.out.println("连接服务器失败");
}
sftpUtil.setJsch(jsch);
if(openChannelType.equals(CHANNELTYPE_SFTP)){
sftpUtil.setSftp((ChannelSftp) channel);
}
sftpUtil.setChannel(channel);
sftpUtil.setSession(session); } /**
* 上传文件
*
* @param directory 上传的目录-相对于SFPT设置的用户访问目录
* @param uploadFile 要上传的文件全路径
*/
public static boolean upload(String directory, String uploadFile) {
boolean resultState=false;
SftpUtil sftpUtil = new SftpUtil();
try{
getConnect(sftpUtil,CHANNELTYPE_SFTP);//建立连接
Session session = sftpUtil.getSession();
Channel channel = sftpUtil.getChannel();
ChannelSftp sftp = sftpUtil.getSftp();// sftp操作类
try {
sftp.cd(directory); //进入目录
} catch (SftpException sException) {
if (ChannelSftp.SSH_FX_NO_SUCH_FILE == sException.id) { //指定上传路径不存在
sftp.mkdir(directory);//创建目录
sftp.cd(directory); //进入目录
}
}
File file = new File(uploadFile);
InputStream in = new FileInputStream(file);
sftp.put(in, file.getName());
in.close();
closeConnect(session, channel, sftp);
resultState=true;
}catch (Exception e){
System.out.println("上传文件异常");
}
return resultState;
} /**
* 获取已连接的Sftp
* @return SftpUtil
*/
public static SftpUtil getConnectSftp(){
SftpUtil sftpUtil=new SftpUtil();
try {
getConnect(sftpUtil,CHANNELTYPE_SFTP);//建立连接
return sftpUtil;
}catch (Exception e){
System.out.println("下载文件异常");
}
return null;
} /**
* 删除文件
* @param directory 要删除文件所在目录
* @param deleteFile 要删除的文件
*/
public static boolean delete(String directory, String deleteFile){
boolean resultState=false;
SftpUtil sftpUtil=new SftpUtil();
try {
getConnect(sftpUtil,CHANNELTYPE_SFTP);//建立连接
Session session = sftpUtil.getSession();
Channel channel = sftpUtil.getChannel();
ChannelSftp sftp = sftpUtil.getSftp();// sftp操作类
sftp.cd(directory); //进入的目录应该是要删除的目录的上一级
sftp.rm(deleteFile);//删除目录
closeConnect(session,channel,sftp);
resultState=true;
}catch (Exception e){
System.out.println("删除文件异常");
}
return resultState;
} /**
JSch有三种文件传输模式:
(1)OVERWRITE:完全覆盖模式。JSch的默认文件传输模式,传输的文件将覆盖目标文件。
(2)APPEND:追加模式。如果目标文件已存在,则在目标文件后追加。
(3)RESUME:恢复模式。如果文件正在传输时,由于网络等原因导致传输中断,则下一次传输相同的文件
时,会从上一次中断的地方续传。
*/
/**
* 追加文件内容
* @param remoteFile 原文件路径
* @param in 追加内容
* @return true成功,false失败
*/
public static boolean appendFileContent(String remoteFile, InputStream in){
boolean resultState=false;
SftpUtil sftpUtil = new SftpUtil();
try{
getConnect(sftpUtil,CHANNELTYPE_SFTP);//建立连接
Session session = sftpUtil.getSession();
Channel channel = sftpUtil.getChannel();
ChannelSftp sftp = sftpUtil.getSftp();// sftp操作类
OutputStream out = sftp.put(remoteFile, ChannelSftp.APPEND);
int bufferSize=1024;
byte[] buff = new byte[bufferSize]; // 设定每次传输的数据块大小
int read;
if (out != null) {
do {
read = in.read(buff, 0, buff.length);
if (read > 0) {
out.write(buff, 0, read);
}
out.flush();
} while (read >= 0);
}
if(out!=null){
out.close();
}
closeConnect(session, channel, sftp);
resultState=true;
}catch (Exception e){
System.out.println("写入文件异常");
}
return resultState;
} /**
* 创建文件
* @param fileDir 文件路径
* @param fileName 文件名称
* @return
*/
public static boolean createFile(String fileDir,String fileName){
try{
execute("mkdir -p "+fileDir+"\n" +
"touch "+fileDir+"/"+fileName);
}catch (Exception e){
return false;
}
return true;
} /**
* 创建文件夹
* @param fileDir 文件路径
* @return true成功/false失败
*/
public static boolean createFileDir(String fileDir){
try{
execute("mkdir -p "+fileDir+"");
}catch (Exception e){
return false;
}
return true;
} /**
* 压缩文件夹为ZIP
* @param fileDir 文件路径
* @param fileName 文件名称
* @param additionalName 压缩附加名
* @return
*/
public static boolean zipDir(String fileDir,String fileName,String additionalName){
try{
execute("cd "+fileDir+"\n" +
"zip -r "+fileDir+"/"+fileName+additionalName+".zip "+fileName);
}catch (Exception e){
return false;
}
return true;
} /**
* 获取文件大小 单位(K)
* @param fileDir 文件路径
* @return 文件大小
*/
public static long getFileSize(String fileDir){
return Long.parseLong(execute("ls -l "+fileDir+" | awk '{ print $5 }'"));
}
/**
* 执行liunx 命令
* @param command 命令内容
* @return 命令输出
*/
private static String execute(String command){
SftpUtil sftpUtil=new SftpUtil();
StringBuffer strBuffer=new StringBuffer();
try {
getConnect(sftpUtil,CHANNELTYPE_EXEC);
// Create and connect session.
Session session = sftpUtil.getSession(); // Create and connect channel.
Channel channel = session.openChannel("exec");
((ChannelExec) channel).setCommand(command); channel.setInputStream(null);
BufferedReader input = new BufferedReader(new InputStreamReader(channel
.getInputStream())); channel.connect();
System.out.println("命令: " + command);
// 获取命令的输出
String line;
while ((line = input.readLine()) != null) {
strBuffer.append(line);
}
input.close();
closeConnect(session,channel,null);
} catch (Exception e) {
e.printStackTrace();
}
return strBuffer.toString();
}
// public static void main(String[] args) throws FileNotFoundException {
// String window_dir="C:\\Users\XXX\\Desktop\\test\\test.txt";
// String liunx_dir="/usr/local/longpizi";
// try {
//// System.out.println(upload(liunx_dir,window_dir));
//// System.out.println(download(liunx_dir,"test.txt","C:\\Users\\XXX\\Desktop\\test"));
//// System.out.println(delete(liunx_dir,"test.txt"));
//
//// InputStream inputStream = new ByteArrayInputStream("this is test".getBytes());
//// System.out.println(appendFileContent(liunx_dir+"/test.txt",inputStream));
//
//// String command="touch /usr/local/longlin/longpizi.sh\nmkdir -p sss";
//// System.out.println(execute(command));
//
//// System.out.println(createFile("/usr/local/longlin/test/sfdsfdf","sss.txt"));
// } catch (Exception e) {
// e.printStackTrace();
// }
// } public JSch getJsch() {
return jsch;
} public void setJsch(JSch jsch) {
this.jsch = jsch;
} public Session getSession() {
return session;
} public void setSession(Session session) {
this.session = session;
} public Channel getChannel() {
return channel;
} public void setChannel(Channel channel) {
this.channel = channel;
} public ChannelSftp getSftp() {
return sftp;
} public void setSftp(ChannelSftp sftp) {
this.sftp = sftp;
}
}

Java使用Sftp实现对跨服务器上传、下载、打包、写入相关操作的更多相关文章

  1. .NET文件跨服务器上传下载

    环境说明:两台服务器服务器为A,服务器为B,服务器B为文件服务器 1.在A和B上创建用户docshareuser,用户名和密码保持一致 2.B服务器上设置附件文件夹Attachments共享,添加用户 ...

  2. jersey实现跨服务器上传

    1.导入跨服务器上传文件jar文件 <dependency> <groupId>commons-io</groupId> <artifactId>com ...

  3. 关于nutz跨服务器上传文件

    关于nutz跨服务器上传文件  发布于 578天前  作者 yong9664  770 次浏览  复制  上一个帖子  下一个帖子  标签: 无 是这样的,项目在一台服务器,文件要存储到另外一台服务器 ...

  4. 阶段3 3.SpringMVC·_05.文件上传_5 文件上传之跨服务器上传分析和搭建环境

    使用这个jar包来跨服务器上传 搞两个tomcat.一个springmvc一个fileupload 选中tomcat server点击左边的加号 需要改端口和JMX pport这个端口 部署文件上传的 ...

  5. idea 内置tomcat jersey 跨服务器 上传文件报400错误

    报错内容 com.sun.jersey.api.client.UniformInterfaceException: PUT http://.jpg returned a response status ...

  6. Android连接socket服务器上传下载多个文件

    android连接socket服务器上传下载多个文件1.socket服务端SocketServer.java public class SocketServer { ;// 端口号,必须与客户端一致 ...

  7. 向linux服务器上传下载文件方式收集

    向linux服务器上传下载文件方式收集 1. scp [优点]简单方便,安全可靠:支持限速参数[缺点]不支持排除目录[用法] scp就是secure copy,是用来进行远程文件拷贝的.数据传输使用 ...

  8. Linux下不借助工具实现远程linux服务器上传下载文件

    # Linux下不借助工具实现远程linux服务器上传下载文件 ## 简介 - Linux下自带ssh工具,可以实现远程Linux服务器的功能- Linux下自带scp工具,可以实现文件传输功能 ## ...

  9. 【转】Android 服务器之SFTP服务器上传下载功能 -- 不错

    原文网址:http://blog.csdn.net/tanghua0809/article/details/47056327 本文主要是讲解Android服务器之SFTP服务器的上传下载功能,也是对之 ...

随机推荐

  1. php.laravel.log

    看代码,原厂代码写的比较清楚,版本(laravel5.7) 简单使用,方便调试,详细使用需要详细查看文档. 在config/app.php 添加 'log' => env('APP_LOG', ...

  2. 第二阶段scrum-5

    1.整个团队的任务量: 2.任务看板: 会议照片: 产品状态: 注册登陆界面功能正在实装,前端制作完成 数据库配置中

  3. tomcat conf目录下server.xml详解

    一.   一个server.xml配置实例 1 <Server port="8005" shutdown="SHUTDOWN"> 2 <Lis ...

  4. 经验分享:如何搞定Personal Statement?

    最近又到申请季啦,如何自己DIY申请,如何准备文书成为众多留学生关心的问题.不管是你申请本科,硕士,还是博士,相信这篇文章都能帮助到你.下面来说一下文书中一个很重要的组成,就是个人陈述Personal ...

  5. 实验吧-密码学-try them all(加salt的密码)、robomunication(摩斯电码)、The Flash-14(闪电侠14集)

    try them all(加salt的密码) 首先,要了解什么事加salt的密码. 加salt是一种密码安全保护措施,就是你输入密码,系统随机生成一个salt值,然后对密码+salt进行哈希散列得到加 ...

  6. JAVA中序列化和反序列化中的静态成员问题

    关于这个标题的内容是面试笔试中比较常见的考题,大家跟随我的博客一起来学习下这个过程. ? ? JAVA中的序列化和反序列化主要用于: (1)将对象或者异常等写入文件,通过文件交互传输信息: (2)将对 ...

  7. python爬取网页文本、图片

    从网页爬取文本信息: eg:从http://computer.swu.edu.cn/s/computer/kxyj2xsky/中爬取讲座信息(讲座时间和讲座名称) 注:如果要爬取的内容是多页的话,网址 ...

  8. Docker 搭建开源 CMDB平台 “OpsManage” 之 Redis

    整体结构如下图   先来在 172.16.0.200 安装docker-ce (新)或 docker-io(旧)      0: Docker-ce  (新版本  Docker version 17. ...

  9. opencv 矩阵操作

    OpenCv矩阵操作 有很多函数有mask,代表掩码,如果某位mask是0,那么对应的src的那一位就不计算,mask要和矩阵/ROI/的大小相等 大多数函数支持ROI,如果图像ROI被设置,那么只处 ...

  10. 2. Jetson TX2--python3下编译安装opencv3.4

    https://cloud.tencent.com/developer/article/1327273 jetpack3.2自带了opencv3.3,但是只提供了python2.7的编译版本,所以也只 ...