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
如下为使用Postman时请求GET的简单说明:.net
[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"]
[HttpGet("{id}")]
public int Get(int id)
{
return id;
}
[HttpGet("{id}")]这个特性是自动生成的,具体的话没有深刻的研究。请求的参数方式会有些不一样。他所携带的参数请求规则为:
http://localhost:54261/api/values/Get/idvalue 。
[HttpPost]
public string Post(string str)
{return str;
}
Headers框下方的"Content-Type" 所对应的值应为 "application/x-www-form-urlencoded"
而后在"Body"框下输入对应的参数名和参数值,点击"Send"按钮便可请求而且获得返回值。
[HttpPost]
public string Post([FromBody]string value)
{return value;
}
倘若传递的参数类型的特性为[FromBody]时,须要注意:做为被标记为[FromBody]的参数只能出现一次,而且 [FromBody] 参数不能是基本的数据类型(如byte、int、bool、DateTime、string等)。
因此以上的方法是不能被访问到的。
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"
PUT请求和Delete请求实际用到的状况不是不少。使用方式跟POST差很少,只须要注意将Postman的请求方式改为对应的PUT或者Delete方式便可。