Tauri 提供界面 + 使用 Rust 实现连接远程 Linux 服务器、发送文件、执行命令

这篇具有很好参考价值的文章主要介绍了Tauri 提供界面 + 使用 Rust 实现连接远程 Linux 服务器、发送文件、执行命令。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Tauri 提供界面 + 使用 Rust 实现连接远程 Linux 服务器、发送文件、执行命令

一、Tauri 概述

Tauri 是一个用于构建跨平台桌面应用程序的工具和框架。它的目标是通过将 Web 技术与本地功能结合,使开发者能够以简单、高效的方式创建现代的桌面应用。

以下是 Tauri 的一些主要特点和概述:

  1. 跨平台支持:Tauri 允许你构建跨平台的桌面应用程序,它支持 Windows、macOS 和 Linux 等常见的操作系统。你可以使用一套代码库在多个平台上构建应用程序。
  2. 基于 Web 技术:Tauri 使用 Web 技术作为应用程序的前端开发语言。你可以使用 HTML、CSS 和 JavaScript(或其他 Web 前端框架)来构建应用程序的用户界面。
  3. 原生功能访问:Tauri 提供了访问原生功能的接口,让你可以从前端代码中直接调用本地操作系统的功能,如文件系统、网络、系统通知等。这样,你可以创建出与本地应用程序类似的功能和体验。
  4. 嵌入式 Web 渲染引擎:Tauri 使用嵌入式的 Web 渲染引擎(如 WebView 或 WebKitGTK)来渲染应用程序的界面。这使得应用程序可以直接在桌面环境中运行,而无需依赖外部的浏览器。
  5. 丰富的生态系统:Tauri 生态系统提供了许多有用的功能和库,如打包工具、插件系统、前端构建工具等,以便于应用程序的开发和部署。
  6. 灵活的扩展性:Tauri 允许你通过使用 Rust 和 JavaScript 进行扩展,从而实现更复杂的功能。你可以编写原生 Rust 代码来访问底层的系统功能,并使用 JavaScript 与前端代码进行交互。

总的来说,Tauri 提供了一个快速、简单的方式来开发跨平台的桌面应用程序。通过结合 Web 技术和原生功能,你可以创建出功能丰富、具有优秀用户体验的桌面应用。无论是构建独立的应用程序,还是将现有的 Web 应用转化为桌面应用,Tauri 都是一个强大的选择。

二、界面预览

Tauri 提供界面 + 使用 Rust 实现连接远程 Linux 服务器、发送文件、执行命令,Linux,服务器,rust,linux

三、代码参考

1、main.rs

// Prevents additional console window on Windows in release, DO NOT REMOVE!!
#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]
#![allow(unused_assignments)] // 禁用未使用赋值的警告

use std::io::{Read, Write};
use std::path::Path;
use ssh2::Session;

// Learn more about Tauri commands at https://tauri.app/v1/guides/features/command
#[tauri::command]
fn go(ip_with_port: &str, username: &str, password: &str, local_file_path: &str, target_file_path: &str, command: &str) {
    publish(ip_with_port, username, password, local_file_path, target_file_path, command)
}

fn main() {
    tauri::Builder::default()
        .invoke_handler(tauri::generate_handler![go])
        .run(tauri::generate_context!())
        .expect("error while running tauri application");
}

const PROGRESS_UPDATE_INTERVAL: usize = 1024 * 1024; // 每传输 1MB 打印一次进度信息

// 发布
fn publish(ip_with_port: &str, username: &str, password: &str, local_file_path: &str, target_file_path: &str, command: &str) {
    // 连接远程服务器
    let tcp = std::net::TcpStream::connect(ip_with_port).unwrap(); // 连接到远程服务器
    let mut sess = Session::new().unwrap(); // 创建一个新的会话
    sess.set_tcp_stream(tcp); // 设置会话的 TCP 流
    sess.handshake().unwrap(); // 进行握手
    sess.userauth_password(username, password).unwrap(); // 使用用户名和密码进行身份验证

    // 传输文件
    let file_size = get_file_size(local_file_path); // 获取文件大小
    let mut channel = sess.scp_send(Path::new(target_file_path), 0o644, file_size, None).unwrap(); // 创建一个新的 SCP 通道
    let mut file = std::fs::File::open(local_file_path).unwrap(); // 打开本地文件
    let mut buffer = Vec::new(); // 创建一个空的字节向量
    file.read_to_end(&mut buffer).unwrap(); // 读取文件内容

    let mut total_bytes_sent = 0; // 已发送的总字节数
    let mut total_mb = (file_size as f64) / (1024.0 * 1024.0); // 文件总大小(MB)
    total_mb = (total_mb * 100.0).round() / 100.0; // 保留2位小数
    let mut transferred_mb = 0.0; // 已传输的文件大小(MB)

    // 记录已发送文件的大小
    let mut bytes_sent = 0; // 已发送的字节数
    for (i, chunk) in buffer.chunks(PROGRESS_UPDATE_INTERVAL).enumerate() { // 循环发送文件内容
        // 循环发送,发完为止!
        while bytes_sent < chunk.len() {
            let result = channel.write(chunk).unwrap(); // 发送文件内容
            bytes_sent += result; // 更新已发送的字节数
        }
        total_bytes_sent += bytes_sent; // 更新已发送的总字节数
        bytes_sent = 0; // 重置已发送的字节数
        transferred_mb = (total_bytes_sent as f64) / (1024.0 * 1024.0); // 更新已传输的文件大小(MB)
        transferred_mb = (transferred_mb * 100.0).round() / 100.0; // 保留2位小数

        if (i + 1) * PROGRESS_UPDATE_INTERVAL <= buffer.len() { // 如果还有剩余的文件内容需要发送
            let progress = (total_bytes_sent as f64) / (file_size as f64) * 100.0; // 计算传输进度
            println!("进度: {:.2}% ({:.2} MB / {:.2} MB)", progress, transferred_mb, total_mb); // 打印传输进度信息
        } else { // 文件传输完毕
            println!("进度: 100% 文件传输完毕!");
        }
    }
    channel.send_eof().unwrap(); // 发送 EOF 标志

    // 执行远程命令
    let mut channel = sess.channel_session().unwrap(); // 创建一个新的会话通道
    channel.exec(command).unwrap(); // 执行命令
    let mut output = Vec::new(); // 创建一个空的字节向量
    channel.read_to_end(&mut output).unwrap(); // 读取命令输出
    println!("{}", String::from_utf8_lossy(&output)); // 打印命令输出
}

// 获取文件大小
fn get_file_size(file_path: &str) -> u64 {
    std::fs::metadata(file_path) // 获取文件元数据
        .map(|metadata| metadata.len()) // 获取文件大小
        .unwrap_or(0) // 如果获取失败,则返回 0
}

2、App.vue

<script setup lang="ts">
import Greet from "./components/Greet.vue";
</script>

<template>
  <div class="container">
    <h1>Spring Boot 程序发布工具!</h1>
    <div class="tips">程序发布 = 连接 Linux + 发送文件 + 执行命令</div>
    <Greet />
  </div>
</template>

<style scoped>
.tips {
  color: #666666;
  margin-bottom: 10px;
}
</style>

3、Greet.vue

<template>
  <form class="row" @submit.prevent="go">
    <input v-model="ipWithPort" placeholder="IP地址:端口号"/>
    <input v-model="username" placeholder="账号"/>
    <input v-model="password" placeholder="密码" type="password"/>
    <input v-model="filePath" placeholder="本地文件路径"/>
    <input v-model="targetPath" placeholder="目标文件路径"/>
    <input v-model="command" placeholder="命令"/>
    <button type="submit">执行!</button>
  </form>

  <p>{{result}}</p>
</template>

<script setup lang="ts">
import {ref} from "vue";
import {invoke} from "@tauri-apps/api/tauri";

// IP地址和端口号:ip:port
const ipWithPort = ref("222.222.222.222:22");
// 账号
const username = ref("root");
// 密码
const password = ref("root");
// 本地文件路径
const filePath = ref("C:\\\\Users\\\\Administrator\\\\Desktop\\\\app.jar");
// 目标文件路径
const targetPath = ref("/home/zibo/app.jar");
// 命令
const command = ref("pwd");
// 执行结果
const result = ref("未开始执行!");

async function go() {
  result.value = "执行中...";
  await invoke("go", {ipWithPort: ipWithPort.value, username: username.value, password: password.value, localFilePath: filePath.value, targetFilePath: targetPath.value, command: command.value});
  result.value = "执行完毕!";
}
</script>

<style>
.row {
  display: flex;
  flex-direction: column;
  margin: 0 10px;
}

.row input {
  margin-bottom: 10px;
}
</style>

4、依赖

Cargo.toml文章来源地址https://www.toymoban.com/news/detail-557530.html

# ssh2
ssh2 = "0.9.4"

到了这里,关于Tauri 提供界面 + 使用 Rust 实现连接远程 Linux 服务器、发送文件、执行命令的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 如何使用JuiceSSH实现手机端远程连接Linux服务器

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站 处于内网的虚拟机如何被外网访问呢?如何手机就能访问虚拟机呢? cpolar+JuiceSSH 实现手机端远程连接Linux虚拟机(内网穿透,手机端连接Linux虚拟机) 1. Linux安装cpolar 首先

    2024年02月04日
    浏览(53)
  • 安卓手机如何使用JuiceSSH实现公网远程连接本地Linux服务器

    处于内网的虚拟机如何被外网访问呢?如何手机就能访问虚拟机呢? cpolar+JuiceSSH 实现手机端远程连接Linux虚拟机(内网穿透,手机端连接Linux虚拟机) 1. Linux安装cpolar 首先,我们在Linux中安装[cpolar内网穿透](cpolar官网-安全的内网穿透工具 | 无需公网ip | 远程访问 | 搭建网站)工具 使用

    2024年03月18日
    浏览(59)
  • 已拒绝远程连接,因为未识别出你提供的用户名和密码组合或在远程访问服务器上禁止使用选定的身份验证协议

    VPN连接时,提示:已拒绝远程连接,因为未识别出你提供的用户名和密码组合或在远程访问服务器上禁止使用选定的身份验证协议。  按下面的操作:  

    2024年02月11日
    浏览(50)
  • Centos7安装图形化界面并使用Windows远程桌面连接(包含离线部署)

    1、关闭防火墙和selinux(xrdp是通过3389端口远程桌面连接 ) [root@localhost ~]# systemctl stop firewalld #临时关闭防火墙 [root@localhost ~]# systemctl disable firewalld.service #永久关闭防火墙 [root@localhost ~]# setenforce 0 #临时关闭selinux [root@localhost ~]# sed -i \\\'s/enforcing/disabled/g\\\' /etc/selinux/config #永久关闭

    2024年02月08日
    浏览(65)
  • 【一起学Rust | 框架篇 | Tauri2.0框架】Tauri2.0环境搭建与项目创建

    Tauri在Rust圈内成名已久,凭借Rust的可靠性,使用系统原生的Webview构建更小的App 以及开发人员可以灵活的使用各种前端框架而一战成名。 然而,这款年轻的框架却有着大量的问题待解决,在这种情况下,他竟然还出了2.0,想要支持 安卓 和 苹果端 ,在我看来步子还是跨的挺

    2024年02月20日
    浏览(54)
  • Rust Tauri & OpenCV 写一个桌面摄像头

    在一些直播场景,或者屏幕录制场景,希望可以把自己的头像通过摄像头放在桌面显示,增加互动性。 一些会议软件是支持这个能力的,但通常会把摄像头的内容放在一个方框里,显得不太好看,而且还得额外打开一个会议软件,会议软件的多余内容也会被录制进去。 于是

    2024年02月16日
    浏览(46)
  • 如何在Linux设置JumpServer实现无公网ip远程访问管理界面

    JumpServer 是广受欢迎的开源堡垒机,是符合 4A 规范的专业运维安全审计系统。JumpServer 帮助企业以更安全的方式管控和登录所有类型的资产,实现事前授权、事中监察、事后审计,满足等保合规要求。 下面介绍如何简单设置即可使本地jump server 结合cpolar 内网穿透实现远程访问

    2024年02月04日
    浏览(61)
  • Linux部署MeterSphere结合内网穿透实现远程访问服务管理界面

    MeterSphere 是一站式开源持续测试平台, 涵盖测试跟踪、接口测试、UI 测试和性能测试等功能,全面兼容 JMeter、Selenium 等主流开源标准,有效助力开发和测试团队充分利用云弹性进行高度可扩展的自动化测试,加速高质量的软件交付,推动中国测试行业整体效率的提升。 下面介

    2024年02月04日
    浏览(39)
  • Linux本地docker一键部署traefik+cpolar实现远程访问dashboard界面

    Træfɪk 是一个云原生的新型的 HTTP 反向代理、负载均衡软件,能轻易的部署微服务。它支持多种后端 (Docker, Swarm, Mesos/Marathon, Consul, Etcd, Zookeeper, BoltDB, Rest API, file…) , 可以对配置进行自动化、动态的管理. Træfɪk 支持docker一键部署,内置 Web UI,管理相对方便,下面介绍Linux 本地

    2024年02月04日
    浏览(44)
  • 使用 FinalShell 进行远程连接(ssh 远程连接 Linux 服务器)

    目录 前言 基本使用教程 新建远程连接 连接主机 自定义命令 路由追踪 后端开发,必然需要和服务器打交道,部署应用,排查问题,查看运行日志等等。一般服务器都是集中部署在机房中,也有一些直接是云服务器,总而言之,程序员不可能直接和服务器直接操作,一般都是

    2024年04月16日
    浏览(80)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包