【web应用】前后端分离项目基本框架组成:Vue + Spring Boot 最佳实践指南

文章目录


前言

本文基于真实项目经验,系统梳理前后端分离架构下的开发规范、协作流程与部署实践,适用于 Vue + Spring Boot 技术栈,帮助团队快速搭建可维护、可扩展的现代化 Web 应用。

一、项目结构与角色边界

1、整体目录约定

text 复制代码
project-root
├── frontend/            # Vue 前端
│   ├── src/api          # 接口封装
│   ├── src/views        # 业务页面
│   ├── src/router       # 前端路由
│   └── .env.*           # 多环境变量
├── backend/             # Spring Boot 后端
│   ├── src/main/java
│   │   ├── controller   # REST 接口
│   │   ├── service      # 业务逻辑
│   │   ├── repository   # 数据访问
│   │   └── config       # 统一配置
│   └── pom.xml
├── deploy/              # Docker & K8s 部署脚本
└── docs/                # Swagger/YApi 接口文档

2、角色职责与协作流程

阶段 前端 后端 共同点
需求评审 评估交互工作量 评估业务/数据工作量 输出接口粒度
接口定义 提供 UI 需要的数据结构 编写 Swagger/YApi 并生成 Mock 评审后锁定接口文档
开发 使用 Mock 数据并行开发 实现业务逻辑 & 单元测试 Git Flow 分支管理
联调 切换代理到真实后端 打开 Swagger 在线调试 使用 Postman 做契约测试
上线 构建静态包→CDN Docker 镜像→K8s/虚拟机 CI/CD 同 Pipeline

二、接口设计规范

1、RESTful URL + 版本控制

复制代码
GET    /api/v1/users?page=1&size=20
POST   /api/v1/users
PUT    /api/v1/users/{id}
DELETE /api/v1/users/{id}

2、统一返回体

json 复制代码
{
  "code": 0,
  "msg": "success",
  "data": { ... },
  "traceId": "c0a8644e166..."
}

3、自动生成文档

Springfox/Knife4j 一键扫描注解 → 前端可直接在线调试,无需 Postman 导入。

三、安全与质量红线

维度 实践要点
认证 JWT + Spring Security;Token 存 HttpOnly Cookie 或 Authorization Header
鉴权 @PreAuthorize("hasRole('ADMIN')")
参数校验 DTO 层 @Validated + Hibernate Validator
跨域 Spring 全局 CORS 配置或使用 Gateway 统一处理
敏感数据 统一脱敏 + 返回最小化原则
审计日志 AOP 记录所有请求耗时、参数、返回值与异常

四、前端工程化实践

  1. 请求封装 :基于 Axios 的 src/api/request.ts 自动携带 Token、统一错误提示。
  2. 环境变量.env.development / .env.production 区分代理地址。
  3. 路由守卫 :动态加载菜单 + 权限指令 v-permission
  4. 构建优化:Vite/Webpack 拆包 + CDN + Gzip,首屏 < 1.5 s。

五、后端可观测性

能力 技术方案
日志 Logback + ELK 收集
链路追踪 Spring Cloud Sleuth → Zipkin
指标 Micrometer → Prometheus → Grafana Dashboard
告警 PrometheusRule 钉钉/飞书机器人

六、部署与 CI/CD

  1. 容器化

    • 前端:nginx:alpine 静态镜像,大小 < 20 MB。
    • 后端:多阶段 Dockerfile mvn packageopenjdk:17-jre-slim
  2. 流水线示例(GitLab CI)

    yaml 复制代码
    stages: [build, docker, deploy]
    build:frontend:
      script: cd frontend && npm ci && npm run build
    build:backend:
      script: cd backend && mvn -B package -DskipTests
    deploy:k8s:
      script: helm upgrade --install app chart/
  3. 灰度发布:K8s Ingress + Nginx 权重分流,支持秒级回滚。

七、团队协作 Tips

  • 接口变更:通过 YApi 的「通知」功能告知全员,旧版本保留 2 个 Sprint。
  • Mock 数据:Mock.js 自动拦截 Ajax 请求,支持随机图片、延迟返回。
  • 代码规范:前端 ESLint + Prettier,后端 Spotless + Checkstyle,提交前 Git Hook 强制格式化。

相关推荐
养鱼的程序员5 分钟前
零基础搭建个人网站:从 Astro 框架到 GitHub 自动部署完全指南
前端·后端·github
罗行9 分钟前
手写防抖和节流
前端·javascript
前端老鹰9 分钟前
CSS :is () 与 :where ():简化复杂选择器的 “语法糖”
前端·css·html
颜酱13 分钟前
理解并尝试vue3源码的reactivity
前端·javascript·vue.js
苏州第一深情21 分钟前
【uniapp】uniapp实现单点登录、打包H5部署到线上
javascript·vue.js·uni-app
拉不动的猪21 分钟前
jS篇Async await实现同步效果的原理
前端·javascript·面试
杨充26 分钟前
03.接口vs抽象类比较
前端·后端
chxii38 分钟前
2.4 组件通信
前端·javascript·vue.js
SteveCode.1 小时前
SpringBoot 2.x 升 3.x 避坑指南:企业级项目的实战问题与解决方案
java·spring boot
泡岩浆的child1 小时前
朋友:你平常都用什么软件取色?我:QQ截图啊。朋友:牛X!
前端