尝试使用tauri2+Django+React的项目

前言

使用Tauri2+前端,本质是进程间的通信。并非前后端。

而想使用nw,先后端打包exe,再和前端打包成exe,并没有完成成功。

而笔者从Tauri中看到这种可能性。很有可能成功基于SeaORM+MySQL+Tauri2+Vite+React等的CRUD交互项目-CSDN博客https://blog.csdn.net/qq_63401240/article/details/146273043在github action工作流使用nw和nw-builder打包-CSDN博客https://blog.csdn.net/qq_63401240/article/details/146126489?spm=1001.2014.3001.5502

关于前后端整合和打包成exe文件的个人的总结和思考_python pyproject.toml 打包exe-CSDN博客https://blog.csdn.net/qq_63401240/article/details/146140425?spm=1001.2014.3001.5501 

正文

建立tq项目

 在前面的基础上。不必细说

直入主题

关键插件

@tauri-apps/plugin-shell | Tauri - Tauri 框架https://v2.tauri.org.cn/reference/javascript/shell/这个插件,可以在Rust运行cmd,也可以在JS中运行。

后端打包成exe,比如manage.exe,应该放到什么位置?这值得思考

一段代码的启示

笔者在下面这段代码发现,打印resolveResource

import {resolveResource} from '@tauri-apps/api/path'
console.log(await resolveResource())
// F:\Users\26644\webstormProject\tq\src-tauri\target\debug

结果是xxxx/xxx/target/debug

看到这里,笔者直觉感觉到放debug目录下。

进入debug目录,笔者发现了tq.exe

第二段代码的启示

在tauri2的官网关于shell的例子

Shell | Taurihttps://v2.tauri.app/zh-cn/plugin/shell/例子如下

JS代码

import { Command } from '@tauri-apps/plugin-shell';
// 当设置 `"withGlobalTauri": true`, 你可以使用
// const { Command } = window.__TAURI__.shell;let result = await Command.create('exec-sh', ['-c',"echo 'Hello World!'",
]).execute();
console.log(result);

 Rust许可

{"$schema": "../gen/schemas/desktop-schema.json","identifier": "main-capability","description": "Capability for the main window","windows": ["main"],"permissions": [{"identifier": "shell:allow-execute","allow": [{"name": "exec-sh","cmd": "sh","args": ["-c",{"validator": "\\S+"}],"sidecar": false}]}]
}

代码的目的就是在sh中打印hello world。

在许可中

name:exec-sh是名字,正是第一次参数

-c:对应-c

在许可中

validator是校验器,后面的正则表达式的意思是输入的字符串必须包含至少一个非空白字符

因此,笔者模仿了代码。

许多次尝试之后

1、将manage.exe放到debug目录下

2、前端的代码如下

import { Command } from '@tauri-apps/plugin-shell';
async function startDjangoServer() {try {console.log('Starting DjangoServer');// 关键代码let result = await Command.create("jango").execute();// 如果执行成功,直接阻塞,不会打印下面的语句console.log('Django server started successfully:', result);} catch (error) {console.log(error)console.error('Failed to start Django server:', error);}
}
export default startDjangoServer;

3、许可如下

"permissions": ["core:default","opener:default","core:window:allow-show","core:window:allow-hide","dialog:default","shell:default",{"identifier": "shell:allow-execute","allow": [{"name": "jango", "cmd": "powershell","args": ["manage.exe runserver --noreload"],"sidecar": false}]}]

名字叫jango。

在powershell中。

运行参数 manage.exe runserver --noreload

运行

在没有运行项目前,端口号8000确实是关闭的

运行项目

刚开始

还没有完全启动,等了一会

完美,看8000端口号

不好的点

如果此时打开任务管理器,搜索manage.exe。

结果如下

可以发现,有多个exe, 

笔者猜测是在前端React的组件中运行的,React组件渲染过程中,多次调用了前面的js代码,而且每次刷新页面,都会增加几个exe。

既然如此,笔者把启动manage.exe的代码写在Tauri中,

其实笔者并不是很甘心,一直询问AI,看看官网,无论是单例模式,还是React-Redux或者其他东西,都尝试过,每次刷新页面,都会新增manage.exe。无可奈何,只能写在Tauri中。

在Tauri中的尝试

希望的逻辑如下。

1、开始的时候,连接exe。

2、关闭的时候,断开exe。

实际的代码

use tauri::Manager;
use tauri::WindowEvent;
use tauri_plugin_shell::ShellExt;
use std::sync::Mutex;
use std::process::Command;struct DjangoState {pid: Option<u32>, // 存储 Django 服务的 PID
}fn is_manage_exe_running() -> bool { // 判断manage.exe 是否在运行let output = Command::new("tasklist").args(&["/FI", "IMAGENAME eq manage.exe"]).output();match output {Ok(output) => {let stdout = String::from_utf8_lossy(&output.stdout);stdout.contains("manage.exe")}Err(_) => false,}
}
#[cfg_attr(mobile, tauri::mobile_entry_point)]
pub fn run() {tauri::Builder::default().plugin(tauri_plugin_shell::init()) // 初始化 shell 插件.plugin(tauri_plugin_dialog::init()).plugin(tauri_plugin_opener::init()).manage(Mutex::new(DjangoState { pid: None })) // 初始化状态.setup(|app| {// 获取状态let state = app.state::<Mutex<DjangoState>>();// 检查是否已经启动let mut state = state.lock().unwrap();if state.pid.is_none() {// 检查 manage.exe 是否已经在运行if is_manage_exe_running() {println!("manage.exe is already running.");} else {// 启动 Django 服务let shell = app.shell();let result = shell.command("powershell") // 或者 "manager.exe",确保路径正确.args(["manage.exe", "runserver", "--noreload"]).spawn();// 返回Result<(Receiver<CommandEvent>, CommandChild)>match result {Ok((_receiver, child)) => {let pid = child.pid();println!("Django server started with PID: {}", pid);// 存储 PIDstate.pid = Some(pid);}Err(err) => {println!("Failed to start Django server: {:?}", err);}}}}Ok(())}).run(tauri::generate_context!()).expect("error while running tauri application");
}

实际情况,笔者无法终结exe,首先,没有管理员权限。

其次,有bug

显示打开的是

PID是14588,然而,打开任务管理器

什么情况????????

为什么有两个,为什么PID不对?

笔者也找不到原因

运行没有bug,可以获得数据。

因此,实际的逻辑

1、查看是否有manage.exe在运行

2、有则跳过,没有则打开

很明显,不是很好,假如有其他的exe,也叫manage.exe,就G了。

但又不得不这样做,可以运行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/37770.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【JavaWeb学习Day27】

Tlias前端 员工管理 条件分页查询&#xff1a; 页面布局 搜索栏&#xff1a; <!-- 搜索栏 --><div class"container"><el-form :inline"true" :model"searchEmp" class"demo-form-inline"><el-form-item label…

Milvus WeightedRanker 对比 RRF 重排机制

省流:优先选择WeightedRanker 以rag为例,优先选择bm25全文检索,其次选择向量检索 Milvus混合搜索中的重排机制 Milvus通过hybrid_search() API启用混合搜索功能&#xff0c;结合复杂的重排策略来优化多个AnnSearchRequest实例的搜索结果。本主题涵盖了重排过程&#xff0c;…

PLY格式文件如何转换成3DTiles格式——使用GISBox软件实现高效转换

一、概述 在三维GIS和数字孪生领域&#xff0c;3DTiles格式已成为主流的数据格式之一。它由Cesium团队提出&#xff0c;专为大规模3D数据可视化设计&#xff0c;能够高效地加载和展示海量模型数据。而PLY格式则是一种常见的三维模型文件格式&#xff0c;主要用于存储点云数据或…

Junit在测试过程中的使用方式,具体使用在项目测试中的重点说明

JUnit 是一个广泛使用的 Java 单元测试框架,主要用于编写和运行可重复的测试。以下是 JUnit 在项目测试中的使用方式和重点说明: 1. 基本使用 场景:测试一个简单的 Java 类。 示例: import org.junit.Test; import static org.junit.Assert.*;public class CalculatorTe…

《C++11 基于CAS无锁操作的atomic原子类型》

count; count--; 我们知道&#xff0c;/--操作并不是原子性的&#xff0c;其实对应三条汇编指令来完成的。 读取&#xff1a;从内存中把变量的值读取到寄存器修改&#xff1a;在寄存器里将变量的值1/-1写入&#xff1a;把修改后的值写入到内存 在单线程环境下&#xff0c;这…

网络编程之客户端聊天(服务器加客户端共三种方式)

最终效果&#xff1a; serve.c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <arpa/inet.h> #include <sys/select.h>#define MAX_CLIENTS 2 // 只允许两个客户端 #define BUF_SIZE 1024i…

《深度学习》—— 模型部署

文章目录 模型部署模型准备选择部署平台部署配置与服务化测试与验证优化与维护常用工具与框架Flask本地部署模型 模型部署 模型部署是将训练好的机器学习或深度学习模型投入实际生产环境&#xff0c;使其能够处理实时数据并提供预测或推理服务的过程。 模型准备 模型格式转换…

解码小米714亿资本棋局:雷军“押宝”AI新战场

目录 小米的AI战略&#xff1a;70亿投入背后的逻辑 1. ​AI成为核心战略&#xff0c;聚焦三大方向 2. ​资本开支超100亿&#xff0c;投资AI基础层公司 3. ​自研芯片与大模型突破 小米的资本棋局&#xff1a;从智能硬件到AI生态 1. ​714亿投资布局&#xff0c;构建产业…

如何为在线游戏选择合适的游戏盾?

在当今这个互联网高速发展的时代&#xff0c;在线游戏已经成为许多人日常生活中不可或缺的一部分。然而&#xff0c;随着游戏人数的不断增加&#xff0c;网络安全问题也层出不穷。游戏盾的问世便是为了解决这一系列安全隐患&#xff0c;确保玩家在游戏中能够拥有安全、畅快的体…

自适应柔顺性策略:扩散引导控制中学习近似的柔顺

24年10月来自斯坦福大学和 TRI 的论文“Adaptive Compliance Policy: Learning Approximate Compliance for Diffusion Guided Control”。 柔顺性在操作中起着至关重要的作用&#xff0c;因为它可以在不确定的情况下平衡位置和力的并发控制。然而&#xff0c;当今的视觉运动策…

w264民族婚纱预定系统

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…

栈/堆/static/虚表

在 C 里&#xff0c;栈空间主要用来存放局部变量、函数调用信息等。下面为你介绍栈空间在 C 里的运用方式。 1. 局部变量的使用 在函数内部定义的变量会被存于栈空间&#xff0c;当函数执行结束&#xff0c;这些变量会自动被销毁。 #include <iostream>void exampleFu…

SpringBoot实现异步调用的方法

在Java中使用Spring Boot实现异步请求和异步调用是一个常见的需求&#xff0c;可以提高应用程序的性能和响应能力。以下是实现这两种异步操作的基本方法&#xff1a; 一、异步请求&#xff08;Asynchronous Request&#xff09; 异步请求允许客户端发送请求后立即返回&#x…

基于 Prompt 的实体关系抽取:原理与优势解析

一、信息抽取的现状与挑战 在当今数字化时代&#xff0c;信息抽取作为自然语言处理&#xff08;NLP&#xff09;领域的核心技术&#xff0c;具有不可替代的重要性。从海量的非结构化文本数据中精准提取出有价值的信息&#xff0c;例如实体&#xff08;如人名、组织名&#xff…

SolidWorks使用显卡教程

操作步骤&#xff1a; 打开注册表编辑器 按下键盘上的 Win R 组合键&#xff0c;输入 regedit 并按回车键&#xff0c;打开注册表编辑器。 导航到显卡信息路径 在注册表中依次展开以下路径&#xff1a; plaintext HKEY_CURRENT_USER\Software\SolidWorks\SOLIDWORKS 2021\Per…

spring-tx笔记

编程式事务与声明式事务的理解 补充&#xff1a;什么是事务&#xff1f; 事务是一个重要概念&#xff0c;尤其在数据库管理系统中。事务是指一组操作。&#xff0c;这些操作要么全部成功执行&#xff0c;要么全部不执行&#xff0c;确保数据的一致性和完整性 编程式事务 编…

使用excel.EasyExcel实现导出有自定义样式模板的excel数据文件,粘贴即用!!!

客户要求导出的excel文件是有好看格式的&#xff0c;当然本文举例模板文件比较简单&#xff0c;内容丰富的模板可以自行设置&#xff0c;话不多说&#xff0c;第一步设置一个"好看"的excel文件模板 上面要注意的地方是{.变量名} &#xff0c;这里的变量名对应的就是…

AutoGluon快速上手

我叫不三不四&#xff0c;很高兴见到大家&#xff0c;欢迎一起学习交流和进步 今天来讲一讲机器学习包 AutoGluon简介&#xff1a; AutoGluon 提供了多种模型来处理不同类型的数据和任务&#xff0c;是由 亚马逊 AWS 团队 开发的一款开源 AutoML 框架&#xff0c;旨在简化机器…

AI风向标《AI与视频制作全攻略:从入门到精通实战课程》

课程信息 AI风向标《AI与视频制作全攻略&#xff1a;从入门到精通实战课程》,夸克网盘和百度网盘课程。 课程介绍 《AI与视频制作全攻略&#xff1a;从入门到精通实战课程》是一套全面融合AI技术与视频制作的实战课程&#xff0c;旨在帮助创作者从基础软件使用到高级视频剪辑…

Docker学习笔记(十)搭建Docker私有仓库

一、环境配置 1、宿主机系统&#xff1a;macOS Sequoia(版本15.2) 2、虚拟机VMware Fusion版本&#xff1a;专业版 13.6.2 (24409261) 3、虚拟机系统&#xff1a;AlmaLinux-9-latest-x86_64-boot.iso 二、安装Harbor开源企业级Docker镜像 Harbor 是一个开源的企业级 Docker…