1.根据传入的请求URL和HTTP动词(GET/POST/PUT/PATCH/DELETE),Web API决定执行哪个Web API控制器和操作方法,如Get()方法将处理HTTP GET请求,POST()方法将处理HTTP POST请求,Put()方法将处理HTTP PUT请求,DELETE()方法将为上述Web API处理HTTP DELETE请求。
2.如果你想写一些不用HTTP动词命名的方法,可以给方法添加一些适当的HTTP动词属性,如HttpGet HttpPost,HttpPut等等就像MVC控制器一样。
[HttpGet]
public string Value(int id)
{
return "value";
}
[HttpPost]
public void SaveNewValue([FromBody]string value)
{
}
[HttpPut]
public void UpdateValue(int id, [FromBody]string value)
{
}
[HttpDelete]
public void RemoveValue(int id)
{
}
3.总结:动作方法名规则与HTTP动词名相同,也可以以HTTP动词开头,或将HTTP动词属性添加到方法。(方法名称必须以Http动词开头或者添加Http属性)
4.常用四个动词:
http动词 | 说明 |
---|---|
Get | 读 |
Post | 写 |
Put | 更新 |
Delete | 删除 |
4.url对应执行的动作,定位规则默认:
a.通过Controler找到类名,
b.通过传参的名称,确定动作方法(可能有重复)
c.通过http动作,确定最终执行的动作方法
5.注意:Web API也能支持像MVC那样的路由规则,将方法名包含在URL中(需要修改默认路由规则)
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{action}/{id}",
defaults: new { id = RouteParameter.Optional }
);
5.通过传参来确定动作方法时,默认为[FromUri],url字符串传过来的参数名,
如果在动作方法参数定义前加上[FromBody],则匹配请求头为Content-Type: application/x-www-form-urlencoded
6.form-data: 就是http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件。
application/x-www-from-urlencoded,会将表单内的数据转换为键值对,比如,name=java&age = 23
7.处理上传文件,也是POST请求,请求类型因为是multipart/form-data,包含文件和键值对,不需要使用[FormBody]修饰参数名,也没有参数名,因为最后会合成一长消息, 以分隔符隔开,是没有类型的
var httpRequest = HttpContext.Current.Request;
string _empId = httpRequest.Form["Emp_Id"];
string _cerId = httpRequest.Form["Cer_Id"];
var file = httpRequest.Files["Picture"];