常见前端GET请求以及对应的Spring后端接收接口写法

ⅰ. 前端 GET 请求的常见写法

1. 直接拼接 URL 参数(最基础)
复制代码
export const getList = (current, size, project, header) => {
  return request({
    url: `/blade-bpConfigur/bpTable/list?current=${current}&size=${size}&project=${project}&header=${header}`,
    method: 'get'
  });
};

特点

• 手动拼接 URL,适合参数少且固定的场景。

• 需自行处理参数编码(如 encodeURIComponent)。

2. 使用 params 对象(推荐)
复制代码
export const getList = (current, size, params) => {
  return request({
    url: '/blade-bpConfigur/bpTable/list',
    method: 'get',
    params: {  // Axios/umi-request 会自动将 params 拼接到 URL
      current,
      size,
      ...params  // 将params属性展开
    }
  });
};

特点

• 代码更简洁,自动处理 URL 编码。

• 参数可动态扩展。

a. 3. 使用 URLSearchParams
复制代码
const query = new URLSearchParams({
  current: 1,
  size: 10,
  project: "隆基西安北郊",
  header: "梁恩伟"
}).toString();

export const getList = () => {
  return request({
    url: `/blade-bpConfigur/bpTable/list?${query}`,
    method: 'get'
  });
};

特点

• 浏览器原生 API,适合非 Axios 场景。

• 自动处理特殊字符编码。

ⅰ. 后端对应的GET请求接收方式

1. 方式一:实体类直接接收(推荐)
复制代码
@GetMapping("/list")
public R<IPage<BpTableVO>> list(BpTable bpTable, Query query) {
    // Spring 自动将 URL 参数注入到 bpTable 和 query 对象
    IPage<BpTable> pages = bpTableService.page(Condition.getPage(query), Condition.getQueryWrapper(bpTable));
    return R.data(BpTableWrapper.build().pageVO(pages));
}

匹配规则

• URL 参数名必须与 BpTable 实体字段名一致(如 projectBpTable.project)。

• 分页参数 currentsize 会被注入到 Query 对象。

原因:

Spring 的隐式绑定规则,当参数是 自定义对象(如 BpTable**)** 时,Spring 会 自动遍历其字段名,尝试从 URL 参数中匹配同名值注入

多余参数

实体类中存在但前端未传递的字段(如实体类有 address 字段,但 JSON 中无此字段)。

  • 结果 :该字段保持 null 或默认值,不会报错

变量名不匹配

实体类字段名与 JSON 键名不一致(如实体类用 projectName,JSON 中用 project)。

  • 结果 :该字段无法自动注入,保持 null
2. 方式二:使用 @RequestParam 注解
复制代码
@GetMapping("/list")
public R<IPage<BpTableVO>> list(
    @RequestParam String project,
    @RequestParam String header,
    @RequestParam Integer current,
    @RequestParam Integer size
) {
    BpTable bpTable = new BpTable();
    bpTable.setProject(project);
    bpTable.setHeader(header);
    
    Query query = new Query();
    query.setCurrent(current);
    query.setSize(size);
    
    IPage<BpTable> pages = bpTableService.page(Condition.getPage(query), Condition.getQueryWrapper(bpTable));
    return R.data(BpTableWrapper.build().pageVO(pages));
}

原因:Spring MVC 默认要求显式声明非对象参数的来源。

适用场景

• 参数较少时使用,灵活性较差。

• 需手动构建实体类。

默认行为

若方法参数标注了 @RequestParam,但前端未传递同名参数,Spring 会抛出:
MissingServletRequestParameterException: Required parameter 'xxx' is not present

3. 方式三:接收 MapMultiValueMap
复制代码
@GetMapping("/list")
public R<IPage<BpTableVO>> list(@RequestParam Map<String, Object> params) {
    BpTable bpTable = new BpTable();
    bpTable.setProject((String) params.get("project"));
    bpTable.setHeader((String) params.get("header"));
    
    Query query = new Query();
    query.setCurrent(Integer.parseInt(params.get("current").toString()));
    query.setSize(Integer.parseInt(params.get("size").toString()));
    
    IPage<BpTable> pages = bpTableService.page(Condition.getPage(query), Condition.getQueryWrapper(bpTable));
    return R.data(BpTableWrapper.build().pageVO(pages));
}

特点

• 适合动态字段(参数名不固定)。

• 需手动处理类型转换。

相关推荐
子兮曰几秒前
🌏浏览器硬件API大全:30个颠覆性技术让你重新认识Web开发
前端·javascript·浏览器
ponnylv3 分钟前
深入剖析Spring Boot自动配置原理
spring boot·spring
即兴小索奇4 分钟前
Google AI Mode 颠覆传统搜索方式,它是有很大可能的
前端·后端·架构
kyle~4 分钟前
排序---快速排序(Quick Sort)
java·开发语言
大虾写代码12 分钟前
nvm和nrm的详细安装配置,从卸载nodejs到安装NVM管理nodejs版本,以及安装nrm管理npm版本
前端·npm·node.js·nvm·nrm
星哥说事13 分钟前
下一代开源 RAG 引擎,让你的 AI 检索与推理能力直接起飞
前端
....49213 分钟前
Vue3 与 AntV X6 节点传参、自动布局及边颜色控制教程
前端·javascript·vue.js
LucianaiB16 分钟前
我用LazyLLM做了一个打工人述职Agent,朋友直呼打工人的福利,太完美了
后端
machinecat16 分钟前
Webpack模块联邦 - vue项目嵌套react项目部分功能实践
前端·webpack
今禾17 分钟前
深入浅出:ES6 Modules 与 CommonJS 的爱恨情仇
前端·javascript·面试