在实际项目中常会遇到需要连接服务器获取文件的场景,如账务系统需要通过连接行方的sftp服务器拉取回单文件。本文将主要讨论使用Java中的jsch与sftp服务器实现ssh免密连接。
网站建设哪家好,找创新互联建站!专注于网页设计、网站建设、微信开发、成都微信小程序、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了大理州免费建站欢迎大家使用!
一、什么是SFTP?
SFTP是一个安全文件传送协议,可以为传输文件提供一种安全的加密方法。SFTP 为 SSH的一部份,是一种传输文件到服务器的安全方式。SFTP是使用加密传输认证信息和传输的数据,所以,使用SFTP是非常安全的。但是,由于这种传输方式使用了加密/解密技术,所以传输效率比普通的FTP要低得多,如果您对网络安全性要求更高时,可以使用SFTP代替FTP。
二、什么是Jsch以及它的作用?
Jsch是一个纯粹的用java实现SSH功能的java library。如果要知道Jsch的功能需先了解一下SSH。SSH是一个安全协议,用来在不同系统或者服务器之间进行安全连接,在连接和传送数据的过程中会进行加密。SSH一般是基于客户端的或者Linux命令行,比如window同过OpenSSH、putty等客户端的工具,在linux上可以通过ssh username@host命令进行连接。但是如果在Java中如何实现SSH呢?这时候便是通过JSCH来实现此的功能。
三、JSCH的依赖
com.jcraft jsch 0.1.51
四、Jsch详解
1. Jsch提供了四种认证机制:
常见的认证方式为password认证,但是本文接下来主要讨论基于publickey认证。对于后面两种认证方式感兴趣的朋友可以去查阅相关资料,本文将不做讨论。
2. 配置SSH免密步骤概述
3. Jsch基于publickey认证Demo
- //从配置文件中读取 目标服务器ip、端口、用户名、私钥路径
- String ftpHost = prop.getProperty("downloadHost");
- String port = prop.getProperty("downloadftpPort");
- String ftpUserName = prop.getProperty("downloadUserName");
- String priKeyBasePath = prop.getProperty("priBaseKeyPath");
- //建立JSch对象
- JSch jsch = new JSch();
- Session session = null;
- ChannelSftp channelSftp = null
- try{
- //添加私钥
- jsch.addIdentity(priKeyBasePath);
- session=jsch.getSession(userName, hostIp, port);
- Properties sessionConfig = new Properties();
- //SSH 公钥检查机制 no、ask、yes
- sessionConfig.put("StrictHostKeyChecking", "no");
- session.connect();
- channelSftp = (ChannelSftp) session.openChannel("sftp"); // 打开SFTP通道
- channelSftp.connect();
- //进行操作 如进入指定文件夹
- channelSftp.cd(config.getFileDir());
- }catch (JSchException e) {
- logger.error("sftp getConnect error : "+e);
- }
4. ChannelSftp类
ChannelSftp是JSch实现SFTP核心类,其包含了所有SFTP的方法,如
本Demo将Jsch核心主要代码提取出来进行讨论,省去了其他代码。网上也有许多完整的基于其他认证方式整合的工具类提供,需要的朋友可以自行查找。
5. SSH公钥检查机制:
公钥检查机制是一个安全机制,可以防范中间人劫持等黑客攻击。SSH连接远程主机时,会检查主机的公钥。如果是第一次该主机,会显示该主机的公钥摘要,提示用户是否信任该主机。当选择接受,就会将该主机的公钥追加到文件 ~/.ssh/known_hosts 中。当再次连接该主机时,就不会再提示该问题了。 但是在某些特殊的情况下,严格的SSH公钥检查可能会破坏一些依赖SSH协议的自动化任务如Java的Jsch免密登录sftp程序。解决方式为调整StrictHostKeyChecking配置指令。StrictHostKeyChecking选项如下3种:
五、总结
Jsch是Java实现SSH功能的java library,可用于连接sftp服务器。其拥有4种认证方式,其中publickey方式通过配置公私钥实现SSH免密登录。Java程序中通过使用Jsch核心类ChannelSftp进行sftp操作。对于连接过程中的SSH公钥检查机制可结合实际情况作出相应的调整。
当前文章:详解Java使用Jsch与sftp服务器实现ssh免密登录
浏览地址:http://www.csdahua.cn/qtweb/news2/409052.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网