编写一个webapi框架的开端


本文摘自PHP中文网,作者零下一度,侵删。

当我们学习到一定程度的时候,我们会想要去深入了解代码底层的东西,也更想拥有一个属于自己的框架,当然,博主也正是如此。本文可能成为编写一个webapi框架的开端。有研究MVC框架的朋友会发现,mvc框架的路由MvcRouteHandler是实现了IRouteHandler而得以实现我们路由,而IRouteHandler只需要返回一个对像,那就是IHttpHandler,而IHttphandler正是处理http请求的。欣喜之中,我们发现我们已经拥有了编写一个webapi最核心的东西,路由以及请求处理。可能本系列文章不会特别深刻的去说明这两个东西具体是什么,而是专注于使用它们,有兴趣的朋友自行了解哦,对理解.net下面的网络请求处理有很大的帮助。

  话不多说了,直接开始

  我们直接建立一个完全空的asp.net web项目

  

  不勾选任何东西。

  然后,我们新增一个BaseRouteHandler,继承自(实现)IRouteHandler,代码如下

1

2

3

4

5

6

7

public class BaseRouteHandler:IRouteHandler

   {

       public IHttpHandler GetHttpHandler(RequestContext requestContext)

       {

           return new BaseHttpHandler();

       }

   }

  我们看到返回了一个BaseHttphandler,这是我们自己编写的

  新建一个BaseHttpHandler,实现IHttpHandler,值得注意的是,如果你需要这个Handler能处理session,你只需要继承IRequiresSessionState,这个接口只是个标记,不需要任何实现

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

public class BaseHttpHandler:IHttpHandler

    {

        public bool IsReusable

        {

            get { return false; }

        }

        public void ProcessRequest(HttpContext context)

        {

            var request = context.Request;

            var response = context.Response;

            var method = request.HttpMethod.ToLower();

            var result = string.Empty;

             

            result = string.Format("您正在请求BaseHttpHandler,请求方式是{0},queryStr={1}", method,request.QueryString);

            response.ContentType = "application/json";

            response.Write(result);

            response.End();

        }

    }

  IHttpHander只有两个东西,一个是IsResuable,IsReusable属性,MSDN上是这样解释的:获取一个值,该值指示其他请求是否可以使用 IHttpHandler 实例。也就是说后继的Http请求是不是可以继续使用实现了该接口的类的实例,这里我们设置成false,因为我们不需要再去继承这个Handler了

  另外一个是ProcessRequest,这个就是处理具体的请求,HttpContext里面包含了我们的http请求的各种参数,我们只需要对context的数据进行处理。

  访问之前,我们需要注册路由

  我们为程序添加一个全局全局应用程序类,删除除了Application_Start方法以外所有的方法,然后编写以下代码

1

2

3

4

5

6

7

public class Global : System.Web.HttpApplication

   {

       protected void Application_Start(object sender, EventArgs e)

       {

           RouteTable.Routes.Add(new Route("api", new BaseRouteHandler()));

       }

   }

  行文到此,项目已经可以正常运行了,于是我们着急的编译运行,输入地址

  注意哦,由于我们路由注册的是api,所以在我们项目地址栏之后加上/api的路由就可以正常请求到我们自定义的HttpRouteHandler里面了。

  于是,我们了解到,最最基础的有三个点:

  一.实现IRouterHandler,

  二.实现IHttpHandler,

  三.注册路由

  如果你也手痒痒,那么,去实现自己的框架吧!

  待续。。。

以上就是编写一个webapi框架的开端的详细内容!

相关阅读 >>

asp .net 面试题及答案分享

关于websocket部署服务器外网无法连接的解决方案

asp.net在网站根目录下创建文件夹

asp.net web api 异常处理经验总结

vs 中引用的问题--出现小叹号

asp.net中关于webapi与ajax进行跨域数据交互时cookies数据的传递

asp.net中webform的生命周期相关讲解

关于操作 asp.net web api的实例

web api的 asp.net属性路由实例详解

详细介绍c#中调用formatmessage api

更多相关阅读请进入《webapi》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...

    暂无评论...