1、java使用Jsch实现远程操作linux服务器进行文件上传、下载,删除和显示目录信息。
参考链接:https://www.cnblogs.com/longyg/archive/2012/06/25/2556576.html
https://www.cnblogs.com/longyg/archive/2012/06/25/2561332.html
https://www.cnblogs.com/qdwyg2013/p/5650764.html#top
引入jar包的maven依赖如下所示:
1 <!-- https://mvnrepository.com/artifact/com.jcraft/jsch --> 2 <dependency> 3 <groupId>com.jcraft</groupId> 4 <artifactId>jsch</artifactId> 5 <version>0.1.54</version> 6 </dependency>
具体演示代码如下所示:
1 package com.fline.aic.utils; 2 3 import java.io.BufferedReader; 4 import java.io.File; 5 import java.io.FileInputStream; 6 import java.io.FileNotFoundException; 7 import java.io.IOException; 8 import java.io.InputStream; 9 import java.io.InputStreamReader; 10 import java.util.Properties; 11 import java.util.Vector; 12 13 import com.jcraft.jsch.Channel; 14 import com.jcraft.jsch.ChannelExec; 15 import com.jcraft.jsch.ChannelSftp; 16 import com.jcraft.jsch.JSch; 17 import com.jcraft.jsch.JSchException; 18 import com.jcraft.jsch.Session; 19 import com.jcraft.jsch.SftpException; 20 21 /** 22 * 23 * @Description TODO 24 * @author biehl 25 * @Date 2018年10月11日 上午10:20:11 26 * 27 * 说明:exec用于执行命令;sftp用于文件处理 28 */ 29 public class SSHRemoteCall { 30 31 // 私有的对象 32 private static SSHRemoteCall sshRemoteCall; 33 34 /** 35 * 私有的构造方法 36 */ 37 private SSHRemoteCall() { 38 } 39 40 // 懒汉式,线程不安全,适合单线程 41 public static SSHRemoteCall getInstance() { 42 if (sshRemoteCall == null) { 43 sshRemoteCall = new SSHRemoteCall(); 44 } 45 return sshRemoteCall; 46 } 47 48 // 懒汉式,线程安全,适合多线程 49 public static synchronized SSHRemoteCall getInstance2() { 50 if (sshRemoteCall == null) { 51 sshRemoteCall = new SSHRemoteCall(); 52 } 53 return sshRemoteCall; 54 } 55 56 private static final int DEFAULT_PORT = 22;// 默认端口号 57 private int port;// 端口号 58 59 private static String ipAddress = "192.168.110.130";// ip地址 60 private static String userName = "root";// 账号 61 private static String password = "hadoop";// 密码 62 63 private Session session;// JSCH session 64 private boolean logined = false;// 是否登陆 65 66 /** 67 * 构造方法,可以直接使用DEFAULT_PORT 68 * 69 * @param ipAddress 70 * @param userName 71 * @param password 72 */ 73 public SSHRemoteCall(String ipAddress, String userName, String password) { 74 this(ipAddress, DEFAULT_PORT, userName, password); 75 } 76 77 /** 78 * 构造方法,方便直接传入ipAddress,userName,password进行调用 79 * 80 * @param ipAddress 81 * @param port 82 * @param userName 83 * @param password 84 */ 85 public SSHRemoteCall(String ipAddress, int port, String userName, String password) { 86 super(); 87 this.ipAddress = ipAddress; 88 this.userName = userName; 89 this.password = password; 90 this.port = port; 91 } 92 93 /** 94 * 远程登陆 95 * 96 * @throws Exception 97 */ 98 public void sshRemoteCallLogin(String ipAddress, String userName, String password) throws Exception { 99 // 如果登陆就直接返回 100 if (logined) { 101 return; 102 } 103 // 创建jSch对象 104 JSch jSch = new JSch(); 105 try { 106 // 获取到jSch的session, 根据用户名、主机ip、端口号获取一个Session对象 107 session = jSch.getSession(userName, ipAddress, DEFAULT_PORT); 108 // 设置密码 109 session.setPassword(password); 110 111 // 方式一,通过Session建立连接 112 // session.setConfig("StrictHostKeyChecking", "no"); 113 // session.connect(); 114 115 // 方式二,通过Session建立连接 116 // java.util.Properties; 117 Properties config = new Properties(); 118 config.put("StrictHostKeyChecking", "no"); 119 session.setConfig(config);// 为Session对象设置properties 120 // session.setTimeout(3000);// 设置超时 121 session.connect();//// 通过Session建立连接 122 123 // 设置登陆状态 124 logined = true; 125 } catch (JSchException e) { 126 // 设置登陆状态为false 127 logined = false; 128 throw new Exception( 129 "主机登录失败, IP = " + ipAddress + ", USERNAME = " + userName + ", Exception:" + e.getMessage()); 130 } 131 } 132 133 /** 134 * 关闭连接 135 */ 136 public void closeSession() { 137 // 调用session的关闭连接的方法 138 if (session != null) { 139 // 如果session不为空,调用session的关闭连接的方法 140 session.disconnect(); 141 } 142 143 } 144 145 /** 146 * 执行相关的命令 147 * 148 * @param command 149 * @throws IOException 150 */ 151 public void execCommand(String command) throws IOException { 152 InputStream in = null;// 输入流(读) 153 Channel channel = null;// 定义channel变量 154 try { 155 // 如果命令command不等于null 156 if (command != null) { 157 // 打开channel 158 //说明:exec用于执行命令;sftp用于文件处理 159 channel = session.openChannel("exec"); 160 // 设置command 161 ((ChannelExec) channel).setCommand(command); 162 // channel进行连接 163 channel.connect(); 164 // 获取到输入流 165 in = channel.getInputStream(); 166 // 执行相关的命令 167 String processDataStream = processDataStream(in); 168 // 打印相关的命令 169 System.out.println("1、打印相关返回的命令: " + processDataStream); 170 } 171 } catch (JSchException e) { 172 e.printStackTrace(); 173 } catch (IOException e) { 174 e.printStackTrace(); 175 } catch (Exception e) { 176 e.printStackTrace(); 177 } finally { 178 if (in != null) { 179 in.close(); 180 } 181 if (channel != null) { 182 channel.disconnect(); 183 } 184 } 185 186 } 187 188 /** 189 * 对将要执行的linux的命令进行遍历 190 * 191 * @param in 192 * @return 193 * @throws Exception 194 */ 195 public String processDataStream(InputStream in) throws Exception { 196 StringBuffer sb = new StringBuffer(); 197 BufferedReader br = new BufferedReader(new InputStreamReader(in)); 198 String result = ""; 199 try { 200 while ((result = br.readLine()) != null) { 201 sb.append(result); 202 // System.out.println(sb.toString()); 203 } 204 } catch (Exception e) { 205 throw new Exception("获取数据流失败: " + e); 206 } finally { 207 br.close(); 208 } 209 return sb.toString(); 210 } 211 212 /** 213 * 上传文件 可参考:https://www.cnblogs.com/longyg/archive/2012/06/25/2556576.html 214 * 215 * @param directory 216 * 上传文件的目录 217 * @param uploadFile 218 * 将要上传的文件 219 */ 220 public void uploadFile(String directory, String uploadFile) { 221 try { 222 // 打开channelSftp 223 ChannelSftp channelSftp = (ChannelSftp) session.openChannel("sftp"); 224 // 远程连接 225 channelSftp.connect(); 226 // 创建一个文件名称问uploadFile的文件 227 File file = new File(uploadFile); 228 // 将文件进行上传(sftp协议) 229 // 将本地文件名为src的文件上传到目标服务器,目标文件名为dst,若dst为目录,则目标文件名将与src文件名相同. 230 // 采用默认的传输模式:OVERWRITE 231 channelSftp.put(new FileInputStream(file), directory, ChannelSftp.OVERWRITE); 232 // 切断远程连接 233 channelSftp.exit(); 234 System.out.println("2、" + file.getName() + " 文件上传成功....."); 235 } catch (JSchException e) { 236 e.printStackTrace(); 237 } catch (SftpException e) { 238 e.printStackTrace(); 239 } catch (FileNotFoundException e) { 240 e.printStackTrace(); 241 } 242 243 } 244 245 /** 246 * 下载文件 采用默认的传输模式:OVERWRITE 247 * 248 * @param src 249 * linux服务器文件地址 250 * @param dst 251 * 本地存放地址 252 * @throws JSchException 253 * @throws SftpException 254 */ 255 public void fileDownload(String src, String dst) throws JSchException, SftpException { 256 // src 是linux服务器文件地址,dst 本地存放地址 257 ChannelSftp channelSftp = (ChannelSftp) session.openChannel("sftp"); 258 // 远程连接 259 channelSftp.connect(); 260 // 下载文件,多个重载方法 261 channelSftp.get(src, dst); 262 // 切断远程连接,quit()等同于exit(),都是调用disconnect() 263 channelSftp.quit(); 264 // channelSftp.disconnect(); 265 System.out.println("3、" + src + " ,下载文件成功....."); 266 } 267 268 /** 269 * 删除文件 270 * 271 * @param directory 272 * 要删除文件所在目录 273 * @param deleteFile 274 * 要删除的文件 275 * @param sftp 276 * @throws SftpException 277 * @throws JSchException 278 */ 279 public void deleteFile(String directoryFile) throws SftpException, JSchException { 280 // 打开openChannel的sftp 281 ChannelSftp channelSftp = (ChannelSftp) session.openChannel("sftp"); 282 // 远程连接 283 channelSftp.connect(); 284 // 删除文件 285 channelSftp.rm(directoryFile); 286 // 切断远程连接 287 channelSftp.exit(); 288 System.out.println("4、" + directoryFile + " 删除的文件....."); 289 } 290 291 /** 292 * 列出目录下的文件 293 * 294 * @param directory 295 * 要列出的目录 296 * @param sftp 297 * @return 298 * @throws SftpException 299 * @throws JSchException 300 */ 301 public Vector listFiles(String directory) throws JSchException, SftpException { 302 ChannelSftp channelSftp = (ChannelSftp) session.openChannel("sftp"); 303 // 远程连接 304 channelSftp.connect(); 305 // 显示目录信息 306 Vector ls = channelSftp.ls(directory); 307 System.out.println("5、" + ls); 308 // 切断连接 309 channelSftp.exit(); 310 return ls; 311 } 312 313 public static void main(String[] args) { 314 // 连接到指定的服务器 315 try { 316 // 1、首先远程连接ssh 317 SSHRemoteCall.getInstance().sshRemoteCallLogin(ipAddress, userName, password); 318 // 打印信息 319 System.out.println("0、连接192.168.110.130,ip地址: " + ipAddress + ",账号: " + userName + ",连接成功....."); 320 321 // 2、执行相关的命令 322 // 查看目录信息 323 // String command = "ls /home/hadoop/package "; 324 // 查看文件信息 325 // String command = "cat /home/hadoop/package/test "; 326 // 查看磁盘空间大小 327 // String command = "df -lh "; 328 // 查看cpu的使用情况 329 // String command = "top -bn 1 -i -c "; 330 // 查看内存的使用情况 331 String command = "free "; 332 SSHRemoteCall.getInstance().execCommand(command); 333 334 // 3、上传文件 335 String directory = "/home/hadoop/package/poi.xlsx";// 目标文件名 336 String uploadFile = "E:\\poi.xlsx";// 本地文件名 337 SSHRemoteCall.getInstance().uploadFile(directory, uploadFile); 338 339 // 4、下载文件 340 // src 是linux服务器文件地址,dst 本地存放地址,采用默认的传输模式:OVERWRITE 341 //test为文件名称哈 342 String src = "/home/hadoop/package/test"; 343 String dst = "E:\\"; 344 SSHRemoteCall.getInstance().fileDownload(src, dst); 345 346 // 5、刪除文件 347 String deleteDirectoryFile = "/home/hadoop/package/test"; 348 SSHRemoteCall.getInstance().deleteFile(deleteDirectoryFile); 349 350 // 6、展示目录下的文件信息 351 String lsDirectory = "/home/hadoop/package"; 352 SSHRemoteCall.getInstance().listFiles(lsDirectory); 353 354 // 7、关闭连接 355 SSHRemoteCall.getInstance().closeSession(); 356 } catch (Exception e) { 357 // 打印错误信息 358 System.err.println("远程连接失败......"); 359 e.printStackTrace(); 360 } 361 } 362 363 }
运行效果如下所示:
0、连接192.168.110.130,ip地址: 192.168.110.130,账号: root,连接成功..... 1、打印相关返回的命令: total used free shared buffers cachedMem: 1030616 840144 190472 0 34672 636228-/+ buffers/cache: 169244 861372Swap: 2064376 0 2064376 2、poi.xlsx 文件上传成功..... 3、/home/hadoop/package/test ,下载文件成功..... 4、/home/hadoop/package/test 删除的文件..... 5、[drwxrwxrwx 2 root root 4096 Oct 12 05:37 ., -rw-r--r-- 1 root root 4770 Oct 12 05:37 poi.xlsx, drwx------ 27 hadoop hadoop 4096 Oct 11 21:05 ..]
待续.....
原文地址:https://www.cnblogs.com/biehongli/p/9780652.html
时间: 2024-10-13 23:57:34