Asp.Net WebApi Post请求整理(一)

摘要:
Asp.NetWebApi+JQueryAjax的Post请求整理一、总结1.WebApi默认支持Post提交处理,返回的结果为json对象,前台不需要手动反序列化处理。

Asp.Net WebApi+JQuery Ajax的Post请求整理


一、总结

1.WebApi 默认支持Post提交处理,返回的结果为json对象,前台不需要手动反序列化处理。
2.WebApi 接收Post提交参数需要指定([FromBody] string name)
3.WebApi 中如果只接收一个基础类型参数,不能指定key的名称
4.WebApi Post请求Action只能接收一个参数,也就是说一个Action中[FromBody]仅可指定一次
5.WebApi Post请求处理多个参数可以使用类对象方式接收参数例如:Student
6.在接收Post参数时,如果不想定义类,可以使用Newtonsoft.Json.Linq的JObject json对象容器接收参数
7.(不推荐使用)此接收参数可以使用dynamic本质是使用的JObject,但是提交参数需要指定字符串类型,contentType: 'application/json',类似WebServer中的指定方式
8.在WebApi的Post请求处理中,后台的Action名称不能使用“GetXXX”方式命名

二、验证代码

1.单个参数传递

Post获取请求参数需要指定参数来源 [FromBody],

Post方式提交时,Action的名称不能使用'Get'名称开头,

如果只接收一个基础类型参数,不能指定key的名称

后台:

/// <summary>
///Post获取请求参数需要指定参数来源 [FromBody]
/// </summary>
/// <param name="name"></param>
/// <returns></returns>
public string ShowName([FromBody] stringname)
{
    return $"您传入的名字:‘{name}’";
}
public Dictionary<string, string> FindList([FromBody] boolIsShow)
{
    Dictionary<string, string> dict = new Dictionary<string, string>();
    if(IsShow)
    {
        dict.Add("name1", "张三");
        dict.Add("name2", "李四");
    }
    returndict;
}

JavaScript:

$.post('/api/postuser/showname', {
    '': '张三丰'
}, function(data) {
    console.info(data);
    alert(data);
});
$.post('/api/postuser/FindList', {
    '': true
}, function(data) {
    console.info(data);
    alert(data);
});

二、多个参数传递

1.指定类类型 Student

后台:

public classStudent
{
    public string Name { get; set; }
    public int Age { get; set; }
}
/// <summary>
///Post获取参数可以接收对象类型,接收多个参数
/// </summary>
/// <param name="stu"></param>
/// <returns></returns>
public stringShowName2([FromBody] Student stu)
{
    return $"'{stu.Name}'的年龄为:{stu.Age}";
}

javascript:

$.post('/api/postuser/showname2', {
    name: '张三丰',
    age: 19
}, function(data) {
    console.info(data);
    alert(data);
});

2.使用JObject

后台:

/// <summary>
/// 在接收Post参数时,如果不想定义类,可以使用Newtonsoft.Json.Linq的JObject json对象容器接收参数
/// </summary>
/// <param name="obj"></param>
/// <returns></returns>
public object ShowName3([FromBody] JObject obj)
{
    return new { name = obj["name"], age = obj["age"], success = true};
}

javascript:

//如果使用JObject,使用对象提交或者使用字符串提交后台都能获取成功
$.post('/api/postuser/showname3', {
    name: '张三丰',
    age: 19
}, function(data) {
    console.info(data);
    alert(data);
});

Asp.Net WebApi Post请求整理(一)第1张

3.使用dynamic(不推荐)

后台:

/// <summary>
/// 在接收Post参数时,如果前台传入参数为一个字符串,可以使用dynamic类型接收,不需要指定[FromBody]
/// 此处obj的真正类型:FullName = "Newtonsoft.Json.Linq.JObject"
/// </summary>
/// <param name="obj"></param>
/// <returns></returns>
public object ShowName3(dynamic obj)
{
    return new { name = obj["name"], age = obj["age"], success = true};
}

javascript:

//需要指定参数类型:contentType: 'application/json',类似WebServer中的指定方式
$.ajax({
    url: '/api/postuser/showname3',
    type:'post',
    contentType: 'application/json',
    data: JSON.stringify({ name: '张三丰', age: 19}),
    success: function(data) {
        console.info(data);
        alert(data);
    }
});

Asp.Net WebApi Post请求整理(一)第2张Asp.Net WebApi Post请求整理(一)第3张

Asp.Net WebApi+AngularJs $http的Post请求整理


一、总结

1.后台使用如上相同

2.$http服务的post在单个参数提交后台接收失败

3.$http的post提交后台要么使用类类型接收,要么使用JObject接收(包含单个或多个参数)

二、代码示例

1.单个参数

//单个参数提交,后台接收失败
$http.post('/api/postuser/showname', {
    '': '张三'
}).then(function(result) {
    console.info(result);
    alert(result.data);
}).catch(function(err) {
    console.info(err);
    alert(err.data.Message);
});
//单个参数提交,后台使用JObject接收成功
$http.post('/api/postuser/showlist', {
    isshow: false
}).then(function(result) {
    console.info(result);
    alert(result.data);
}).catch(function(err) {
    console.info(err);
    alert(err.data.Message);
});

2.多个参数

//多个参数提交,Student类型接收参数
$http.post('/api/postuser/showname2', {
    name: '张三',
    age: '15'
}).then(function (result) {  //正确请求成功时处理
console.info(result);
    alert(result.data);
}).catch(function (result) { //捕捉错误处理
console.info(result);
    alert(result.data.Message);
});
//多个参数提交,JObject接收参数
//WebApi,相应结果为json对象,不需要手动发序列化处理
$http.post('/api/postuser/showname3', {
    name: '张三',
    age: '15'
}).then(function (result) {  //正确请求成功时处理
console.info(result);
    alert(result.data.name);
}).catch(function (result) { //捕捉错误处理
console.info(result);
    alert(result.data.Message);
});

更多参考:

Asp.Net WebApi Get请求整理(一)

Asp.Net WebAPI Get提交、Post提交处理

Asp.Net WebApi Action命名中已‘Get’开头问题

免责声明:文章转载自《Asp.Net WebApi Post请求整理(一)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇ABAP如何在abap中使用日志管理基础框架一:“零代码”实现单表增删改查、唯一性校验、枚举类型翻译下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

JAVA 调用HTTP接口POST或GET实现方式(转)

HTTP是一个客户端和服务器端请求和应答的标准(TCP),客户端是终端用户,服务器端是网站。通过使用Web浏览器、网络爬虫或者其它的工具,客户端发起一个到服务器上指定端口(默认端口为80)的HTTP请求。 具体POST或GET实现代码如下: packagecom.yoodb.util; importjava.io.ByteArrayOutputStre...

EBS_FORM开发之触发器

FORM触发器执行顺序:1.当打开FORM时: 1) PRE-FORM 2) PRE-BLOCK(BLOCK级) 3) WHEN-NEW-FORM-INSTANCE 4) WHEN-NEW-BLOCK-INSTANCE 5) WHEN-NEW-RECORD-INSTANCE 6) WHEN-NEW-ITEM-INSTANCE 2.当填写一行记录...

由nginx和spring boot中tomcat配置不当引起的问题

最近接浅橙贷超Api推过来的流量,由于有几个请求头的body体积比较大,最大有30M,到我们这边nginx的error日志就报错了: 2018/11/19 22:33:52 [error] 9791#0: *639124 readv() failed (104: Connection reset by peer) while reading upstrea...

nodejs body-parser 解析post数据

安装 $ npm install body-parser API var bodyPaeser =require('body-parser') 可以通过body-parser 对象创建中间件,当接收到客户端请求时所有的中间件都会给req.body 添加属性,请求体为空,则解析为空{} (或者出现错误)。 bodyParser.json(options) 中...

.net WebApi使用swagger 美化接口文档

本文将一步步演示如何用swagger美化WebApi接口文档,为接口文档添加接口名称说明,为请求参数和返回数据结构字段含义添加注释说明 一、为WebApi项目安装Swagger 首先我们新建一个WebApi项目 图1(新建WebApi项目) 右击项目,选择管理NuGet程序包,搜索swagger,为WebApi安装swagger 图2(右击项目或者解决...

吐血巨献:VB网络编程(webbrowser+Inet+抓包封包+经验)

      声明:本文部分内容来源与网络!    网络的重要性不用我说,所以关于网络的编程对我我们来说也是非常重要,非常实用的!    但是我在网络上却没有看到多少关于VB网络编程方面的知识,一方面是VB用的人比较少,不会用就说VB不好(个人认为学好VB以后C++、Java一看就会!);另一方面是大家不愿意公开这方面的知识,自己辛辛苦苦探索的,还得靠它吃...