Files
ogame-vue-ts/server.js
coolxitech 7e937330bb ci(workflow): 添加多平台构建与发布工作流
- 新增 GitHub Actions 工作流文件
- 支持 Windows、Linux 和 macOS 平台构建
- 配置 Bun 环境并安装依赖
- 构建 Vue 前端资源
- 编译后端为可执行文件
- 打包静态资源与可执行程序
- 上传构建产物并创建 GitHub Release
2025-12-13 13:12:37 +08:00

44 lines
1.4 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
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);
}
});