转 Postman访问Webapi的Get/Post/Put/Delte请求

Postman访问Webapi的Get/Post/Put/Delte请求

问题场景:

ASP.NET MVC WebApi 定义Get/Post/Put/Delete方法。使用Postman工具调用相应的方法。根据方法的特性不一样、参数的特性不一样,所访问的方式也不一样。html

问题分析:

建立一个新的WebApi的项目。控制器自动生成的代码以下:json

首先看到类的上面有个特性默认以下:api

[Route("api/[controller]")]app

这个是访问时的路由规则(eg:http://localhost:port/api/conroller)。访问地址时不须要输入方法名,路由规则会根据参数的状况自动匹配。工具

建议将路由规则修改成post

[Route("api/[controller]/[action]")]url

这样的话咱们就能输入方法名精确到咱们须要访问的方法。下面开始介绍Get/Post/Put/Delete请求。spa

1.页面访问Get请求方法:

如下为使用Postman时请求GET的简单说明:.net

a) 特性为HttpGet

[HttpGet]
public IEnumerable<string> Get()
{
    return new string[] { "value1", "value2" };
}code

 

Postman使用GET请求,Url地址便可(eg:http://localhost:port/api/values/Get),若是该方法有参数,则在Params输入对应的参数名和参数值便可(即url地址中尾部增长'?key1=val1&key2=val2')。获得的返回值是["value1","value2"]

b) 特性为HttpGet("{name}")

[HttpGet("{id}")]
public int Get(int id)
{
    return id;
}

[HttpGet("{id}")]这个特性是自动生成的,具体的话没有深刻的研究。请求的参数方式会有些不一样。他所携带的参数请求规则为:

http://localhost:54261/api/values/Get/idvalue 。

2.页面访问POST请求方法:

a) 参数为基本数据类型

[HttpPost]
public string Post(string str)
{

    return str;
}

Headers框下方的"Content-Type" 所对应的值应为 "application/x-www-form-urlencoded"

而后在"Body"框下输入对应的参数名和参数值,点击"Send"按钮便可请求而且获得返回值。

 b) 参数特性被标记为[FromBody]

[HttpPost]
public string Post([FromBody]string value)
{

    return value;
}

 倘若传递的参数类型的特性为[FromBody]时,须要注意:做为被标记为[FromBody]的参数只能出现一次,而且 [FromBody] 参数不能是基本的数据类型(如byte、int、bool、DateTime、string等)。

因此以上的方法是不能被访问到的。

c)  [FromBody]标记的参数为对象

public class ReqTest
{
    public int id { get; set; }
    public string name { get; set; }
}

[HttpPost]
public string Post([FromBody]ReqTest req)
{
    return req.id.ToString() + req.name;
}

 [FromBody]标记参数须要使用json的格式进行传递。

Headers框下方的"Content-Type" 所对应的值应为 "application/json"

而后在"Body"框下选择"raw",输入json格式的参数进行访问(eg:{"id":9527,"name":"Mark"})。

获得的返回值为"9527Mark"

3.HTTP PUT/Delete请求方式:

PUT请求和Delete请求实际用到的状况不是不少。使用方式跟POST差很少,只须要注意将Postman的请求方式改为对应的PUT或者Delete方式便可。

相关文章
相关标签/搜索