话不多说了,直接开始
我们直接建立一个完全空的asp.net web项目
不勾选任何东西。
然后,我们新增一个BaseRouteHandler,继承自(实现)IRouteHandler,代码如下
public class BaseRouteHandler:IRouteHandler
{
public IHttpHandler GetHttpHandler(RequestContext requestContext)
{
return new BaseHttpHandler();
}
}
我们看到返回了一个BaseHttphandler,这是我们自己编写的
新建一个BaseHttpHandler,实现IHttpHandler,值得注意的是,如果你需要这个Handler能处理session,你只需要继承IRequiresSessionState,这个接口只是个标记,不需要任何实现
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方法以外所有的方法,然后编写以下代码
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框架的开端的详细内容,更多请关注php中文网其它相关文章!
声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
程序员必备接口测试调试工具:点击使用
Apipost = Postman + Swagger + Mock + Jmeter
Api设计、调试、文档、自动化测试工具
网页生成APP,用做网站的技术去做APP:立即创建
手机网站开发APP、自助封装APP、200+原生模块、2000+映射JS接口按需打包
相关文章
相关视频