ci(workflow): 添加多平台构建与发布工作流

- 新增 GitHub Actions 工作流文件
- 支持 Windows、Linux 和 macOS 平台构建
- 配置 Bun 环境并安装依赖
- 构建 Vue 前端资源
- 编译后端为可执行文件
- 打包静态资源与可执行程序
- 上传构建产物并创建 GitHub Release
This commit is contained in:
coolxitech
2025-12-13 13:12:37 +08:00
parent cfbbb95ddb
commit 7e937330bb
2 changed files with 126 additions and 0 deletions

44
server.js Normal file
View File

@@ -0,0 +1,44 @@
const express = require('express');
const path = require('path');
const open = require('open'); // 需要安装: npm install open express
const os = require('os');
const app = express();
const HOST = '0.0.0.0';
app.set('trust proxy', true);
// 指向 Vue 构建后的 dist 目录
app.use(express.static(path.join(process.cwd(), 'dist')));
const getLocalIp = () => {
const interfaces = os.networkInterfaces();
for (let devName in interfaces) {
let face = interfaces[devName];
for (let i = 0; i < face.length; i++) {
let alias = face[i];
if (alias.family === 'IPv4' && alias.address !== '127.0.0.1' && !alias.internal) {
return alias.address;
}
}
}
return 'localhost';
}
const server = app.listen(0, HOST, async () => {
const { port } = server.address();
const url = `http://localhost:${port}`;
console.log('-----------------------------------');
console.log(`🚀 服务器已成功启动!`);
console.log(`🔗 本地地址: ${url}`);
console.log(`🌐 默认允许局域网访问http://${getLocalIp()}:${port}`);
console.log('-----------------------------------');
console.log('提示: 关闭此控制台窗口将停止服务。');
// 3. 自动打开浏览器
try {
await open(url);
} catch (err) {
console.error('无法自动打开浏览器:', err);
}
});