一、什么是WebAPI?
1.1-什么是WebAPI?
WebAPI是一种用开发系统接口、设备接口API的技术,基于Http协议,请求和返回格式默认是Json格式。比WCF简单、更通用;比WebService更节省流量,更简洁。
1.2-WebAPI的特点?
- Action方法直接返回对象,专注于数据
- 更符合Restful的风格
- 有利于独立于IIS部署
- Action可以直接声明为async
二、什么是Restful?
2.1-传统的Http接口怎么设计?
data:image/s3,"s3://crabby-images/00dea/00dea59b4422e87b37ab461ca0ba3c14303d7a7e" alt=""
2.2-Http设计之初"谓词语义"?
- GET:查询获取
- POST:添加
- Put:修改
- Delete:删除
2.3-Http设计之初"谓词语义"带来的好处是什么?
- 为不同的请求做不同的权限的控制;
- 不需要"Delete","AddNew"这样的Action名字,根据请求的类型就可以判断
- 返回报文的格式也确定,不用在约定返回状态码,充分利用Http状态码
- 有利于系统优化,浏览器可以自动缓存Get请求
- Get没有副作用,是幂等的,可以重试。
注意:返回结果尽量根据Http状态码返回。
三、简单的WebAPI(.NET Framework)
3.1-简单WebAPI和是使用异步方式调用
- /// <summary>
- /// 需要继承自ApiController
- /// </summary>
- public class PersonController : ApiController
- {
- public string[] Get() {
- return new string[] { "西瓜程序猿", "Albert" };
- }
- public string Get(int id) {
- return $"Haha:" + id;
- }
- public string Get(string name) {
- return name;
- }
- }
- }
复制代码data:image/s3,"s3://crabby-images/c24c0/c24c09dcce4f33e339b33416a511b5e2b2406a29" alt=""
3.2-WebAPI的参数
data:image/s3,"s3://crabby-images/5afef/5afefea0bd3f01f925d7a4d185b97109fedc9698" alt=""
data:image/s3,"s3://crabby-images/7a9f6/7a9f68883060ebaf836474879b72d148b67f3926" alt=""
data:image/s3,"s3://crabby-images/88816/8881686d0a447aac6cdc2d5f637b1db68cd8b287" alt=""
data:image/s3,"s3://crabby-images/de730/de73081b39dfb6a8d64b4ee84704ab7720a23329" alt=""
data:image/s3,"s3://crabby-images/d591b/d591b558198dd95995a5c57362033cda839c38f5" alt=""
3.3-WebAPI的返回值
data:image/s3,"s3://crabby-images/cb4fc/cb4fc7494f090f7bcce8e0962e9e5a80ff70dd8a" alt="" - /// <summary>
- /// HttpResponseMessage类型
- /// 返回报文头、内容等等信息(控制相应的内容)
- /// </summary>
- /// <returns></returns>
- [HttpGet]
- [Route("Test3")]
- public HttpResponseMessage Test3() {
- HttpResponseMessage msg = new HttpResponseMessage();
- msg.Content =new StringContent( "报文体");
- msg.Headers.Add("Haha", "这是请求头体");
- msg.StatusCode = System.Net.HttpStatusCode.OK;
- msg.Headers.Age = TimeSpan.FromDays(3);
- return msg;
- }
复制代码 3.4-通过自定义路由处理API多版本
data:image/s3,"s3://crabby-images/63914/63914949d214d0a0642212f93265691980e93988" alt=""
data:image/s3,"s3://crabby-images/7dcb4/7dcb4842ce3440c54591f786656099bd1bc49c1d" alt=""
data:image/s3,"s3://crabby-images/77386/77386f221ecb01fe6ce858845ed8425b6697aa06" alt=""
3.5-通过ControllerSelector实现多版本(配置路由规则)
(1)创建2个版本控制器
data:image/s3,"s3://crabby-images/caa53/caa539c4760df1a6bf4294a4f89b5552d76f6f97" alt=""
(2)在【WebApiConfig】的Register中,添加1个路由规则,并替换IHttpControllerSelector- config.Routes.MapHttpRoute(
- name: "DefaultApiV1",
- routeTemplate: "api/v1/{controller}/{id}",
- defaults: new { id = RouteParameter.Optional }
- );
- //添加一个路由规则
- config.Routes.MapHttpRoute(
- name: "DefaultApiV2",
- routeTemplate: "api/v2/{controller}/{id}",
- defaults: new { id = RouteParameter.Optional }
- );
- //替换
- config.Services.Replace(typeof(IHttpControllerSelector), new VersionControllerSelector(config));
复制代码 (3)VersionControllerSelector.cs代码如下:- namespace Demo
- {
- /// <summary>
- /// 用来控制API版本
- /// 需要继承自DefaultHttpControllerSelector
- /// </summary>
- public class VersionControllerSelector : DefaultHttpControllerSelector
- {
- private readonly HttpConfiguration _config;
- private IDictionary<string, HttpControllerDescriptor> _ctlMapping;
- public VersionControllerSelector(HttpConfiguration config) : base(config)
- {
- this._config = config;
- }
- public override IDictionary<string, HttpControllerDescriptor> GetControllerMapping()
- {
- Dictionary<string, HttpControllerDescriptor> dict = new Dictionary<string, HttpControllerDescriptor>();
- //加载所有程序集,然后遍历
- foreach (var asm in _config.Services.GetAssembliesResolver().GetAssemblies())
- {
- //获得程序集所有的类,并且该类不是抽象类,并且继承自ApiController
- var controllerTypes = asm.GetTypes().Where(u => u.IsAbstract == false && typeof(ApiController).IsAssignableFrom(u));
- //遍历并生成名字
- foreach (var ctrlType in controllerTypes)
- {
- string ctrolTypeNS = ctrlType.Namespace;//获取命名空间名称
- var match = Regex.Match(ctrolTypeNS, @"\.v(\d)");//获得需要的名称
- if (!match.Success)
- {
- continue;
- }
- string verNum = match.Groups[1].Value;//拿到版本号1提取出来
- string ctrlTypeName = ctrlType.Name;//拿到类名(PersonController)
- //拿到匹配的类型
- var matchController = Regex.Match(ctrlTypeName, @"^(.+)Controller$");
- if (!matchController.Success)
- {
- continue;
- }
- string ctrlName = matchController.Groups[1].Value;//得到合法的PersonController
- string key = ctrlName + "v" + verNum;
- dict[key] = new HttpControllerDescriptor(_config, ctrlName,ctrlType);
- }
- }
- _ctlMapping = dict;
- return dict;
- }
- public override HttpControllerDescriptor SelectController(HttpRequestMessage request)
- {
- //拿到controller
- string controller =(string)request.GetRouteData().Values["controller"];
- if (_ctlMapping == null) {
- //调用之前的方法拿到,key/value
- _ctlMapping = GetControllerMapping();
- }
-
- // /api/v1/person
- var matchVer = Regex.Match(request.RequestUri.PathAndQuery, @"/v(\d+)/");
- if (!matchVer.Success) {
- //我处理不了,让父类处理
- return base.SelectController(request);
- }
- string verNum = matchVer.Groups[1].Value;//2
- string key = controller + "v" + verNum;
- if (_ctlMapping.ContainsKey(key))
- {
- return _ctlMapping[key];
- }
- else {
- //我处理不了,让父类处理
- return base.SelectController(request);
- }
- }
- }
- }
复制代码 3.6-WebAPI中Filter-简单判断是否授权
(1)新建一个类。
data:image/s3,"s3://crabby-images/a0716/a07168a9d8795e4586b8cf1ef0e41a8c7437459f" alt=""
(2)类的代码如下:- namespace Demo.Filter
- {
- public class MyAuthorFilter : IAuthorizationFilter
- {
- public bool AllowMultiple => true;
- public async Task<HttpResponseMessage> ExecuteAuthorizationFilterAsync(HttpActionContext actionContext, CancellationToken cancellationToken, Func<Task<HttpResponseMessage>> continuation)
- {
- IEnumerable<string> userNames;
- if (!actionContext.Request.Headers.TryGetValues("UserName", out userNames)){
- //返回未授权状态码
- return new HttpResponseMessage(System.Net.HttpStatusCode.Unauthorized);
- };
- string userName = userNames.First();
- if (userName == "admin")
- {
- return await continuation();
- }
- else {
- //返回未授权状态码
- return new HttpResponseMessage(System.Net.HttpStatusCode.Unauthorized);
- }
- }
- }
- }
复制代码 (3)在【WebApiConfig.cs】的Register方法进行注册自定义的Filter。- //注册自己写的Filter
- config.Filters.Add(new MyAuthorFilter());
复制代码 3.7-WebAPI的异常处理
系统错误:
data:image/s3,"s3://crabby-images/90747/9074701d9fc5152646e3f2b29fc9cc040eb8c854" alt=""
业务错误:
data:image/s3,"s3://crabby-images/4788a/4788a2f71551c1badcacb5872c5920f54d074783" alt=""
data:image/s3,"s3://crabby-images/29a16/29a166ffb51628f9b865689ce04a4ab1727d995b" alt=""
3.8-接口的安全性问题
data:image/s3,"s3://crabby-images/d97c8/d97c8be56d90a0a7d166a722a178c9ba471ad8cf" alt=""
data:image/s3,"s3://crabby-images/9f364/9f364dc95f3dc7d512d474d0c16b5353d979e8c4" alt=""
data:image/s3,"s3://crabby-images/bac4d/bac4dd4eda96d3e6f28f42386f12811f740d647c" alt=""
data:image/s3,"s3://crabby-images/43efa/43efa9a34cd0edc3f93ea7adca263294d06b9754" alt=""
3.9-JWT介绍
data:image/s3,"s3://crabby-images/0a0b4/0a0b4f5e81e9711c1748da5e82cddb0abb1ba176" alt=""
3.10-接口安全传输
data:image/s3,"s3://crabby-images/e707e/e707e1bb5ae055a5926dcf9710f3e6b6abda5a5a" alt=""
原文链接:https://www.cnblogs.com/kimiliucn/p/17607795.html
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |