Java使用Jsch与sftp服务器实现ssh免密登录

复制代码
本次验证是通过jsch配置rsa私钥路径的思路进行的。详细步骤如下:

1、引用依赖jar

java 复制代码
<dependency>
<groupId>com.jcraft</groupId>
<artifactId>jsch</artifactId>
<version>0.1.51</version>
</dependency>

2、代码参考:

java 复制代码
//从环境变量或配置文件中读取 目标服务器ip、端口、用户名、私钥路径
String ftpHost = System.getEnv("sftpHost");
String sftpPort= System.getEnv("sftpPort");
String sftpUserName = System.getEnv("sftpUserName");
String sftpPrivatekey= System.getEnv("sftp_privatekey");

//建立JSch对象
JSch jsch = new JSch();
Session session = null;
ChannelSftp channelSftp = null

try{
 //添加私钥
 jsch.addIdentity(sftpPrivatekey);
 session=jsch.getSession(sftpUserName, ftpHost, sftpPort);
 Properties sessionConfig = new Properties();
 //SSH 公钥检查机制 no、ask、yes
 sessionConfig.put("StrictHostKeyChecking", "no");
 session.connect();
 channelSftp = (ChannelSftp) session.openChannel("sftp"); // 打开SFTP通道
 channelSftp.connect();
 //进行操作 如进入指定文件夹
 channelSftp.cd(path);
}catch (JSchException e) {
 logger.error("sftp getConnect error : "+e);
}

3、配置私钥的步骤

1、在linux下执行ssh-keygen -t rsa 生成一对对应公私钥。 输入命令后按三下回车。

2、检查~/用户名/.ssh目录下是否有id_rsa、id_rsa.pub、authorized_keys三个文件。

注意:生成文件的目录建议默认,如果没有authorized_keys文件需要手工新建下,或者直接把id_rsa.pub复制为authorized_keys。检查并设置id_rsa、authorized_keys文件的权限为600。

java 复制代码
cp id_rsa.pub  authorized_keys
chmod 600 id_rsa 
chmod 600 authorized_keys
stat --c "%a %n"  文件夹或文件名

3、root用户检查/etc/ssh/sshd_config下面是否有配置HostKey对应的rsa文件路径,如果存在其他rsa结尾的路径,建议把新生成的id_rsa文件的绝对路径配置到sshd_config中,如果没有可以忽略。

注意:修改sshd_config后需要重启sshd服务。

java 复制代码
sudo systemctl restart sshd

4、把生成的id_rsa文件放到代码中配置的sftp_privatekey路径下一份。

5、免密登录是否配置成功检查

java 复制代码
ssh --i id_rsa绝对路径  sftp用户@sftp地址

感觉各位博主的分享:

<Linux>《OpenSSH 守护进程配置文件sshd_config详解》

Linux免密登录设置(22端口和非默认端口)

详解Java使用Jsch与sftp服务器实现ssh免密登录

linux ssh配置文件和密钥文件

【authorized_keys配置及常见问题】

jsch session(ssh)

相关推荐
abcnull2 小时前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
j_xxx404_2 小时前
Linux:静态链接与动态链接深度解析
linux·运维·服务器·c++·人工智能
叶小鸡2 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
juniperhan3 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
ID_180079054733 小时前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
c++之路3 小时前
C++23概述
java·c++·c++23
墨风如雪3 小时前
别被“高价建站”劝退了!我跑了多年的 WordPress 架构,一年只花 $25.7
服务器
云飞云共享云桌面4 小时前
东莞智能装备工厂数字化实践—研发部门10名SolidWorks设计共享一台云主机流畅设计
服务器·自动化·汽车·负载均衡·制造
专注API从业者4 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库