何时使用查询字符串参数和路径参数_2024-06-28

REST API 已成为构建和使用 Web 服务的标准。在设计 REST API 时,一个重要方面是决定如何构造 URL 和参数。向 API 传递参数的两种常见方法是通过查询字符串参数和路径参数。本文将解释这两种方法之间的区别、何时使用每种方法,并提供示例来说明它们的用法。

查询字符串参数

什么是查询字符串参数?

查询字符串参数是附加到 URL 末尾的键值对,位于问号 (?) 后面。多个参数用与号 (&) 分隔。它们通常用于过滤、排序或分页数据。

查询字符串参数示例

以下是用于过滤结果的查询字符串参数的简单示例:

GET /api/products?category=electronics&sort=price

在这个例子中

  • category 是用于按电子类别过滤产品的查询参数。
  • sort 是一个查询参数,用于按价格对产品进行排序。

何时使用查询字符串参数?

  • 过滤:当您需要根据特定标准过滤项目列表时。
  • 排序:当您需要对项目列表进行排序时。
  • 分页:当您需要对项目列表进行分页时(例如,page=2&limit=20)。
  • 可选参数:参数是可选的,并且可能并不总是提供。

.NET Core 中的示例

下面是如何在 ASP.NET Core 控制器中处理查询字符串参数的示例:

[ApiController]
[Route("api/[controller]")]
public class ProductsController : ControllerBase
{[HttpGet]public IActionResult GetProducts([FromQuery] string category, [FromQuery] string sort){// Example logic to filter and sort productsvar products = GetProductsFromDatabase();if (!string.IsNullOrEmpty(category)){products = products.Where(p => p.Category == category).ToList();}if (!string.IsNullOrEmpty(sort)){products = sort switch{"price" => products.OrderBy(p => p.Price).ToList(),_ => products};}return Ok(products);}private List<Product> GetProductsFromDatabase(){// Placeholder method to get products from a databasereturn new List<Product>{new Product { Id = 1, Name = "Laptop", Category = "electronics", Price = 1000 },new Product { Id = 2, Name = "Phone", Category = "electronics", Price = 500 },// More products...};}
}
public class Product
{public int Id { get; set; }public string Name { get; set; }public string Category { get; set; }public decimal Price { get; set; }
}

路径参数

什么是路径参数?

路径参数是 URL 路径本身的一部分,用于标识特定资源。它们直接嵌入到 URL 中,通常用于检索、更新或删除特定资源。

路径参数示例

以下是用于通过 ID 检索特定产品的路径参数的示例:

GET /api/products/123

在这个例子中

123 是用于指定要检索的产品的 ID 的路径参数。

何时使用路径参数?

  1. 资源标识:当需要该参数来识别特定资源时。
  2. 强制参数:需要该参数来完成请求。

.NET Core 中的示例

下面是如何在 ASP.NET Core 控制器中处理路径参数的示例。

[ApiController]
[Route("api/[controller]")]
public class ProductsController : ControllerBase
{[HttpGet("{id}")]public IActionResult GetProductById(int id){// Example logic to retrieve a product by IDvar product = GetProductFromDatabase(id);if (product == null){return NotFound();}return Ok(product);}private Product GetProductFromDatabase(int id){// Placeholder method to get a product from a databasevar products = new List<Product>{new Product { Id = 1, Name = "Laptop", Category = "electronics", Price = 1000 },new Product { Id = 2, Name = "Phone", Category = "electronics", Price = 500 },// More products...};return products.FirstOrDefault(p => p.Id == id);}
}

组合查询字符串和路径参数

在单个 API 中同时使用查询字符串和路径参数通常很有用。例如,您可以使用路径参数来标识特定资源,并使用查询字符串参数来过滤或排序相关数据。

例子

这是一个 API 示例,它检索特定客户(由路径参数标识)的订单,并支持按订单状态进行过滤(使用查询字符串参数)。

GET /api/customers/123/orders?status=shipped

.NET Core 中的示例

以下是如何在 ASP.NET Core 控制器中实现此功能。

[ApiController]
[Route("api/[controller]")]
public class CustomersController : ControllerBase
{// 处理GET请求,路径为api/customers/{customerId}/orders[HttpGet("{customerId}/orders")]public IActionResult GetCustomerOrders(int customerId, [FromQuery] string status){// 示例逻辑:检索特定客户的订单,并根据状态进行筛选var orders = GetOrdersFromDatabase(customerId);// 如果status参数不为空,则筛选出该状态的订单if (!string.IsNullOrEmpty(status)){orders = orders.Where(o => o.Status == status).ToList();}// 返回筛选后的订单列表return Ok(orders);}// 从数据库获取订单列表的占位方法private List<Order> GetOrdersFromDatabase(int customerId){return new List<Order>{new Order { Id = 1, CustomerId = 123, Status = "shipped", Total = 50.00m },new Order { Id = 2, CustomerId = 123, Status = "processing", Total = 100.00m },// 更多订单...};}
}// 订单类
public class Order
{public int Id { get; set; }public int CustomerId { get; set; }public string Status { get; set; }public decimal Total { get; set; }
}

结论

了解何时使用查询字符串参数和路径参数对于设计直观有效的 REST API 至关重要。查询字符串参数非常适合过滤、排序和分页,而路径参数则用于资源识别。将两者结合起来可以提供一种灵活而强大的方式与您的 API 进行交互。

通过遵循本文提供的指南和示例,您可以设计结构良好、易于使用和维护的 REST API。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/37398.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二刷算法训练营Day45 | 动态规划(7/17)

目录 详细布置&#xff1a; 1. 139. 单词拆分 2. 多重背包理论基础 3. 背包总结 3.1 背包递推公式 3.2 遍历顺序 01背包 完全背包 详细布置&#xff1a; 1. 139. 单词拆分 给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单…

昇思25天学习打卡营第6天|linchenfengxue

​​​​​​SSD目标检测 SSD&#xff0c;全称Single Shot MultiBox Detector&#xff0c;是Wei Liu在ECCV 2016上提出的一种目标检测算法。使用Nvidia Titan X在VOC 2007测试集上&#xff0c;SSD对于输入尺寸300x300的网络&#xff0c;达到74.3%mAP(mean Average Precision)以…

刷题Day37|416. 分割等和子集

416. 分割等和子集 题目&#xff1a;416. 分割等和子集 - 力扣&#xff08;LeetCode&#xff09; 思路&#xff1a;0-1背包问题&#xff0c;重量和价值一样&#xff0c;每个元素只能使用一次&#xff0c;装满背包且最大价值为sum/2就是true 。dp[target] target返回true。 …

nginx架构基本数据结构配置模块请求详解

nginx源码的目录结构&#xff1a; . ├── auto 自动检测系统环境以及编译相关的脚本 │ ├── cc 关于编译器相关的编译选项的检测脚本 │ ├── lib nginx编译所需要的一些库的检测脚本 │ ├── os 与平台相关的一些系统参…

端口扫描攻击检测及防御方案

端口扫描数据一旦落入坏人之手&#xff0c;可能会成为更大规模恶意活动的一部分。因此&#xff0c;了解如何检测和防御端口扫描攻击至关重要。 端口扫描用于确定网络上的端口是否开放以接收来自其他设备的数据包&#xff0c;这有助于网络安全团队加强防御。但恶意行为者也可以…

ubuntu 18 虚拟机安装(5) postgres sql 数据库 简单 应用

ubuntu 18 虚拟机安装&#xff08;5&#xff09; postgres sql 数据库 简单 应用 参考 PostgreSQL的基本使用整理 https://blog.csdn.net/qq_45658339/article/details/124431612 sudo su - postgres psqlsudo -u postgres psqlsudo systemctl status postgresql sudo syste…

50-1 内网渗透 - 未引用的服务路径提权

一、未引用的服务路径介绍 未引用的服务路径(Unquoted Service Path)漏洞利用了Windows文件路径解析的特性。当服务启动时,如果其执行文件路径中包含空格并且未包含在引号中,就可能导致此漏洞的发生。 具体来说,如果完整路径中包含空格且未使用引号括起来,Windows将按顺…

zabbix-server的搭建

zabbix-server的搭建 部署 zabbix 服务端(192.168.99.180) rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/5.0/rhel/7/x86_64/zabbix-release-5.0-1.el7.noarch.rpm cd /etc/yum.repos.d sed -i s#http://repo.zabbix.com#https://mirrors.aliyun.com/zabbix# zabbix.r…

实验八 T_SQL编程

题目 以电子商务系统数据库ecommerce为例 1、在ecommerce数据库&#xff0c;针对会员表member首先创建一个“呼和浩特地区”会员的视图view_hohhot&#xff0c;然后通过该视图查询来自“呼和浩特”地区的会员信息&#xff0c;用批处理命令语句将问题进行分割&#xff0c;并分…

【方案+源码】srm供应商招投标管理系统建设方案及源码实现

SRM供应商管理系统功能建设涵盖&#xff1a; 供应商管理&#xff1a;整合供应商信息&#xff0c;实现全生命周期管理。 采购需求管理&#xff1a;精准把握采购需求&#xff0c;优化采购计划。 采购寻源管理&#xff1a;智能寻源&#xff0c;匹配最佳供应商。 采购合同管理&…

TypeScript中的Omit和Pick

最近面试中被问到了TypeScript中的Omit和Pick。第一时间就是尬住了&#xff0c;因为在工作里很少使用了TS&#xff0c;基本都是在写类型。这俩关键词&#xff0c;有点不面熟。面试结束后也是了解了一下&#xff0c;挺简单的两个类型工具。 在 TypeScript 中&#xff0c;Omit 和…

spring和springboot的关系是什么?

大家好&#xff0c;我是网创有方的站长&#xff0c;今天给大家分享下spring和springboot的关系是什么&#xff1f; Spring和Spring Boot之间的关系可以归纳为以下几个方面&#xff1a; 技术基础和核心特性&#xff1a; Spring&#xff1a;是一个广泛应用的开源Java框架&#…

【深度学习基础】`view` 和 `reshape` 的参数详解

目录 基本概念参数详解 示例view 和 reshape 在具体应用中的参数解释参数解释 更多示例高维张量示例非连续内存示例 总结 基本概念 view 和 reshape 都用于调整张量的形状&#xff0c;它们的参数是新的形状&#xff0c;每个维度的大小可以指定为具体的数值或者 -1。-1 表示这个…

计算机类主题会议推荐之——AIIIP 2024

【ACM出版 |IEEE&ACM院士、CCF杰出会员担任组委| 往届会后4个月检索 】 第三届人工智能与智能信息处理国际学术会议&#xff08;AIIIP 2024&#xff09; 2024 3rd International Conference on Artificial Intelligence and Intelligent Information Processing 中国-天…

uniapp部署服务器,uniapp打包H5部署服务器,uniapp将config.js抽离

目录 步骤一.在static文件夹下新建config.js文件 config.js文件说明 在config.js中放入使用的请求的接口地址,资源路径等 congfig.js中的变量在页面中如何使用 步骤二.manifest.json配置 1.在项目根目录(与app.vue同级)创建template.h5.html文件 2.在manifest.json配置刚刚创…

全面体验ONLYOFFICE 8.1版本桌面编辑器

ONLYOFFICE官网 在当今的数字化办公环境中&#xff0c;选择合适的文档处理工具对于提升工作效率和团队协作至关重要。ONLYOFFICE 8.1版本桌面编辑器&#xff0c;作为一款集成了多项先进功能的办公软件&#xff0c;为用户提供了全新的办公体验。今天&#xff0c;我们将深入探索…

深入探索STM32的SPI功能:W25Q64 Flash存储器全攻略

摘要 随着嵌入式系统对存储需求的增长&#xff0c;选择合适的存储设备变得尤为重要。W25Q64 Flash存储器以其8Mbit的存储容量和SPI接口的便捷性&#xff0c;成为STM32微控制器项目中的优选存储方案。本文将深入探索STM32的SPI功能&#xff0c;提供W25Q64 Flash存储器的全面集成…

如何成为-10x工程师:反向教学大数据开发实际工作中应如何做

10x 工程师可能是神话&#xff0c;但 -10x 工程师确实存在。要成为 -10x 工程师&#xff0c;只需每周浪费 400 小时的工程时间。结合以下策略&#xff1a; 目录 如何使 10 名工程师的输出无效化改变需求大数据开发示例 创建 400 小时的繁忙工作任务示例大数据开发示例 创建 400…

WPF UI交互专题 界面结构化处理 查看分析工具Snoopy 逻辑树与视觉树 平面图像 平面图形 几何图形 弧线 01

1、开发学习环境 2、XAML界面结构化处理 3、逻辑树与视觉树 4、基于XAML的标签扩展方式 5、基础控件应用分析 6、控件常用属性与事件总结 7、常用控件特别属性说明 8、平面图形控件与属性 9、平面几何图形 10、弧线的处理过程 WPF项目-XAML 项目表现形式 项目结…

threadX netX 创建/删除 IP实例,使能 ARP地址解析

创建IP实例 函数原型 UINT nx_ip_create( NX_IP *ip_ptr, CHAR *name, ULONG ip_address, ULONG network_mask,NX_PACKET_POOL *default_pool,VOID (*ip_network_driver)(NX_IP_DRIVER *), VOID *memory_ptr,ULONG memory_size,UINT priority);参数&#xff1a; ip_ptr&…