这篇文章将为大家详细讲解有关如何编写一个webapi框架的开端,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
当我们学习到一定程度的时候,我们会想要去深入了解代码底层的东西,也更想拥有一个属于自己的框架,当然,博主也正是如此。本文可能成为编写一个webapi框架的开端。有研究MVC框架的朋友会发现,MVC框架的路由MvcRouteHandler是实现了IRouteHandler而得以实现我们路由,而IRouteHandler只需要返回一个对像,那就是IHttpHandler,而IHttpHandler正是处理http请求的。欣喜之中,我们发现我们已经拥有了编写一个webapi最核心的东西,路由以及请求处理。可能本系列文章不会特别深刻的去说明这两个东西具体是什么,而是专注于使用它们,有兴趣的朋友自行了解哦,对理解。net下面的网络请求处理有很大的帮助。
话不多说了,直接开始
我们直接建立一个完全空的asp.net web项目
不勾选任何东西。
然后,我们新增一个BaseRouteHandler,继承自(实现)IRouteHandler,代码如下
公共类BaseRouteHandler: IRouteHandler { 公共IHttpHandler GetHttpHandler (RequestContext RequestContext对象) { 返回新BaseHttpHandler (); } }
我们看到返回了一个BaseHttphandler,这是我们自己编写的
新建一个BaseHttphandler,实现IHttpHandler,值得注意的是,如果你需要这个处理器能处理,你只需要继承IRequiresSessionState,这个接口只是个标记,不需要任何实现
公共类BaseHttpHandler: IHttpHandler { 公共bool IsReusable { 得到{返回false;} } 公共空间ProcessRequest (HttpContext上下文) { var请求=context.Request; var响应=context.Response; var方法=request.HttpMethod.ToLower (); 结果var=string.Empty; 结果=string.Format(“您正在请求BaseHttpHandler,请求方式是{0},queryStr={1}“,方法,request.QueryString); 响应。ContentType=坝τ贸绦?json"; response.Write(结果); response.End (); } }
IHttpHander只有两个东西,一个是IsResuable, IsReusable属性,MSDN上是这样解释的:获取一个值,该值指示其他请求是否可以使用IHttpHandler实例。也就是说后继的Http请求是不是可以继续使用实现了该接口的类的实例,这里我们设置成假,因为我们不需要再去继承这个处理器了
另外一个是ProcessRequest,这个就是处理具体的请求,HttpContext里面包含了我们的Http请求的各种参数,我们只需要对上下文的数据进行处理。
访问之前,我们需要注册路由
我们为程序添加一个全局全局应用程序类,删除除了Application_Start方法以外所有的方法,然后编写以下代码
公共类全球:System.Web.HttpApplication { 保护无效Application_Start(对象发送方,EventArgs e) { RouteTable.Routes。添加(新路线(“api",新的BaseRouteHandler ())); } }
行文到此,项目已经可以正常运行了,于是我们着急的编译运行,输入地址
注意哦,由于我们路由注册的是api,所以在我们项目地址栏之后加上/api的路由就可以正常请求到我们自定义的HttpRouteHandler里面了。
于是,我们了解到,最最基础的有三个点:
一。实现IRouterHandler,
二。实现IHttpHandler,
三。注册路由
如果你也手痒痒,那么,去实现自己的框架吧!
待续…
关于如何编写一个webapi框架的开端就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看的到。