Web Api 创建及其使用 WEB API的适用场景、第一个实例

由于创建博客,我需要尝试一些新的技术,新的思路,所以我没规规矩矩的写博客,用上了诸多以前没用的东西,比如现在这个(我只是听过web api 我连 web server 都只是用过两三次/手动滑稽)

昨天开始研究的,一直到现在,我还是懵比的,只不过也算是比不懂懂了一点吧。

在这里,谢谢各位前辈与大佬的博客,建议,demo(虽然demo 我一个都看不懂,也运行不了,但还是感谢你们),思路

谢谢你们(90度鞠躬)

希望大家觉得这篇文章好的话都顶一顶(第一次说出这话/脸红.jpg)

下面的文章 用到哪些博客,我都会引用过来,如果侵权的话,希望能告诉我,我会把引用的地方删除的,谢谢

首先先百度一下,Web API ,Web server  ,MVC    www.baidu.com

Web API:

Web API是网络应用程序接口。包含了广泛的功能,网络应用通过API接口,可以实现存储服务、消息服务、计算服务等能力,利用这些能力可以进行开发出强大功能的web应用。

1、这是一个简单的构建HTTP服务的新框架
2、在.net平台上Web API 是一个开源的、理想的、构建REST-ful 服务的技术
3、不像WCF REST Service.它可以使用HTTP的全部特点(比如URIs、request/response头,缓存,版本控制,多种内容格式)
4、它也支持MVC的特征,像路由、控制器、action、filter、模型绑定、控制反转(IOC)或依赖注入(DI),单元测试。
5、它可以部署在应用程序和IIS上
6、这是一个轻量级的框架,并且对限制带宽的设备,比如智能手机等支持的很好
7、Response可以被Web API的MediaTypeFormatter转换成Json、XML 或者任何你想转换的格式。

。。。

 

Web  server

1、它是基于SOAP协议的,数据格式是XML
2、只支持HTTP协议
3、它不是开源的,但可以被任意一个了解XML的人使用
4、它只能部署在IIS上

。。。

MVC:

MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。

 

 

MVC 和Web  API

使用上区分,mvc主要用于建站,web api主要用于构建http服务

 

mvc  注重  网站交互

web api 跟注重与数据

WEB API的适用场景、第一个实例

https://www.cnblogs.com/UliiAn/p/5373854.html

WCF提供的是一种RPC实现的集合,WCF的设计更多地考虑了SOA的场景,以及各种RPC的问题。很多人也会说,RestFul API也是一种RPC啊,并且WCF中也有关于RestFul 的实现啊。很多资料中RPC和RestFul在风格概念上是有一些区别的,其实我觉得这两者的区别比较主观,过度纠结这些就学院派了;我主要关注了实际使用上的一些问题,在WCF中,支持的协议很多,WS-*系列协议,以及一些更简洁的协议,其中提供了一些专用通信协议的性能是非常高的,并且WCF还提供了服务发现等功能,我认为WCF更适合内部系统间的高性能调用,社区中也有其他一些RPC方案可以选择,例如gRPC,Avor,thrift都是和WCF定位相同的产品;而WEB API是关注于HTTP RestFul风格的产品,在此基础上,任何语言、任何终端都能非常容易地进行对接,并且能利用非常成熟的各种HTTP基础设施和解决方案来进行开发、调试、负载均衡、内容分发。所以,WEB API是一种针对HTTP的,偏重于快速开发RestFul风格开放式API的开发框架。目前看来,他并不能取代WCF,他们各有适合的场景,不能认为WEB API是WCF的替代产品。

创建Web  api(vs2017)

 

这里有多种选择

第一种,纯粹的 里面很干净,

相当于这样

第二种

 我没试过,改天有时间再试试

 第三种 (类似mvc 项目的api  只不过加了一个 webapiconfig.cs类...这里又可以扯很多,你们可以百度一下,或者有时间在修改)

第四种  (同上)

下面的两个我都没用过了,你们可以试试,我好懒的

在这里我创建的web api 是第一种

我们像 MVC  一样(怕有些人没用过MVC --> 我就是,虽然以前学了,但是很久没用都忘的差不多了,啊啊啊啊,我们从这开始就把mvc 和web api 分开)

添加控制器  Userx  我们就用一个最简单的方式,让你最快的认识,了解api

   public class UserController : ApiController
    { 
        [HttpGet]
        public string Getuser(string username, string password)
        {
          // API 名字 最好是以请求方式开头 
         //假如你是Get 请求  最好是GetXXX
         return  sername+password;
        }
    }    
UserController

如何我们运行

第一个报错

这里我们要打开webapiconfig.cs 类查看一下

            // Web API 路由
            config.MapHttpAttributeRoutes();
          

            config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );
        }

看清楚了,

api/{controller}/{id} 。。。
api / 控制器/ 也就是传递的参数(我是这么认为的)所以我们这里的路径要改一下

http://localhost:60530/api/User/id?username=1&password=2

但是我这里修改了默认路由机制,所以我的结果是这样子的,如果你们也要修改的话

            // Web API 路由
            config.MapHttpAttributeRoutes();
          

            config.Routes.MapHttpRoute(
                name: "DefaultApi",              //这里
                routeTemplate: "api/{controller}/{action}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );
        }

   

好了现在你运行一下,看看出现了啥

这就是你创建的第一个web API  项目,你也已经成功运行了

未完,待续。。。

猜你喜欢

转载自www.cnblogs.com/whatarey/p/10300801.html