总结webAPI的常用请求方法与后台参数的获取:

 

一:get请求:(会将所以参数拼接到URL里面)

1:基础类型:string  a=“hello” , 前端无论你是写到ajax里面的data属性还是直接拼接到URL里面,后台直接string a获取;

[HttpGet]

public JObject AddUserInfo(string a)

{.........}

2:实体类型:(1)使用FromUri关键字:前端写到ajax里面的data属性里面提交,如data:{
      Id:"1",
      Name:"lsm",
      Old:"25",
    }

后台采用实体接收,先定义实体,属性名称需要和前台传过来的属性名称一致,使用【FromUri】关键字接收,

如模型定义为 public class UserModel
    {
        public string Id { get; set; }
        public string Name { get; set; }
        public string Old { get; set; }
    }

接口写成:

[HttpGet]

public JObject AddUserInfo([FromUri]UserModel userInfo)

{.........}

(2)不使用FromUri关键字

前台将对象序列化成字符串:data: { strQuery: JSON.stringify({Id:"1",
      Name:"lsm",
      Old:"25",})}

后台采用字符串接收:参数名需和前台传过来的一致,并再序列化json对象

 接口写法 [HttpGet]

)
{
;
。。。。
}
3:若web API的接口方法名称以get开头的时候,可以省略[HttpGet]过滤
二:post请求
1:基础类型:data: { "": "Jim" },注意这里不能写key值,否则后台获取到的值将为空,后台使用[FromUri]关键字获取
[HttpPost]
)
{
;
}
2:多个基础类型数据参数
前台写法:
data:{
      Id:"1",
      Name:"lsm",
      Old:"25",
    }
后台取法:使用dynamic关键字
]
)
{
;
;
}
3:单个实体类型:注意此时不能指定contentType为appplication/json,应当默认的application/x-www-form-urlencoded,否则将取不到数据
前台写法
data:{
      Id:"1",
      Name:"lsm",
      Old:"25",
    }
后台直接由实体接收:
[HttpPost]
)
{
;
}
4:单个实体类型:前台指定contentType为appplication/json,必须将json对象序列化在传输
前台写法
postdata:{
      Id:"1",
      Name:"lsm",
      Old:"25",
    }
data: JSON.stringify(postdata),
后台直接由实体接收:
[HttpPost]
)
{
;
}
 
5:基础类型+实体:前台定contentType为appplication/json,后台使用dynamic关键字接收
前台:
postdata:{
      Id:"1",
      Name:"lsm",
      Old:"25",
    }
data: JSON.stringify({NAME:"Lilei", Charging:postdata}),
后台:
[HttpPost]
)
{
;
;
;
}
6:数组为参数:前台指定contentType为appplication/json
前台:
arr:["2","3","3","5"]
data: JSON.stringify(arr),
后台:
  [HttpPost]
)
{
;
}
 
7:实体集合:前台指定contentType为appplication/json
前台
[
,
,
}
;
 
data: JSON.stringify(arr),
后台:
 [HttpPost]
)
{
;
}
三:put请求机制和post一样
四:delete请求机制和post一样

相关文章: