使用websocket 和apache ssd写一个从前端输入命令到远程服务器执行的Java程序

时间: 2024-03-12 21:46:23 浏览: 21
这里是一个基本的Java程序示例,可以使用WebSocket和Apache SSH库将从前端输入的命令发送到远程服务器并执行: ```java import java.io.IOException; import java.net.URI; import java.net.URISyntaxException; import java.nio.charset.StandardCharsets; import java.util.Base64; import java.util.concurrent.CountDownLatch; import java.util.concurrent.TimeUnit; import org.apache.sshd.client.SshClient; import org.apache.sshd.client.channel.ChannelExec; import org.apache.sshd.client.keyverifier.PromiscuousVerifier; import org.apache.sshd.client.session.ClientSession; import org.apache.sshd.common.keyprovider.FileKeyPairProvider; import org.apache.sshd.common.util.io.NoCloseInputStream; import org.glassfish.tyrus.client.ClientManager; import org.glassfish.tyrus.client.ClientProperties; import org.glassfish.tyrus.client.SslContextConfigurator; import org.glassfish.tyrus.client.auth.AuthConfig; import org.glassfish.tyrus.client.auth.Credentials; import javax.net.ssl.SSLContext; import javax.websocket.ClientEndpoint; import javax.websocket.CloseReason; import javax.websocket.ContainerProvider; import javax.websocket.DeploymentException; import javax.websocket.OnClose; import javax.websocket.OnError; import javax.websocket.OnMessage; import javax.websocket.OnOpen; import javax.websocket.Session; import javax.websocket.WebSocketContainer; @ClientEndpoint public class RemoteShellClient { private static final String REMOTE_HOST = "remote.hostname.com"; private static final int REMOTE_PORT = 22; private static final String REMOTE_USERNAME = "remote_username"; private static final String REMOTE_PASSWORD = "remote_password"; private static final String REMOTE_PRIVATE_KEY_PATH = "/path/to/remote/private/key"; private static final String REMOTE_PUBLIC_KEY_PATH = "/path/to/remote/public/key"; private static final String WEBSOCKET_URL = "wss://websocket.server.com"; private Session websocketSession; private ClientSession sshSession; private ChannelExec sshChannel; private CountDownLatch latch; public RemoteShellClient() { this.latch = new CountDownLatch(1); } @OnOpen public void onWebSocketConnect(Session session) { this.websocketSession = session; } @OnMessage public void onWebSocketText(String command) { try { // Connect to remote host SshClient client = SshClient.setUpDefaultClient(); client.setKeyPairProvider(new FileKeyPairProvider(new String[] { REMOTE_PRIVATE_KEY_PATH })); client.setServerKeyVerifier(new PromiscuousVerifier()); client.start(); // Authenticate with remote host AuthConfig authConfig = AuthConfig.builder() .setCredentials(new Credentials() { @Override public boolean matches(String username, String password) { return REMOTE_USERNAME.equals(username) && REMOTE_PASSWORD.equals(password); } }) .build(); this.sshSession = client.connect(REMOTE_HOST, REMOTE_PORT).auth(authConfig).getSession(); // Start shell channel this.sshChannel = (ChannelExec) this.sshSession.createChannel("exec"); this.sshChannel.setCommand(command); this.sshChannel.setIn(new NoCloseInputStream(System.in)); this.sshChannel.setOut(System.out); this.sshChannel.setErr(System.err); this.sshChannel.open(); // Wait for channel to close this.latch.await(); // Disconnect from remote host this.sshChannel.disconnect(); this.sshSession.close(); client.stop(); } catch (IOException | InterruptedException e) { e.printStackTrace(); } } @OnClose public void onWebSocketClose(CloseReason reason) { this.latch.countDown(); } @OnError public void onWebSocketError(Throwable cause) { cause.printStackTrace(); } public void run() throws URISyntaxException, DeploymentException, IOException, InterruptedException { // Configure SSL context SSLContext sslContext = SSLContext.getDefault(); SslContextConfigurator sslContextConfigurator = new SslContextConfigurator(); sslContextConfigurator.setSslContext(sslContext); // Configure WebSocket client ClientManager client = ClientManager.createClient(); client.getProperties().put(ClientProperties.SSL_CONTEXT, sslContext); client.getProperties().put(ClientProperties.AUTH_CONFIG, AuthConfig.Builder.create().build()); client.connectToServer(this, new URI(WEBSOCKET_URL)); // Wait for WebSocket session to close this.latch.await(1, TimeUnit.DAYS); } public static void main(String[] args) { try { RemoteShellClient client = new RemoteShellClient(); client.run(); } catch (URISyntaxException | DeploymentException | IOException | InterruptedException e) { e.printStackTrace(); } } } ``` 在这个示例中,我们首先配置了远程主机的连接信息和WebSocket服务器的URL。当从WebSocket接收到文本消息时,我们使用Apache SSH库连接到远程主机并启动一个shell通道来执行接收到的命令。然后等待shell通道关闭,并断开与远程主机的连接。 要运行此程序,您需要将WebSocket和Apache SSH库添加到类路径中,并将示例中的REMOTE_HOST、REMOTE_PORT、REMOTE_USERNAME、REMOTE_PASSWORD、REMOTE_PRIVATE_KEY_PATH、REMOTE_PUBLIC_KEY_PATH和WEBSOCKET_URL替换为实际值。

相关推荐

最新推荐

recommend-type

java与微信小程序实现websocket长连接

主要为大家详细介绍了java与微信小程序实现websocket长连接,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C#实现WebSocket协议客户端和服务器websocket sharp组件实例解析

主要介绍了C#实现WebSocket协议客户端和服务器websocket sharp组件实例解析,包括websocket sharp组件的概念及使用方法,需要的朋友可以参考下
recommend-type

java 实现websocket的两种方式实例详解

主要介绍了java 实现websocket的两种方式实例详解,一种使用tomcat的websocket实现,一种使用spring的websocket,本文通过代码给大家介绍的非常详细,需要的朋友可以参考下
recommend-type

PHP用swoole+websocket和redis实现web一对一聊天

主要介绍了PHP用swoole+websocket和redis实现web一对一聊天,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

微信小程序websocket实现即时聊天功能

主要为大家详细介绍了微信小程序websocket实现即时聊天功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。