转 Postman访问Webapi的Get/Post/Put/Delte请求
Postman访问Webapi的Get/Post/Put/Delte请求
问题场景:
ASP.NET MVC WebApi 定义Get/Post/Put/Delete方法。使用Postman工具调用相应的方法。根据方法的特性不同、参数的特性不同,所访问的方式也不同。
问题分析:
创建一个新的WebApi的项目。控制器自动生成的代码如下:
首先看到类的上面有个特性默认如下:
[Route("api/[controller]")]
这个是访问时的路由规则(eg:http://localhost:port/api/conroller)。访问地址时不需要输入方法名,路由规则会根据参数的情况自动匹配。
建议将路由规则修改为
[Route("api/[controller]/[action]")]
这样的话我们就能输入方法名精确到我们需要访问的方法。下面开始介绍Get/Post/Put/Delete请求。
1.页面访问Get请求方法:
以下为使用Postman时请求GET的简单说明:
a) 特性为HttpGet
[HttpGet]
public IEnumerable<string> Get()
{
return new string[] { "value1", "value2" };
}
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方式即可。
转 Postman访问Webapi的Get/Post/Put/Delte请求的更多相关文章
- 使用Postman访问OAuth2保护的WebAPI
Instantnoodle现时的WebAPI已经受Azure AD保护,平时直接输入URL的方式已经不能够正常访问到WebAPI 所有API都可以Swagger页面找到 http://getazdev ...
- 利用HttpWebRequest访问WebApi
WebApi现在越来越流行,下面给出利用HttpWebRequest访问WebApi的工具方法: 1.利用基准URL和参数字典生成完整URL /// <summary> /// 生成URL ...
- Android 访问 Webapi 更新UI
首先,写一个访问webapi的工具类 import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import or ...
- 浏览器跨域访问WebApi
webapi地址:wapapi.ebcbuy.com web地址:wapweb.ebcbuy.com 在默认情况下这两个域名属于两个不同的域,他们之间的交互存在跨域的问题,但因为他们都同属于一 ...
- html网页访问WebAPI中的方法遇到的问题
1.移动端访问远程服务时,建议使用WebAPI 2.用不同浏览器访问WebAPI时返回的文本格式是不同的,Chrome Firefox将在浏览器中以XML形式显示此列表,IE浏览器将获得Json格 ...
- 使用react全家桶制作博客后台管理系统 网站PWA升级 移动端常见问题处理 循序渐进学.Net Core Web Api开发系列【4】:前端访问WebApi [Abp 源码分析]四、模块配置 [Abp 源码分析]三、依赖注入
使用react全家桶制作博客后台管理系统 前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用react全家桶制作的博客后台管理系统 概述 该项目是基 ...
- Azure CosmosDB (14) 使用Postman访问CosmosDB REST API
<Windows Azure Platform 系列文章目录> 今天研究了一下如何使用Postman访问Azure CosmosDB. CosmosDB API接口,可以参考:https: ...
- Azure EA (2) 使用Postman访问国内Azure Billing API
<Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China 请读者先看一下之前的文档内容:Azure EA (1) 查看国内Az ...
- layui表单提交与ajax访问webapi
啊啊啊啊 这个东西实在很蛋疼啊 每次访问webapi就很老火 这里就一下 以后忘记的话就来查阅 不多说 直接开始 首先html页面 新建一个基于layui的form表单页面LayuiForm.csh ...
随机推荐
- web程序顺序
1.org.apache.catalina.core.AprLifecycleListener init 2.Apache Tomcat Native library which allows opt ...
- 不同版本的IDE ,对应的选项 有变化
xx.dproj对应的项目级选项 也不同,所以,要分别保存为不同的文件. 如果不同的IDE,打开同一个 .dproj文件,会因为 选项界面的选项不同,提示一些错误.
- linux创建虚拟环境
linux提供的虚拟环境工具: virtualenv pipenv 1.安装python的虚拟环境 pip3 install -i https://pypi.tuna.tsinghua.edu.c ...
- Judy Beta 阶段整体计划
Judy Beta 总体规划 经过Alpha阶段的人员变动,Judy组成员如下:Manli Shu, Yuechen Wang, Zhiqi Lin, Yu Xing. 前Alpha阶段PM离职. 人 ...
- Python2.0 与 3.0 的区别
Python 2.0 =默认编码=ASSIC=不支持中文 Python 3.0 =默认编码=UNICODE=默认支持中文 In summary : Python 2.x is legacy, Py ...
- php短信验证码接口接入流程及代码示例
对于绝大部分企业来说,所使用的短信验证码接口都是第三方短信服务商所提供,目前市场上短信服务商有很多,在此向大家推荐一家动力思维乐信,运营13年,值得信赖! 就拿动力思维乐信短信验证码接口为例,详细介绍 ...
- PC端车牌识别朱凯茵从事图像识别算法、OCR算法
大家好,我是从事图像识别的pc端车牌识别朱凯茵,多多交流OCR算法,不限于车牌识别等,技术需要突破,你我成就梦想.
- @Dependson注解与@ConditionalOnBean注解的区别
@Dependson注解是在另外一个实例创建之后才创建当前实例,也就是,最终两个实例都会创建,只是顺序不一样 @ConditionalOnBean注解是只有当另外一个实例存在时,才创建,否则不创建,也 ...
- python之生成器与迭代器
生成器 列表生成式:li = [i for i in range(10)] 将列表生成式中[]换成()即为生成器generator 生成器保存的对象不是具体的数,而是一种算法,一种推导式,调用__ne ...
- maven profile实现多环境配置
每次项目部署上线都需要手动去修改配置文件(比如数据库配置,或者一个自定义的配置)然后才能打包,很麻烦,网上找到 maven profile可以完成这个工作,记录如下: 环境:eclipse + spr ...