初级程序员必备的十大技能之 API 接口与前后端联调(五)

简介: 教程来源 https://xgmoi.cn/ 本文系统梳理API联调核心知识:涵盖CORS跨域、404/401/403错误排查、数据格式转换、重复请求防控等高频问题及代码级解决方案;详解接口文档规范与Swagger自动化实践,并总结HTTP协议、RESTful设计、前端封装、调试工具等完整知识体系。

七、常见问题与解决方案

7.1 跨域问题(CORS)
问题:浏览器报错 No 'Access-Control-Allow-Origin' header is present

原因:浏览器的同源策略,前端和后端端口/域名不同时被阻止。

解决方案:

// 方案1:后端配置 CORS(推荐)
// Node.js + Express
const cors = require('cors');
app.use(cors({
  origin: 'http://localhost:3000',  // 允许的前端地址
  credentials: true,                 // 允许携带 Cookie
  methods: ['GET', 'POST', 'PUT', 'DELETE'],
  allowedHeaders: ['Content-Type', 'Authorization']
}));

// 方案2:开发时代理(Vite)
// vite.config.js
export default {
  server: {
    proxy: {
      '/api': {
        target: 'http://localhost:8080',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, '')
      }
    }
  }
};

// 方案3:Nginx 反向代理
location /api/ {
    proxy_pass http://backend-server:8080/;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
}

7.2 接口报 404
排查步骤:

检查 URL 是否正确

检查请求方法(GET/POST)是否匹配

检查服务器是否启动

检查路由是否注册

// 调试方法
console.log('请求URL:', url);
console.log('请求方法:', method);

// 在 Network 面板查看实际请求
// 查看 Request URL 是否拼写正确

7.3 接口报 401/403
401 Unauthorized:未认证(没有 token 或 token 过期)
403 Forbidden:已认证但无权限

// 处理 token 过期
instance.interceptors.response.use(
  response => response,
  error => {
    if (error.response?.status === 401) {
      // 清除本地存储
      localStorage.removeItem('token');
      // 跳转到登录页
      window.location.href = '/login';
      // 可以尝试刷新 token
      return refreshToken().then(() => {
        return instance.request(error.config);
      });
    }
    return Promise.reject(error);
  }
);

7.4 数据格式不一致

// 问题:后端返回 camelCase,前端用 snake_case
// 后端:{ user_name: "张三" }
// 前端:data.userName → undefined

// 解决方案1:统一规范(推荐)
// 前后端约定都使用 camelCase

// 解决方案2:转换函数
function toCamelCase(obj) {
  if (typeof obj !== 'object' || obj === null) return obj;

  if (Array.isArray(obj)) {
    return obj.map(toCamelCase);
  }

  return Object.keys(obj).reduce((acc, key) => {
    const camelKey = key.replace(/_([a-z])/g, (_, letter) => letter.toUpperCase());
    acc[camelKey] = toCamelCase(obj[key]);
    return acc;
  }, {});
}

// 使用
const response = await fetch('/api/user');
const data = toCamelCase(await response.json());

7.5 重复请求问题

// 防抖(Debounce):输入框搜索
function debounce(fn, delay) {
  let timer;
  return function(...args) {
    clearTimeout(timer);
    timer = setTimeout(() => fn.apply(this, args), delay);
  };
}

const searchUsers = debounce(async (keyword) => {
  const result = await userApi.searchUsers(keyword);
  setSearchResult(result);
}, 300);

// 节流(Throttle):滚动加载更多
function throttle(fn, delay) {
  let lastTime = 0;
  return function(...args) {
    const now = Date.now();
    if (now - lastTime >= delay) {
      fn.apply(this, args);
      lastTime = now;
    }
  };
}

// 取消重复请求(使用 AbortController)
const abortController = new AbortController();

fetch('/api/search', { signal: abortController.signal });

// 发起新请求前取消上一个
if (currentRequest) {
  currentRequest.abort();
}
currentRequest = new AbortController();

八、接口文档管理

8.1 文档必备内容

# 用户管理 API

## 基础信息
- Base URL: `https://api.example.com/v1`
- 认证方式: Bearer Token
- 请求格式: application/json
- 响应格式: application/json

## 错误码说明
| 错误码 | 说明 |
|--------|------|
| 40001 | 用户名不存在 |
| 40002 | 密码错误 |
| 40100 | token 过期 |

## 接口列表

### 获取用户信息

**接口**: `GET /users/{id}`

**路径参数**:
| 参数 | 类型 | 必填 | 说明 |
|------|------|------|------|
| id | int | 是 | 用户ID |

**请求示例**:

GET /api/v1/users/123
Authorization: Bearer xxxxx


**响应示例**:
```json
{
  "code": 200,
  "data": {
    "id": 123,
    "name": "张三",
    "email": "zhangsan@example.com"
  }
}

### 8.2 自动化文档(Swagger UI)

```javascript
// 安装 swagger-jsdoc
npm install swagger-jsdoc swagger-ui-express

// swagger.js
const swaggerJsdoc = require('swagger-jsdoc');

const options = {
  definition: {
    openapi: '3.0.0',
    info: {
      title: 'API 文档',
      version: '1.0.0',
    },
    servers: [{ url: 'http://localhost:3000/api' }],
    components: {
      securitySchemes: {
        bearerAuth: {
          type: 'http',
          scheme: 'bearer',
          bearerFormat: 'JWT'
        }
      }
    },
    security: [{ bearerAuth: [] }]
  },
  apis: ['./routes/*.js']
};

module.exports = swaggerJsdoc(options);

// 使用
const swaggerUi = require('swagger-ui-express');
const swaggerSpec = require('./swagger');

app.use('/api-docs', swaggerUi.serve, swaggerUi.setup(swaggerSpec));

附:知识体系总结

API 接口与前后端联调
├── HTTP 协议
│   ├── 请求方法(GET、POST、PUT、DELETE、PATCH)
│   ├── 状态码(2xx、3xx、4xx、5xx)
│   └── Headers(Content-Type、Authorization)
├── RESTful 设计
│   ├── 资源命名(名词、复数、子资源)
│   ├── 统一响应格式
│   └── 错误处理
├── 前端联调
│   ├── 请求封装(拦截器、错误处理)
│   ├── 状态管理(loading、error、data)
│   └── Mock 数据
├── 调试工具
│   ├── Postman/Apifox
│   ├── 浏览器 DevTools
│   └── Swagger 文档
└── 常见问题
    ├── CORS 跨域
    ├── Token 管理
    ├── 重复请求
    └── 超时重试

来源:
https://amwtm.cn/

相关文章
|
1天前
|
前端开发 JavaScript 程序员
初级程序员必备的十大技能之开发工具熟练使用(三)
教程来源 https://bncne.cn/ 浏览器开发者工具是前端调试核心利器,涵盖Elements(实时编辑DOM/CSS)、Console(日志、断点、DOM操作)、Sources(多类型断点与作用域调试)、Network(请求分析与模拟)、Performance(性能指标与火焰图)及Application(存储管理)六大面板,全面提升开发效率。
|
1天前
|
前端开发 程序员 开发工具
初级程序员必备的十大技能之开发工具熟练使用(四)
教程来源 https://tmywi.cn/ VS Code深度集成Git:快捷键操作、冲突可视化解决;GitLens增强代码溯源与历史追踪;配合高效命令行别名与撤销技巧;辅以Node/前端多维调试方案,全面提升开发效能。
|
1天前
|
程序员 Shell 持续交付
初级程序员必备的十大技能之开发工具熟练使用(二)
教程来源 https://zlpow.cn/ 命令行是程序员高效开发的“第二语言”:涵盖文件操作、进程管理、网络诊断、管道重定向、Shell脚本及终端增强工具,助你快速定位问题、批量处理任务、自动化部署,全面提升系统操控力与生产力。
|
1天前
|
Linux 程序员 网络安全
初级程序员必备的十大技能之基础 Linux 命令(一)
教程来源 https://qcycj.cn/ 本文系统讲解程序员必备的Linux核心命令,涵盖文件操作、文本处理、权限管理、进程与网络工具等,结合原理、参数详解及实战案例,助你高效部署、排查与运维——无论用Windows还是macOS,Linux都是程序员不可或缺的“第二操作系统”。
|
1天前
|
前端开发 JavaScript 程序员
初级程序员必备的十大技能之 API 接口与前后端联调(四)
教程来源 https://ltglu.cn/ Postman、Apifox与Swagger是主流API调试与文档工具:Postman侧重灵活调试与脚本测试;Apifox国产集成强,支持文档/Mock/测试一体化;Swagger(OpenAPI)专注标准化接口定义,助力前后端契约开发与协同。
|
1天前
|
JSON 前端开发 程序员
初级程序员必备的十大技能之 API 接口与前后端联调(三)
教程来源 https://wkmsa.cn/ 本节详解前后端联调完整流程:涵盖接口设计约定(含规范文档示例)、Mock数据并行开发(代码/JSON Server/Mock.js三方式)、前端API封装最佳实践(拦截器、模块化、组件调用),以及主流请求库对比与Axios封装示例,助力高效协同开发。
|
1天前
|
程序员 API 网络架构
初级程序员必备的十大技能之 API 接口与前后端联调(二)
教程来源 https://vrhyh.cn/ RESTful API 是基于资源的标准化接口设计风格,强调名词化URI、HTTP方法语义化(GET/POST/PUT/PATCH/DELETE)、无状态通信与统一响应格式,提升可读性、可维护性与前后端协作效率。
|
1天前
|
程序员 测试技术 API
初级程序员必备的十大技能之开发工具熟练使用(五)
教程来源 https://oplhc.cn/ 本节精选6大类高效开发工具:全局搜索(Alfred/Everything)、笔记与代码片段(Obsidian/Snipaste)、终端管理(iTerm2)、API测试(curl/Postman)、数据库(DBeaver/DataGrip)、正则调试(regex101)。覆盖日常编码全链路,提升检索、记录、调试与协作效率。
|
1天前
|
人工智能 IDE 程序员
初级程序员必备的十大技能之开发工具熟练使用(一)
教程来源 https://qeext.cn/ 本文面向初级程序员,系统讲解VS Code等核心开发工具的高效用法:涵盖编辑器配置、终端/ Git /调试技巧、AI编程(Cursor)、快捷键与插件实战,助你从“手动搬砖”跃升为“智能工匠”,大幅提升编码、调试与协作效率。
|
23天前
|
编解码 数据可视化 前端开发
前端组件库——DataV知识点大全(二)
教程来源 https://www.xbivx.cn DataV提供40+高质量组件,涵盖边框(13种SVG动画边框)、装饰、数字翻牌器、滚动表格、水位图、锥形柱图、飞线图及全屏容器等,支持高度自定义与响应式适配,助力快速构建专业数据大屏。

热门文章

最新文章