`
xpenxpen
  • 浏览: 736277 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Jsch初步

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

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

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

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

3.再做一个SFTP试验

import java.io.*;
import java.util.*;
import com.jcraft.jsch.*;

public class Test1 {
	
	public static void main(String[] args) throws Exception {
		Test1.sshSftp("127.0.0.1", "Administrator", "cyg_server", 22);
		Test1.sshSftp2("127.0.0.1", "Administrator", 22, "C:/Users/Administrator/rsa_my", "");
	}
	
	/**
	 * 利用JSch包实现SFTP下载、上传文件(用户名密码方式登陆)
	 * @param ip 主机IP
	 * @param user 主机登陆用户名
	 * @param psw  主机登陆密码
	 * @param port 主机ssh2登陆端口,如果取默认值(默认值22),传-1
	 * 
	 */
	public static void sshSftp(String ip, String user, String psw 
			,int port) throws Exception{
		System.out.println("开始用户名密码方式登陆");
		Session session = null;
		
		JSch jsch = new JSch();
		
		if(port <=0){
			//连接服务器,采用默认端口
			session = jsch.getSession(user, ip);
		}else{
			//采用指定的端口连接服务器
			session = jsch.getSession(user, ip ,port);
		}

		//如果服务器连接不上,则抛出异常
		if (session == null) {
			throw new Exception("session is null");
		}
		
		//设置登陆主机的密码
		session.setPassword(psw);//设置密码   
		session.setConfig("PreferredAuthentications", "publickey,keyboard-interactive,password");
		//设置第一次登陆的时候提示,可选值:(ask | yes | no)
		session.setConfig("StrictHostKeyChecking", "no");
		//设置登陆超时时间   
		session.connect(30000);
		
		sftp(session, "aa.log");
		System.out.println("sftp成功");
	}
	
	/**
	 * 利用JSch包实现SFTP下载、上传文件(秘钥方式登陆)
	 * @param ip 主机IP
	 * @param user 主机登陆用户名
	 * @param port 主机ssh2登陆端口,如果取默认值(默认值22),传-1
	 * @param privateKey 密钥文件路径
	 * @param passphrase 密钥的密码
	 * 
	 */
	public static void sshSftp2(String ip, String user
			,int port ,String privateKey ,String passphrase) throws Exception{
		System.out.println("开始秘钥方式登陆");
		Session session = null;
		
		JSch jsch = new JSch();
		
		//设置密钥和密码
		//支持密钥的方式登陆,只需在jsch.getSession之前设置一下密钥的相关信息就可以了
		if (privateKey != null && !"".equals(privateKey)) {
	           if (passphrase != null && "".equals(passphrase)) {
	           	//设置带口令的密钥
	               jsch.addIdentity(privateKey, passphrase);
	           } else {
	           	//设置不带口令的密钥
	               jsch.addIdentity(privateKey);
	           }
	    }
		
		
		if(port <=0){
			//连接服务器,采用默认端口
			session = jsch.getSession(user, ip);
		}else{
			//采用指定的端口连接服务器
			session = jsch.getSession(user, ip ,port);
		}

		//如果服务器连接不上,则抛出异常
		if (session == null) {
			throw new Exception("session is null");
		}
		
		//设置第一次登陆的时候提示,可选值:(ask | yes | no)
		session.setConfig("StrictHostKeyChecking", "no");
		//设置登陆超时时间
		session.connect(30000);
		
		sftp(session, "bb.log");
		System.out.println("sftp成功");
	}
	
	private static void sftp(Session session, String uploadFileName) throws Exception {
		Channel channel = null;
		try {
			//创建sftp通信通道
			channel = (Channel) session.openChannel("sftp");
			channel.connect(1000);
			ChannelSftp sftp = (ChannelSftp) channel;
			
			
			//进入服务器指定的文件夹
			sftp.cd("testsftp");
			
			//列出服务器指定的文件列表
			Vector v = sftp.ls("*.txt");
			for(int i=0;i<v.size();i++){
				System.out.println(v.get(i));
			}
			
			//以下代码实现从本地上传一个文件到服务器,如果要实现下载,对换以下流就可以了
			OutputStream outstream = sftp.put(uploadFileName);
			InputStream instream = new FileInputStream(new File("C:/ftptest/aa.txt"));
			
			byte b[] = new byte[1024];
			int n;
		    while ((n = instream.read(b)) != -1) {
		    	outstream.write(b, 0, n);
		    }
		    
		    outstream.flush();
		    outstream.close();
		    instream.close();
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			session.disconnect();
			channel.disconnect();
		}
	}
}


代码是引用了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则为空。
分享到:
评论

相关推荐

    jsch_jsch jsch_jsch jsch_jsch

    `jsch` 是一个Java库,全称为Java Simple Cryptography Handler,它提供了SSH(Secure Shell)协议的实现,使得Java程序能够与远程服务器进行安全的通信。SSH是一种网络协议,用于在不安全的网络上安全地执行命令、...

    JSCH免费下载啦

    **JSCH库详解** JSCH(Java Secure Channel)是一个开源的Java库,它允许开发者在Java应用程序中实现SSH(Secure Shell)协议,从而支持SFTP(Secure File Transfer Protocol)。JSCH库提供了对SSH2协议的强大支持...

    jsch的jar包

    **JSCH库详解** JSCH(Java Secure Channel)是一个开源的Java库,它实现了SSH2协议,用于在Java应用程序中实现安全的网络通信。SSH2协议提供了加密、身份验证和安全的数据传输,常用于文件传输服务如SFTP(Secure ...

    jsch实现sftp文件上传、下载 ,jsch jar

    JSch jsch = new JSch(); session = jsch.getSession("username", "hostname", 22); session.setPassword("password"); // 如果使用密钥对,注释掉上面一行,然后设置以下两行 // String privateKeyPath = ...

    jsch0.1.55.jar_jsch0.1.53.jar

    JSch是Java Secure Channel的缩写,它是一个纯Java实现的SSH2库,允许Java应用程序连接到支持SSH协议的服务器,进行安全的数据传输。在给定的标题"jsch0.1.55.jar_jsch0.1.53.jar"中,提到了两个不同版本的JSch库...

    jsch-0.1.54-API文档-中文版.zip

    赠送jar包:jsch-0.1.54.jar; 赠送原API文档:jsch-0.1.54-javadoc.jar; 赠送源代码:jsch-0.1.54-sources.jar; 赠送Maven依赖信息文件:jsch-0.1.54.pom; 包含翻译后的API文档:jsch-0.1.54-javadoc-API文档-...

    jsch版本50-53.rar

    JSCH,全称为Java Simple SSH,是一个开源的Java库,用于实现SSH2协议,以便在Java应用程序中进行安全的远程文件传输、shell访问以及端口转发。JSCH库广泛应用于需要与支持SSH2的服务器进行交互的场景,例如SFTP...

    jsch-0.1.54.zip

    **JSch库详解** JSch(Java Secure Channel)是一个开源的Java库,它实现了SSH2协议,用于在Java应用程序中实现安全的远程登录和其他安全网络服务。JSch库的版本0.1.54是我们关注的重点,这个版本包含了源代码和...

    jsch API文档

    **JSch API文档详解** JSch(Java Secure Channel)是一个用Java实现的SSH2库,它允许Java应用程序连接到支持SSH协议的服务器,进行安全的数据传输。JSch库提供了广泛的API,涵盖了SSH协议的主要功能,包括连接建立...

    JSCH0.1.46

    JSCH(Java Simple Connection Handler)是一个Java库,用于在客户端应用程序和远程服务器之间建立SSH(Secure Shell)连接。版本0.1.46是JSCH的最新版,它提供了丰富的功能,使开发者能够通过SSH协议在Java应用中...

    jsch文件名中文乱码解决办法

    *jsch的源文件 *jsch的依赖包 *用jsch源文件及依赖包构建的项目,便于修改其源码* 修改源码后重新导出的jar包 *我写的一段小程序,实现的主要功能是同步sftp上的文件夹(sftp-&gt;本地) *我写的一个小程序,用于将字符...

    jsch-0.1.55_jsch_JSCH0.1._55_服务器_jsch0.1.55_

    JSch 是SSH2的一个纯Java实现。它允许你连接到一个sshd 服务器,使用端口转发,X11转发,文件传输等等。你可以将它的功能集成到你自己的 程序中。同时该项目也提供一个J2ME版本用来在手机上直连SSHD服务器

    jsch-0.1.55.jar 包

    **jsch-0.1.55.jar 包详解** `jsch-0.1.55.jar` 是一个Java库,主要用于实现SSH(Secure Shell)协议,它允许Java应用程序在远程Linux服务器上进行安全的登录和命令执行。SSH是一种网络协议,用于加密网络通信,...

    可用的jsch-0.1.54.jar

    **JSCH库详解** JSCH(Java Secure Channel)是一个开源的Java库,它实现了SSH2协议,用于在Java应用程序中实现安全的远程登录、文件传输、端口转发等功能。JSCH库广泛应用于需要通过SSH连接到远程服务器进行操作的...

    jsch-0.1.54-API文档-中英对照版.zip

    赠送jar包:jsch-0.1.54.jar; 赠送原API文档:jsch-0.1.54-javadoc.jar; 赠送源代码:jsch-0.1.54-sources.jar; 赠送Maven依赖信息文件:jsch-0.1.54.pom; 包含翻译后的API文档:jsch-0.1.54-javadoc-API文档-...

    JSCH执行命令是输入密码的方法

    在IT领域,JavaScript Secure Channel (JSCH) 是一个非常实用的Java库,它允许开发者在Java应用程序中实现Secure Shell (SSH) 协议。本文将深入探讨如何使用JSCH库来执行远程命令,并且处理输入密码的情况。我们将...

    jsch实现远程传输

    **JSch库详解与远程SFTP传输** JSch(Java Secure Channel)是一个纯Java实现的SSH2库,它允许Java应用程序连接到支持SSH协议的服务器,进行安全的远程操作,如文件传输。在本文中,我们将深入探讨JSch库的工作原理...

    jsch的jar包,包含0.1.51,0.1.52,0.1.53,0.1.54等这几个版本

    JSch,全称为Java Secure Channel,是一个开源的Java库,用于实现SSH(Secure Shell)协议。这个库的主要目的是提供安全的远程登录、文件传输以及端口转发等功能,广泛应用于需要在Java应用程序中进行安全通信的场景...

    jcraft-jsch.zip

    《JSch:Java SSH 库的深度探索》 JSch,全称为JCraft SSH,是一个用Java编写的开源库,用于实现Secure Shell (SSH) 协议。在标题"jcraft-jsch.zip"中,我们可以看到这个压缩包包含了JSch的两个版本,0.1.24和...

    com.jcraft.jsch

    1. 加载jsch库,并实例化JSch对象。 2. 创建Session对象,设置主机名、端口号、用户名和认证方式。 3. 调用Session的connect()方法建立连接。 4. 创建通道,例如ShellChannel或SftpChannel。 5. 通过通道执行相应...

Global site tag (gtag.js) - Google Analytics