由于创建博客,我需要尝试一些新的技术,新的思路,所以我没规规矩矩的写博客,用上了诸多以前没用的东西,比如现在这个(我只是听过web api 我连 web server 都只是用过两三次/手动滑稽)
昨天开始研究的,一直到现在,我还是懵比的,只不过也算是比不懂懂了一点吧。
在这里,谢谢各位前辈与大佬的博客,建议,demo(虽然demo 我一个都看不懂,也运行不了,但还是感谢你们),思路
谢谢你们(90度鞠躬)
希望大家觉得这篇文章好的话都顶一顶(第一次说出这话/脸红.jpg)
下面的文章 用到哪些博客,我都会引用过来,如果侵权的话,希望能告诉我,我会把引用的地方删除的,谢谢
首先先百度一下,Web API ,Web server ,MVC www.baidu.com
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的替代产品。
WebApi 基于资源,Webserver 基于方法
创建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; } }
如何我们运行
第一个报错
这里我们要打开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 项目,你也已经成功运行了
未完,待续。。。