C# WebApi传参及Postman调试
创始人
2025-01-08 13:05:57
0

概述

欢迎来到本文,本篇文章将会探讨C# WebApi中传递参数的方法。在WebApi中,参数传递是一个非常重要的概念,因为它使得我们能够从客户端获取数据,并将数据传递到服务器端进行处理。WebApi是一种使用HTTP协议进行通信的RESTful服务,它可以通过各种方式传递参数。在本文中,我们只会针对Get和Post讨论参数传递的方法,以及如何在C# WebApi中正确地处理它们。

Get

GET请求方法用于获取资源,通常会将参数放在URL的查询字符串中进行传递。由于GET请求方法是无状态的,因此它通常被用于获取数据,而不是修改数据。

// 该函数用于向服务器发送GET请求并获取数据 export function getAction(url, query) {   return request({     url: url,     method: 'get',     params: query   }) } 

1.传递字符串参数

// 前端代码 handleTest() {       getAction('/test/list1', { id: 1 }).then((res) => {         console.log('res=', res)       })     }, 
// 后端代码 [Route("test")] public class TestController : ControllerBase {     [HttpGet("list1")]     public IActionResult Index(int id)     {         return Ok(id);     } } 

附上Postman调用截图

2.传递实体参数

注意:.Net Core 项目中使用[FromQuery]特性,在.Net Framework 项目中使用[FromUri]特性

// 前端代码 handleTest() {       getAction('/test/getPerson', { Name: 'Hpf', Age: '29', Sex: '男' }).then((res) => {         console.log('res=', res)       })     }, 
//后端代码 [Route("test")] public class TestController : BaseController { 	[HttpGet("getPerson")] 	public IActionResult GetPerson([FromQuery] Person person) 	{ 		return Ok(); 	} }   public class Person { 	public string Name { get; set; } 	public string Age { get; set; } 	public string Sex { get; set; } } 

附上Postman调用截图

Post

POST请求方法用于向服务器端提交数据,通常会将参数放在请求体中进行传递。POST请求方法通常被用于创建、更新或删除资源。

// 该函数用于向服务器发送POST请求并获取数据 export function postAction(url, data) {   return request({     url: url,     method: 'post',     data: data   }) } 

1.传递实体参数

// 前端代码 handleTest() {       postAction('/test/postPerson', { Name: 'Hpf', Age: '29', Sex: '男' }).then((res) => {         console.log('res=', res)       })     }, 
// 后端代码 [Route("test")] public class TestController : BaseController { 	[HttpPost("postPerson")] 	public IActionResult PostPerson([FromBody] Person person) 	{ 		return Ok(); 	} }   public class Person { 	public string Name { get; set; } 	public string Age { get; set; } 	public string Sex { get; set; } } 

附上Postman调用截图

2.传递实体集合参数

// 前端代码 handleTest() {       let list = [         { Name: 'Hpf', Age: '29', Sex: '男' },         { Name: 'Zzr', Age: '26', Sex: '女' },       ]       postAction('/test/postPerson', list).then((res) => {         console.log('res=', res)       })     }, 
// 后端代码 [Route("test")] public class TestController : BaseController { 	[HttpPost("postPerson")] 	public IActionResult PostPerson([FromBody] List person) 	{ 		return Ok(); 	} }   public class Person { 	public string Name { get; set; } 	public string Age { get; set; } 	public string Sex { get; set; } } 

附上Postman调用截图

3.传递数组参数

// 前端代码 handleTest() {       postAction('/test/postPerson',  ['1', '2', '3']).then((res) => {         console.log('res=', res)       })     }, 
// 后端代码 [Route("test")] public class TestController : BaseController { 	[HttpPost("postPerson")] 	public IActionResult PostPerson([FromBody] string[] str) 	{ 		return Ok(); 	} } 

附上Postman调用截图

# 概述

欢迎来到本文,本篇文章将会探讨C# WebApi中传递参数的方法。在WebApi中,参数传递是一个非常重要的概念,因为它使得我们能够从客户端获取数据,并将数据传递到服务器端进行处理。WebApi是一种使用HTTP协议进行通信的RESTful服务,它可以通过各种方式传递参数。在本文中,我们只会针对Get和Post讨论参数传递的方法,以及如何在C# WebApi中正确地处理它们。

Get

GET请求方法用于获取资源,通常会将参数放在URL的查询字符串中进行传递。由于GET请求方法是无状态的,因此它通常被用于获取数据,而不是修改数据。

// 该函数用于向服务器发送GET请求并获取数据 export function getAction(url, query) {   return request({     url: url,     method: 'get',     params: query   }) } 

1.传递字符串参数

// 前端代码 handleTest() {       getAction('/test/list1', { id: 1 }).then((res) => {         console.log('res=', res)       })     }, 
// 后端代码 [Route("test")] public class TestController : ControllerBase {     [HttpGet("list1")]     public IActionResult Index(int id)     {         return Ok(id);     } } 

附上Postman调用截图

2.传递实体参数

注意:.Net Core 项目中使用[FromQuery]特性,在.Net Framework 项目中使用[FromUri]特性

// 前端代码 handleTest() {       getAction('/test/getPerson', { Name: 'Hpf', Age: '29', Sex: '男' }).then((res) => {         console.log('res=', res)       })     }, 
//后端代码 [Route("test")] public class TestController : BaseController { 	[HttpGet("getPerson")] 	public IActionResult GetPerson([FromQuery] Person person) 	{ 		return Ok(); 	} }   public class Person { 	public string Name { get; set; } 	public string Age { get; set; } 	public string Sex { get; set; } } 

附上Postman调用截图

Post

POST请求方法用于向服务器端提交数据,通常会将参数放在请求体中进行传递。POST请求方法通常被用于创建、更新或删除资源。

// 该函数用于向服务器发送POST请求并获取数据 export function postAction(url, data) {   return request({     url: url,     method: 'post',     data: data   }) } 

1.传递实体参数

// 前端代码 handleTest() {       postAction('/test/postPerson', { Name: 'Hpf', Age: '29', Sex: '男' }).then((res) => {         console.log('res=', res)       })     }, 
// 后端代码 [Route("test")] public class TestController : BaseController { 	[HttpPost("postPerson")] 	public IActionResult PostPerson([FromBody] Person person) 	{ 		return Ok(); 	} }   public class Person { 	public string Name { get; set; } 	public string Age { get; set; } 	public string Sex { get; set; } } 

附上Postman调用截图

2.传递实体集合参数

// 前端代码 handleTest() {       let list = [         { Name: 'Hpf', Age: '29', Sex: '男' },         { Name: 'Zzr', Age: '26', Sex: '女' },       ]       postAction('/test/postPerson', list).then((res) => {         console.log('res=', res)       })     }, 
// 后端代码 [Route("test")] public class TestController : BaseController { 	[HttpPost("postPerson")] 	public IActionResult PostPerson([FromBody] List person) 	{ 		return Ok(); 	} }   public class Person { 	public string Name { get; set; } 	public string Age { get; set; } 	public string Sex { get; set; } } 

附上Postman调用截图

3.传递数组参数

// 前端代码 handleTest() {       postAction('/test/postPerson',  ['1', '2', '3']).then((res) => {         console.log('res=', res)       })     }, 
// 后端代码 [Route("test")] public class TestController : BaseController { 	[HttpPost("postPerson")] 	public IActionResult PostPerson([FromBody] string[] str) 	{ 		return Ok(); 	} } 

附上Postman调用截图

相关内容

热门资讯

aapoker有外挂!AA P... aapoker有外挂!AA POKER下载软件,(aapoker app)原来真的是有挂(详细辅助黑...
微扑克辅助软件(微扑克)微扑克... 微扑克辅助软件(微扑克)微扑克系统发牌(透视)原来是有挂(详细辅助教你攻略);1、任何微扑克辅助软件...
第四分钟实锤!德扑之星作弊(德... 第四分钟实锤!德扑之星作弊(德州俱乐部)确实是有挂(详细辅助攻略方法);所有人都在同一条线上,像星星...
wpk ai辅助!wpk辅助插... wpk ai辅助!wpk辅助插件(透视)外挂透视挂辅助神器(原生真的是有挂);支持多人共享记分板与复...
aapoker透明挂!aapo... aapoker透明挂!aapoker有外挂吗,(aapoker下载)从来是真的有挂(详细辅助扑克教程...
微扑克ai机器人(微扑克)微扑... 微扑克ai机器人(微扑克)微扑克ai辅助神器(透视)总是是有挂(详细辅助攻略方法)微扑克ai机器人是...
9分钟实锤!德扑起手牌胜率图(... 9分钟实锤!德扑起手牌胜率图(德州机器人)总是有挂(详细辅助大神讲解);1、玩家可以在德扑起手牌胜率...
wpk有透视辅助!wpk怎输赢... wpk有透视辅助!wpk怎输赢机制(透视)外挂透视辅助技巧(一贯有挂);人气非常高,ai更新快且高清...
aapoker挂!aapoke... aapoker挂!aapoker线上规律,(aa扑克伙牌)原来存在有挂(详细辅助透明挂教程);实战中...
微扑克全自动机器人(微扑克)微... 微扑克全自动机器人(微扑克)微扑克智能助手(透视)果然是有挂(详细辅助解密教程)1、在微扑克全自动机...