首页
/ SSHJ 教程:Java实现安全Shell连接

SSHJ 教程:Java实现安全Shell连接

2026-01-16 09:37:20作者:郦嵘贵Just

1. 项目介绍

SSHJ 是一个由 Hierynomus 开发并维护的开源 Java 库,它提供了对 SSH(Secure Shell)协议的支持,使得用户可以在 Java 应用程序中实现安全的远程命令执行、文件传输等功能。SSHJ 底层使用 Apache SSHD,但其API设计更加简洁易用。

2. 项目快速启动

要开始使用 SSHJ,首先确保你的项目已经集成了 SSHJ 的依赖。如果你使用的是 Maven,添加以下依赖到你的 pom.xml 文件:

<dependency>
    <groupId>com.hierynomus</groupId>
    <artifactId>sshj</artifactId>
    <version>0.35.0</version> <!-- 最新版本可能不同,请检查 https://mvnrepository.com/artifact/com.hierynomus/sshj -->
</dependency>

然后,你可以尝试一下简单的 SSH 连接示例:

import net.schmizz.sshj.SSHClient;
import net.schmizz.sshj.common.IOUtils;
import net.schmizz.sshj.connection.Connection;

public class SSHJQuickStart {
    public static void main(String[] args) throws Exception {
        SSHClient sshClient = new SSHClient();
        sshClient.addHostKeyVerifier(new PromiscuousVerifier()); // 不安全的验证,仅用于演示
        sshClient.connect("your-server-ip", 22);
        try {
            sshClient.authPassword("username", "password");
            Connection conn = sshClient.getConnection();
            System.out.println("Connected to server...");
            
            // 在这里执行远程命令或进行其他操作
        } finally {
            sshClient.disconnect();
        }
    }
}

3. 应用案例和最佳实践

执行远程命令

public void execRemoteCommand() throws IOException {
    SSHClient sshClient = new SSHClient();
    sshClient.addHostKeyVerifier(new PromiscuousVerifier());
    sshClient.connect("your-server-ip", 22);
    
    try {
        sshClient.authPublicKey("username", new File("path/to/your/id_rsa.pem")); // 使用公钥认证
        Session session = sshClient.startSession();
        Command cmd = session.exec("ls -l");
        
        IOUtils.readFully(cmd.getInputStream()).toString(Charset.defaultCharset());
        cmd.close();
        session.close();
    } finally {
        sshClient.disconnect();
    }
}

SCP 文件传输

import net.schmizz.sshj.xfer.scp.SCPFileTransfer;

// ... 忽略 SSH 客户端设置部分 ...

SCPFileTransfer scpTransfer = sshClient.getFileTransfer();
scpTransfer.put(new File("/local/path/file.txt"), "/remote/path/");
scpTransfer.shutdown();

// 或者下载文件
scpTransfer.get(new File("/remote/path/file.txt"), "/local/path/");

4. 典型生态项目

SSHJ 可以和其他 Java 工具和框架结合使用,例如 Spring Boot、Jenkins 等。它还能够与其他基于 SSH 的工具(如 Ansible)互操作,因为它们都是通过 SSH 协议通信的。

示例:Spring Boot 集成

在 Spring Boot 中配置 SSHJ,可以通过创建一个 Bean 来实现:

@Configuration
public class SSHConfig {

    @Bean
    public SSHClient sshClient() {
        SSHClient sshClient = new SSHClient();
        sshClient.addHostKeyVerifier(new PromiscuousVerifier());
        return sshClient;
    }

}

随后,你可以在其他服务类中注入这个 SSHClient Bean 并使用它。

以上就是 SSHJ 的基本介绍及使用教程。请务必在实际生产环境中替换掉不安全的 PromiscuousVerifier,并考虑使用更安全的主机键验证机制。更多详细信息请参考 SSHJ 的官方文档:https://github.com/hierynomus/sshj/blob/master/docs/README.md 。

登录后查看全文

项目优选

收起
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
466
kernelkernel
deepin linux kernel
C
32
16
atomcodeatomcode
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get Started
Rust
2.09 K
218
ops-nnops-nn
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
700
1.4 K
docsdocs
暂无描述
Dockerfile
780
5.08 K
pytorchpytorch
Ascend Extension for PyTorch
Python
758
968
flutter_flutterflutter_flutter
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
ops-transformerops-transformer
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
880
2.03 K
mindquantummindquantum
MindQuantum is a general software library supporting the development of applications for quantum computation.
Python
183
112
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.11 K
682