[From] http://xpenxpen.iteye.com/blog/2061869

上一篇文章我们成功搭建了sshd服务器,并通过3种方式登陆上了ssh。这一篇我们将用开源jar包jsch来登陆ssh服务器。

1.去官网下载最新的jar包 
jsch-0.1.51.jar

2.运行官方例子 
Shell.java 
演示了如何连接到sshd服务器 
Exec.java 
演示了登陆上去并执行一条命令

注意以上2个例子让你输入密码同样也是输入cyg_server用户的密码 
运行成功后可以看下它的代码。

3.再做一个SFTP试验

  1. import java.io.*;
  2. import java.util.*;
  3. import com.jcraft.jsch.*;
  4. public class Test1 {
  5. public static void main(String[] args) throws Exception {
  6. Test1.sshSftp("127.0.0.1", "Administrator", "cyg_server", 22);
  7. Test1.sshSftp2("127.0.0.1", "Administrator", 22, "C:/Users/Administrator/rsa_my", "");
  8. }
  9. /**
  10. * 利用JSch包实现SFTP下载、上传文件(用户名密码方式登陆)
  11. * @param ip 主机IP
  12. * @param user 主机登陆用户名
  13. * @param psw  主机登陆密码
  14. * @param port 主机ssh2登陆端口,如果取默认值(默认值22),传-1
  15. *
  16. */
  17. public static void sshSftp(String ip, String user, String psw
  18. ,int port) throws Exception{
  19. System.out.println("开始用户名密码方式登陆");
  20. Session session = null;
  21. JSch jsch = new JSch();
  22. if(port <=0){
  23. //连接服务器,采用默认端口
  24. session = jsch.getSession(user, ip);
  25. }else{
  26. //采用指定的端口连接服务器
  27. session = jsch.getSession(user, ip ,port);
  28. }
  29. //如果服务器连接不上,则抛出异常
  30. if (session == null) {
  31. throw new Exception("session is null");
  32. }
  33. //设置登陆主机的密码
  34. session.setPassword(psw);//设置密码
  35. //设置第一次登陆的时候提示,可选值:(ask | yes | no)
  36. session.setConfig("StrictHostKeyChecking", "no");
  37. //设置登陆超时时间
  38. session.connect(30000);
  39. sftp(session, "aa.log");
  40. System.out.println("sftp成功");
  41. }
  42. /**
  43. * 利用JSch包实现SFTP下载、上传文件(秘钥方式登陆)
  44. * @param ip 主机IP
  45. * @param user 主机登陆用户名
  46. * @param port 主机ssh2登陆端口,如果取默认值(默认值22),传-1
  47. * @param privateKey 密钥文件路径
  48. * @param passphrase 密钥的密码
  49. *
  50. */
  51. public static void sshSftp2(String ip, String user
  52. ,int port ,String privateKey ,String passphrase) throws Exception{
  53. System.out.println("开始秘钥方式登陆");
  54. Session session = null;
  55. JSch jsch = new JSch();
  56. //设置密钥和密码
  57. //支持密钥的方式登陆,只需在jsch.getSession之前设置一下密钥的相关信息就可以了
  58. if (privateKey != null && !"".equals(privateKey)) {
  59. if (passphrase != null && "".equals(passphrase)) {
  60. //设置带口令的密钥
  61. jsch.addIdentity(privateKey, passphrase);
  62. } else {
  63. //设置不带口令的密钥
  64. jsch.addIdentity(privateKey);
  65. }
  66. }
  67. if(port <=0){
  68. //连接服务器,采用默认端口
  69. session = jsch.getSession(user, ip);
  70. }else{
  71. //采用指定的端口连接服务器
  72. session = jsch.getSession(user, ip ,port);
  73. }
  74. //如果服务器连接不上,则抛出异常
  75. if (session == null) {
  76. throw new Exception("session is null");
  77. }
  78. //设置第一次登陆的时候提示,可选值:(ask | yes | no)
  79. session.setConfig("StrictHostKeyChecking", "no");
  80. //设置登陆超时时间
  81. session.connect(30000);
  82. sftp(session, "bb.log");
  83. System.out.println("sftp成功");
  84. }
  85. private static void sftp(Session session, String uploadFileName) throws Exception {
  86. Channel channel = null;
  87. try {
  88. //创建sftp通信通道
  89. channel = (Channel) session.openChannel("sftp");
  90. channel.connect(1000);
  91. ChannelSftp sftp = (ChannelSftp) channel;
  92. //进入服务器指定的文件夹
  93. sftp.cd("testsftp");
  94. //列出服务器指定的文件列表
  95. Vector v = sftp.ls("*.txt");
  96. for(int i=0;i<v.size();i++){
  97. System.out.println(v.get(i));
  98. }
  99. //以下代码实现从本地上传一个文件到服务器,如果要实现下载,对换以下流就可以了
  100. OutputStream outstream = sftp.put(uploadFileName);
  101. InputStream instream = new FileInputStream(new File("C:/ftptest/aa.txt"));
  102. byte b[] = new byte[1024];
  103. int n;
  104. while ((n = instream.read(b)) != -1) {
  105. outstream.write(b, 0, n);
  106. }
  107. outstream.flush();
  108. outstream.close();
  109. instream.close();
  110. } catch (Exception e) {
  111. e.printStackTrace();
  112. } finally {
  113. session.disconnect();
  114. channel.disconnect();
  115. }
  116. }
  117. }

代码是引用了http://my.oschina.net/hetiangui/blog/137357 
首先这句sftp.ls("*.txt")是列出指定文件夹下所有txt文件, 
然后sftp.put("3.txt")是上传一个文件到SFTP服务器上。

注意main函数里有2种登陆方式, 
第一种是通过用户名Administrator,密码cyg_server的方式登陆。 
第二种是通过秘钥方式登陆,我们的私钥目录是"C:/Users/Administrator/rsa_my",而passphrase则为空。

最新文章

  1. CMD命令大全
  2. div+css使多行文字垂直居中?
  3. 转:安装MySQL遇到MySQL Server Instance Configuration Wizard未响应的解决办法
  4. oracle—无法启动
  5. MYSQL 5.7 新增150多个新功能
  6. 更新Windows ActiveX,Ios
  7. 【HDOJ】1042 N!
  8. IE8下ckeditor无法正常使用,提示&quot;例外被抛出且未被接住&quot;的解决办法
  9. Android Studio插件之FindBugs
  10. 转-Web Service中三种发送接受协议SOAP、http get、http post
  11. 布隆过滤器(Bloom Filter) 未完待续
  12. [Swift]LeetCode938. 二叉搜索树的范围和 | Range Sum of BST
  13. transient关键字的使用
  14. MongoDB添加仲裁节点报错replica set IDs do not match办法
  15. ftp弱密码案例
  16. jQuery学习--Code Organization Concepts
  17. 什么是虚拟DOM?为啥虚拟DOM可以提升性能?
  18. ssh-keygen生成git ssh密钥
  19. Java遍历文件夹下的所以文件
  20. javaScript错误(一)Cannot call method &#39;addEventListener&#39; of null

热门文章

  1. 利用HttpWebRequest类Post数据至URI
  2. cv 验证
  3. hibernate mapping文件中 xmlns会导致linq to xml 查询不到对应的节点
  4. Oracle——分组函数
  5. Servlet入门第一天
  6. .html与.text的异同
  7. Linux 上安装Gearman及其PHP扩展
  8. SQL聚集索引和非聚集索引的区别
  9. wpf 依赖属性注册解释
  10. DFT到FFT的理解