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

2018年07月26日 15:04:46 DoNotWorkOvertime 阅读数:348 标签: WebApiPostman 更多

个人分类: ASP.NET
 

问题场景:

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请求的更多相关文章

  1. 使用Postman访问OAuth2保护的WebAPI

    Instantnoodle现时的WebAPI已经受Azure AD保护,平时直接输入URL的方式已经不能够正常访问到WebAPI 所有API都可以Swagger页面找到 http://getazdev ...

  2. 利用HttpWebRequest访问WebApi

    WebApi现在越来越流行,下面给出利用HttpWebRequest访问WebApi的工具方法: 1.利用基准URL和参数字典生成完整URL /// <summary> /// 生成URL ...

  3. Android 访问 Webapi 更新UI

    首先,写一个访问webapi的工具类 import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import or ...

  4. 浏览器跨域访问WebApi

      webapi地址:wapapi.ebcbuy.com web地址:wapweb.ebcbuy.com   在默认情况下这两个域名属于两个不同的域,他们之间的交互存在跨域的问题,但因为他们都同属于一 ...

  5. html网页访问WebAPI中的方法遇到的问题

      1.移动端访问远程服务时,建议使用WebAPI 2.用不同浏览器访问WebAPI时返回的文本格式是不同的,Chrome Firefox将在浏览器中以XML形式显示此列表,IE浏览器将获得Json格 ...

  6. 使用react全家桶制作博客后台管理系统 网站PWA升级 移动端常见问题处理 循序渐进学.Net Core Web Api开发系列【4】:前端访问WebApi [Abp 源码分析]四、模块配置 [Abp 源码分析]三、依赖注入

    使用react全家桶制作博客后台管理系统   前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用react全家桶制作的博客后台管理系统 概述 该项目是基 ...

  7. Azure CosmosDB (14) 使用Postman访问CosmosDB REST API

    <Windows Azure Platform 系列文章目录> 今天研究了一下如何使用Postman访问Azure CosmosDB. CosmosDB API接口,可以参考:https: ...

  8. Azure EA (2) 使用Postman访问国内Azure Billing API

    <Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China 请读者先看一下之前的文档内容:Azure EA (1) 查看国内Az ...

  9. layui表单提交与ajax访问webapi

    啊啊啊啊 这个东西实在很蛋疼啊 每次访问webapi就很老火 这里就一下  以后忘记的话就来查阅 不多说 直接开始 首先html页面 新建一个基于layui的form表单页面LayuiForm.csh ...

随机推荐

  1. web程序顺序

    1.org.apache.catalina.core.AprLifecycleListener init 2.Apache Tomcat Native library which allows opt ...

  2. 不同版本的IDE ,对应的选项 有变化

    xx.dproj对应的项目级选项 也不同,所以,要分别保存为不同的文件. 如果不同的IDE,打开同一个 .dproj文件,会因为 选项界面的选项不同,提示一些错误.

  3. linux创建虚拟环境

    linux提供的虚拟环境工具: virtualenv   pipenv 1.安装python的虚拟环境 pip3 install -i https://pypi.tuna.tsinghua.edu.c ...

  4. Judy Beta 阶段整体计划

    Judy Beta 总体规划 经过Alpha阶段的人员变动,Judy组成员如下:Manli Shu, Yuechen Wang, Zhiqi Lin, Yu Xing. 前Alpha阶段PM离职. 人 ...

  5. Python2.0 与 3.0 的区别

    Python 2.0 =默认编码=ASSIC=不支持中文 Python 3.0 =默认编码=UNICODE=默认支持中文   In summary : Python 2.x is legacy, Py ...

  6. php短信验证码接口接入流程及代码示例

    对于绝大部分企业来说,所使用的短信验证码接口都是第三方短信服务商所提供,目前市场上短信服务商有很多,在此向大家推荐一家动力思维乐信,运营13年,值得信赖! 就拿动力思维乐信短信验证码接口为例,详细介绍 ...

  7. PC端车牌识别朱凯茵从事图像识别算法、OCR算法

    大家好,我是从事图像识别的pc端车牌识别朱凯茵,多多交流OCR算法,不限于车牌识别等,技术需要突破,你我成就梦想.

  8. @Dependson注解与@ConditionalOnBean注解的区别

    @Dependson注解是在另外一个实例创建之后才创建当前实例,也就是,最终两个实例都会创建,只是顺序不一样 @ConditionalOnBean注解是只有当另外一个实例存在时,才创建,否则不创建,也 ...

  9. python之生成器与迭代器

    生成器 列表生成式:li = [i for i in range(10)] 将列表生成式中[]换成()即为生成器generator 生成器保存的对象不是具体的数,而是一种算法,一种推导式,调用__ne ...

  10. maven profile实现多环境配置

    每次项目部署上线都需要手动去修改配置文件(比如数据库配置,或者一个自定义的配置)然后才能打包,很麻烦,网上找到 maven profile可以完成这个工作,记录如下: 环境:eclipse + spr ...