首页 > 其他分享 >前后端接口写法(传输数据)

前后端接口写法(传输数据)

时间:2024-04-07 21:31:36浏览次数:34  
标签:return 请求 RequestParam 接口 传输数据 参数 doWeekPlan save 写法

目录

前言

对于后端常用的两个注解:详细分析Java中的@RequestParam和@RequestBody

以下文章主要用于笔记总结,后续可翻看

1. 零散数据

前端数据

export const doWeekPlan = (ids,selectedPeriod) => {
  return request({
    url: '/api/blade-equipment/inforunningdata/doWeekPlan',
    method: 'post',
    params: {
      ids,
      selectedPeriod
    }
  })
}

此时需要带上@RequestParam ,也可以不要@RequestParam

@PostMapping("/doWeekPlan")
@ApiOperationSupport(order = 10)
@ApiOperation(value = "周计划" , notes = "传入infoRunningDataVO")
public R doWeekPlan(@RequestParam Long ids,@RequestParam String selectedPeriod){
	Result result = null;
	try {
		result = infoRunningDataService.doWeekPlan(ids,selectedPeriod);
		return R.status(result.getIsTrue());
	}catch (Exception e){
		return R.fail(e.getMessage());
	}
}

带不带@RequestParam 的差异之处在于:

使用了 @RequestParam 注解,需明确指定每个参数的名称,并且参数是作为请求的一部分发送的,特别是Get请求

没有使用 @RequestParam 注解,而是直接将参数作为方法的参数传递。这种写法通常适用于 POST 请求,其中参数是通过请求体发送的。Spring 框架默认会将请求体中的数据与方法参数进行绑定

如果数据是通过请求体发送的,并且想要保持代码更加简洁,可以选择不使用 @RequestParam 注解。但如果明确指定参数名称或者处理 GET 请求,那么第一种写法会更加合适

2. 函数体

以下为get请求:

export const getList = (current, size, params,tenantId) => {
  return request({
    url: '/api/blade-equipment/inforunningdata/list',
    method: 'get',
    params: {
      ...params,
      current,
      size,
      tenantId
    }
  })
}

后端数据

@GetMapping("/list")
@ApiOperationSupport(order = 2)
@ApiOperation(value = "分页", notes = "传入infoRunningData")
public R<IPage<InfoRunningDataVO>> list(InfoRunningData infoRunningData, Query query,String tenantId) {
	IPage<InfoRunningData> pages = infoRunningDataService.page(Condition.getPage(query),
		Condition.getQueryWrapper(infoRunningData).eq("tenant_id",tenantId));
	return R.data(InfoRunningDataWrapper.build().pageVO(pages));
}

如果是post请求:

export const add = (row) => {
  return request({
    url: '/api/blade-equipment/weekplan/save',
    method: 'post',
    data: row
  })
}

后端

@PostMapping("/save")
@ApiOperationSupport(order = 4)
@ApiOperation(value = "新增", notes = "传入weekPlan")
public R save(@Valid @RequestBody WeekPlan weekPlan) {
	boolean save = weekPlanService.save(weekPlan);
	if(save == false){
		String errorMessage = "存在如下周计划:\n" +
			"机种:" + weekPlan.getParentModel() + "\n" +
			",时间段:" + weekPlan.getPlanTime() + "\n";
		throw new RuntimeException(errorMessage);
	}
	return R.status(save);
}

需要在请求体中发送一个对象时,使用 @RequestBody 注解以及 POST 请求。
需要发送一系列查询参数时,使用 GET 请求,并将参数作为查询参数发送

3. 总结

对于新增操作:(适用于需要创建新资源的场景)
前端通常使用 POST 请求,并将数据作为请求的主体发送到后端
后端使用 @RequestBody 注解来接收请求体中的数据

对于查询操作:(根据特定条件检索数据的场景)
前端通常使用 GET 请求,并将查询参数作为 URL 的一部分发送到后端
后端使用 @RequestParam 或直接作为方法参数来接收查询参数

两种写法都是有效的,但适用于不同的场景,具体选择取决于需求和偏好
在设计接口时,需要考虑到前后端数据的传输方式、请求类型以及参数的处理方式,以便实现更好的交互和数据传递

标签:return,请求,RequestParam,接口,传输数据,参数,doWeekPlan,save,写法
From: https://blog.csdn.net/weixin_47872288/article/details/137462590

相关文章

  • 调用方使用“复杂接口”与“是否使用事务”
    问题“底层能力接口比较复杂,涉及到多个表的更新操作以及外部rpc的接口调用,并且部分接口使用了事务,支持回滚。”上面这种接口直接对外提供rpc接口是没问题的,因为内部已经保证了数据的一致性;但是如果直接提供给其他serviceA方法调用(非rpc调用),serviceA调用方是否使用事务,会发生不......
  • 携程景点详情数据API接口丨携程景点详情数据采集接口丨携程API接口文档
    携程景点详情数据API接口是用于获取特定景点详细信息的编程接口。要使用这个API接口,你需要遵循以下步骤:注册开发者账号:访问携程开放平台,并注册成为一个开发者。创建应用并获取权限:在携程开放平台上创建一个应用,并获取相应的API权限。构建请求:根据文档指导,构建HTTP请求,设置必......
  • 携程获取景点列表API接口丨携程景点API接口丨携程API接口文档
    携程获取景点列表API接口为开发者提供了一种方便的方式来获取景点的详细信息。以下是使用该API接口的具体步骤:注册开发者账号:您需要在携程开放平台注册一个开发者账号,这是使用API接口的前提条件。创建应用并获取API密钥:登录到您的开发者账号后,创建一个新的应用,并获取相应的API......
  • 携程网获取地方美食品列表API数据接口丨携程商品列表数据接口丨携程API接口文档
    携程网提供了API接口用于获取地方美食品列表,具体接口名称为item_local_cuisine。为了使用这个API接口,你需要进行以下几个步骤:注册账号:访问携程开放平台,注册并开通相应的API服务。或者是根据PHP,java,C,Python等开发语言进行亚马逊商品详情数据接口,复制Taobaoapi2014添加薇好......
  • HIS系统是什么?一套前后端分离云HIS系统源码 接口技术RESTful API + WebSocket + WebSe
    HIS系统是什么?一套前后端分离云HIS系统源码接口技术RESTfulAPI+WebSocket+WebService医院管理信息系统(全称为HospitalInformationSystem)即HIS系统。常规模版包括门诊管理、住院管理、药房管理、药库管理、院长查询、电子处方、物资管理、媒体管理等,为医院管理提......
  • 身份证实名认证接口的价格一般是多少呢?基于PHP身份核验接口
    身份证实名认证接口分为身份证二要素、三要素、三要素+人像核验接口,被广泛的应用于婚恋、交友、电商等等一系列行业领域,身份证实名认证需要实时数据,对于数据源来说也需要可靠,那么,身份证实名认证的价格是不是很贵呢?以翔云身份证实名认证二要素接口为例,是按照二要素核验进......
  • 身份证真伪查询接口、身份证实名认证一行python代码即可实现,实时数据
    互联网多元化的发展使得互联网金融、O2O、交友等新型商业形式不断的兴起与创新,也正因如此,互联网企业对于实名认证接口的需求也在不断的增多,对数据形式,可靠性也有了更高的需求,对此衍生了身份证实名认证接口业务,那么如何通过一行python代码来实现实名认证呢?以翔云身份证实......
  • 肖sir__接口测试之postman11.1
    接口测试之postman一、介绍postmanPostman是一个网页调试工具,也可以调试css、html等Postman的操作环境环境:Postman Mac、Windows X32、Windows X64、Linux系统、postman 浏览器扩展程序、postman chrome应用程序Postman下载:https://www.postman.com/downloads/  记得......
  • Tailwind写法总结
    在使用TailwindCSS编写类时,通常按照以下一般顺序排列类,以确保代码的清晰性和易读性:定位类:包括控制元素位置的类,如absolute,relative,fixed,static,sticky等。盒模型类:包括控制元素内边距、外边距、宽度和高度的类,如p-,m-,w-,h-等。背景类:包括控制元素背景颜色、......
  • java为什么要使用接口呢 用例子带你全面理解接口
    接口的概念简单来说接口就是一个框架这就像做数学题的时候,需要套用固定的步骤是一样的在编程时,如果需要实现多个类似或者相同的模块,那么使用接口,可以让你拥有一套随时可以编辑的步骤.接口的意义在Java中,接口(Interface)扮演着非常关键的角色,它们有以下意义和作用:......