导读:在实际项目中常会遇到需要连接服务器获取文件的场景,如账务系统需要通过连接行方的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的依赖
<dependency><groupId>com.jcraft</groupId><artifactId>jsch</artifactId><version>0.1.51</version></dependency>四、Jsch详解
1、Jsch提供了四种认证机制:
- password 密码方式
- publickey(DSA,RSA) 公私钥方式
- keyboard-interactive
- gss-api-with-mic
2、配置SSH免密步骤概述
- 在linux下执行ssh-keygen -t rsa 生成一对对应公私钥 。
- 把公钥复制到将要连接的目标服务器上,放到对应用户的.ssh目录下 。
- 进入到.ssh中:cd ~/.ssh,并公钥导入到authorized_keys信任列表:cat 公钥 >> authorized_key
- 更新权限:chmod 600 authorized_keys,自此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 = nulltry{ //添加私钥 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的方法,如
- put()--文件上传
- get()--文件下载
- cd()--进入指定目录
- ls()--得到指定目录下的文件列表
- rename()--重命名指定文件或目录
- rm()--删除指定文件
- mkdir()--创建目录
- rmdir()--删除目录
文章插图
5、SSH公钥检查机制:公钥检查机制是一个安全机制,可以防范中间人劫持等黑客攻击 。SSH连接远程主机时,会检查主机的公钥 。如果是第一次该主机,会显示该主机的公钥摘要,提示用户是否信任该主机 。当选择接受,就会将该主机的公钥追加到文件 ~/.ssh/known_hosts 中 。当再次连接该主机时,就不会再提示该问题了 。但是在某些特殊的情况下,严格的SSH公钥检查可能会破坏一些依赖SSH协议的自动化任务如Java的Jsch免密登录sftp程序 。解决方式为调整StrictHostKeyChecking配置指令 。StrictHostKeyChecking选项如下3种:
推荐阅读
- javascrip基础:var,let和const区别在哪里
- JavaScript Dom 绑定事件操作实例详解
- 今日头条、抖音推荐算法原理全文详解
- 一文帮你读懂Java浮点数的存储原理
- Java主流数据库连接池优劣及未来
- 超好用的 Java 开源 验证码 神器
- 酸奶机怎么样使用 酸奶机怎么样
- 加湿器棉棒怎么使用 加湿器送的棉棒怎么用
- 核动力优势明显,天问一号为什么还要使用太阳能?
- 鸡眼膏的原理和使用方法