前后端分离架构(Vue 前端 + Java/SpringBoot 后端)项目部署 || 全服务器部署(宝塔面板)全流程 || 前端Netlify + 后端服务器 部署对比

前后端分离架构(Vue 前端 + Java/SpringBoot 后端)项目部署 || 全服务器部署(宝塔面板)全流程 || 前端Netlify + 后端服务器 部署对比

一、 部署需要分「前端」「后端」「数据库」三个部分

优先选低成本 + 易操作的组合:

  • 前端:免费静态托管平台(Netlify/Vercel,无需服务器)
  • 后端:云服务器(学生机,每月 9 元起)
  • 数据库:云服务器内置 MySQL(或用免费云数据库)
下文的部署采用的是全服务器部署方式,即前后端都部署到云服务器上

二、第一步:部署前端(Vue 项目,免费 + 5 分钟完成)

  1. 本地打包前端代码
    在 Vue 项目根目录执行命令,生成静态文件目录dist:
npm run build 
  1. 部署到 Netlify(免费、自动构建、带 HTTPS)
    (如果是全服务器部署,此步骤可以跳过)
    把前端代码推到 GitHub/Gitee 仓库(已有仓库可跳过);
    打开Netlify 官网,用 GitHub/Gitee 账号登录;
    点击「Add new site」→「Import an existing project」,选择你的前端仓库;
    配置构建参数(Netlify 会自动识别 Vue 项目,默认即可):
    构建命令:npm run build
    发布目录:dist
    点击「Deploy site」,等待 2 分钟,Netlify 会生成一个免费域名(如your-site.netlify.app),前端部署完成。

三、第二步:部署后端(Java/SpringBoot,学生机低成本)

  1. 购买学生云服务器
    推荐腾讯云轻量应用服务器(学生机):
    价格:2 核 2G/1M 带宽,每月 9 元(需学生认证);
    系统:选CentOS 7.x(Linux 系统,稳定常用,宝塔面板部署)。
  2. 服务器环境配置(用宝塔面板可视化操作)
    登录腾讯云服务器控制台,通过「WebShell」登录服务器;
    安装宝塔面板(可视化管理服务器):
wget -O install.sh http://download.bt.cn/install/install_6.0.sh &&bash install.sh 

这个命令只需要输入一次,记住给的账号和密码,下次再次登录,直接使用外网地址就行,重复运行会导致内存挤压,程序崩溃

登录宝塔面板


安装完成后,记录宝塔的登录地址(如http://服务器IP:8888)、账号密码;
登录宝塔面板,一键安装「LNMP 套件」(包含 Nginx/MySQL/Node.js)。

⚠ 如果忘记宝塔界面登录密码,重置方法:
cmd + R打开终端面板,输入 ssr 用户名@主机服务器ip指定 SSR 客户端连接代理服务器

接着输入下面的代码

cd /www/server/panel && btpython tools.py panel 你的重置密码 
宝塔面板密码重置


当看见命令行返回了你宝塔账户的用户名,就证明你成功地重置了密码。
完成以上操作就可以重新登录宝塔面板啦!

四、第三步:部署数据库(MySQL,服务器内置)

宝塔面板→「软件商店」→安装MySQL 8.0;
点击「设置」→「数据库」→「添加数据库」:
数据库名:quiz_db
用户名 / 密码:自定义(如quiz_user/123456);
导入本地数据库脚本:
本地导出 SQL 文件,在宝塔「数据库」→「导入」上传 SQL 文件。

如果出现报错信息:mysqldump: [ERROR] unknown variable ‘collation=utf8mb4_general_ci’.
数据库部署报错信息


✅ 本地 DataGrip 连接的是 MySQL 8.0 版本,导出的 SQL 里自带了高版本专属的排序规则 utf8mb4_0900_ai_ci;✅ 服务器宝塔的 MySQL 版本是 5.7/5.6 版本,不认识这个高版本规则,直接拒绝导入,同时连带报表不存在(因为建表语句第一步就执行失败了)。

五、第四步:连接前后端 + 配置域名

  1. 后端配置数据库
    修改 SpringBoot 项目的application.yml,将数据库连接改为服务器的 MySQL:
spring:datasource:url: jdbc:mysql://服务器IP:3306/quiz_db?useSSL=false&serverTimezone=Asia/Shanghaiusername: quiz_user password:123456

打包 jar 包,上传到服务器并启动后端服务。
部署后端代码具体步骤:

  1. 本地打包 SpringBoot 项目为jar包: IDEA 中执行mvn package,生成target/xxx.jar;
  2. 上传jar 包到服务器: 宝塔面板→「文件」→新建目录(如/www/backend),上传 jar 包;
  3. 启动后端服务:
    • 安装「PM2
      管理器」、「Java项目项目管理器」(宝塔软件商店);
    • 点击左侧导航栏「网站」→「Java项目」: 项目名称:自定义(如quiz-backend)
      • 启动文件:选择上传的 jar 包 启动命令:java -jar xxx.jar --server.port=8080(指定端口);

使用Nginx进行反向代理
「网站」→「PHP项目」→ 「添加站点」

Nginx创建节点


项目前端dist文件结构

前端打包成静态资源放在和jar同一目录下

项目结构

完成创建后项目会自动启动,后端服务在服务器8080端口运行。

项目后端部署

六、最终访问

公网访问链接


将这个网址发给你的朋友,他们就可以访问你的网站啦!

以上采用的是全服务器部署策略,若是采用前端Netlify部署 + 后端服务器部署,Netlify会强制将http请求转换成https请求,而https请求若是没有部署ssl证书和域名的加持,浏览器会识别成不安全网站,向后端请求资源的行为会被拦截

解决方案有两个:

方案一:全服务器部署 ,使用http请求(即上文提到的部署方式)

  • 将前后端都部署在云服务器上,使用http请求和默认80端口,将前端项目打包,上传至后端项目
    所在文件夹,使用Nginx进行反向代理
  • 核心优势是 “零额外成本”(无需买域名、SSL 证书),适合个人测试、小型 demo 或非公开项目;
  • 缺点: “HTTP” 有安全性缺陷(数据传输未加密,适合非敏感场景),且无法使用需要 HTTPS 的功能(如浏览器定位、PWA、部分第三方 API); 前端静态资源和后端 API 都依赖同一台服务器的带宽和性能,若访问量增大,可能需要升级服务器配置;
  • Nginx 的作用:监听服务器的 80 端口(HTTP 默认端口),当用户访问http://服务器IP时,Nginx 会 “转发请求”—— 静态资源(页面、CSS、JS)直接返回前端文件,API 请求(如/api/login)转发到后端的 8080 端口

请求发送流程图:

1. 在浏览器输入:http://服务器IP2. 80端口请求进入Nginx3. 判断请求类型:静态资源(页面/CSS/JS)3. 判断请求类型:API接口(如/api/login)4. 返回静态资源4. 处理API请求,返回数据(如JSON)5. Nginx将结果返回给浏览器6. 浏览器渲染页面,展示内容

用户

云服务器(公网IP)

Nginx反向代理

服务器本地:前端静态文件(dist文件夹)

服务器本地:后端服务(8080端口)

用户看到最终页面

方案二:Netlify 前端 + 服务器后端 , 使用https请求

  • 核心优势是 “生产级正式性”(HTTPS 加密、自定义域名),适合公开项目、面向用户的产品,但需承担域名 / SSL 成本(部分 SSL 免费),并遵守备案规则;前端静态资源由 Netlify 的 CDN(全球分发网络)加载,用户访问页面更快(就近获取资源),后端仅需处理 API 请求,服务器压力更小,更适合有一定访问量的项目。
  • 后端服务器配置 SSL 证书(通过 Nginx 或后端框架本身),让后端接口支持https://你的域名:8080/api(或用 Nginx 监听 443 端口,转发到 8080,隐藏端口)—— 否则前端(HTTPS)调用后端(HTTP)仍会被浏览器拦截(混合内容错误)。

如果坚持将前端部署在Netlify上,需要购买域名,申请SSL证书,购买域名后,需要解析域名(DNS[ Domain Name System]解析),与自己的服务器进行绑定,但是,这个方法,如果是在腾讯云购买域名,会提示你,只有备案过的域名才能进行解析,但是,只有购买期超过三个月的域名才能够备案

申请ssl证书失败

请求发送流程图:

1. 输入: https://你的自定义域名2. 加载前端静态资源3. 返回前端页面 完成初步渲染4. 前端发起接口请求: https://你的域名/api5. 解析域名 → 云服务器公网IP6. 转发请求到本机后端7. 处理业务 返回JSON数据8. HTTPS加密返回数据9. 把接口数据返回前端

用户浏览器

Netlify CDN服务器

Netlify 存储前端打包文件

DNS域名解析服务器

云服务器 443端口 HTTPS

Nginx 反向代理 已配置SSL证书

云服务器本地 后端服务 8080端口

浏览器渲染接口数据 展示最终完整页面

简言之,方案一更加省钱,但是,方案二是更为正式稳健的一种部署方案。

Read more

Flutter for OpenHarmony:blurhash_dart 优雅的图片加载占位符(提升视觉体验的黑科技) 深度解析与鸿蒙适配指南

Flutter for OpenHarmony:blurhash_dart 优雅的图片加载占位符(提升视觉体验的黑科技) 深度解析与鸿蒙适配指南

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在移动应用中,图片加载是一个关键的体验点。网络环境不佳时,图片区域长时间显示白屏或灰底,用户体验非常割裂。 传统的做法是放一个 Loading 转圈或固定的占位图,但这种方式依然比较生硬。 BlurHash 是一种革命性的占位符技术。它将图片压缩成一段只有二三十个字符的短字符串。客户端只需要这段字符串,就能瞬间(< 1ms)在本地解码并渲染出一个模糊但色调与原图一致的占位图。 blurhash_dart 是该算法的 Dart 纯实现版本。对于 OpenHarmony 应用,这意味着你可以在不增加太多带宽成本的情况下,实现如丝般顺滑的各种图片加载过渡效果。 一、核心原理与效果 1.1 什么是 BlurHash? BlurHash 算法基于 离散余弦变换 (DCT),类似于 JPEG 的压缩原理,但它只保留最低频的颜色信息(Base83 编码)。 * 输入:

By Ne0inhk
Flutter for OpenHarmony: Flutter 三方库 fake_async 掌控时间的魔法,让鸿蒙异步单测快如闪电(单元测试加速神器)

Flutter for OpenHarmony: Flutter 三方库 fake_async 掌控时间的魔法,让鸿蒙异步单测快如闪电(单元测试加速神器)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在 OpenHarmony 应用的单元测试中,异步逻辑是一个避不开的难点。如果你的代码中有 Future.delayed(Duration(minutes: 5)),难道你在跑测试时真的要等上 5 分钟吗?或者如果你在测试一个复杂的动画状态流转,如何精确地模拟时间流逝了 125 毫秒? fake_async 是 Dart 测试工具链中的“时间胶囊”。它能在一个受控的环境中虚拟化时钟。你可以瞬间“拨快”时间,让那些原本需要漫长等待的异步操作立即执行,从而让你的鸿蒙单测运行速度提升千倍。 一、核心虚拟时间原理 它通过接管全局的 Zone,拦截了所有基于时间的调度任务。 elapse(5 mins) 测试用例 fakeAsync 闭包环境 挂起的延迟任务 (Future/Stream) 瞬间拨快虚拟时钟

By Ne0inhk
【HarmonyOS 6 特别发布】鸿蒙 6 正式登场:功能升级,构建跨设备安全流畅新生态

【HarmonyOS 6 特别发布】鸿蒙 6 正式登场:功能升级,构建跨设备安全流畅新生态

文章目录 * 前言 * 一、好看好玩的 HarmonyOS 6 * 二、好用的 HarmonyOS 6 * 三、智能的 HarmonyOS 6 * 四、安心的 HarmonyOS 6 * 五、丝滑的 HarmonyOS 6 * HarmonyOS 6 升级计划 * 小结 前言 2025 年 10 月 22 日 14:30,华为正式发布新一代鸿蒙操作系统 HarmonyOS 6。HarmonyOS 6 系统全面进化,无论是流畅度、智能化程度,还是跨设备协同等,都能让你感受到无缝、便捷的交互体验。更好看,更好用,更智能,更安全,

By Ne0inhk
Flutter for OpenHarmony: Flutter 三方库 shamsi_date 助力鸿蒙应用精准适配波斯历法(中东出海必备)

Flutter for OpenHarmony: Flutter 三方库 shamsi_date 助力鸿蒙应用精准适配波斯历法(中东出海必备)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在进行 OpenHarmony 的全球化(Internationalization)应用开发时,进军中东市场(尤其是波斯语地区)是一项充满潜力的战略。但在这些地区,用户习惯使用的并非公历(Gregorian),而是 波斯历(Shamsi/Jalali)。 1. 如何将用户的生日从公历转换成波斯历? 2. 鸿蒙应用的时间轴、日历选择器如何呈现 Jalali 格式? 3. 业务系统中的合同到期日如何按波斯历进行逻辑计算? shamsi_date 是 Dart 生态中处理波斯历法的权威库。它提供了极其简单的转换 API,是你开发鸿蒙出海应用、打入中东市场的关键技术补丁。 一、历法转换算法模型 shamsi_date 实现了公历与波斯历之间的双向精准映射。 Conversion Conversion 公历 (2024-02-20) 波斯历 (1402-12-01)

By Ne0inhk