LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

C# ASP.NET MVC净化版WebAPI框架

admin
2025年6月30日 8:16 本文热度 34

前言


我们都知道WebAPI是依赖于ASP.NET MVC,所以想创建WebAPI就需要先创建一个ASP.NET MVC项目。


但用Visual Studio创建的MVC项目通常会带很多功能,而这些功能,很多是我们并不想用的,或者我们想用其他开源控件代替它。


而这样杂乱的起始项目,对于我们这种有精神洁癖的开发者而言,简直是折磨。


所以,让我们编写一个简洁版本的WebAPI来净化世界吧。


净化版WebAPI预览


首先,我们先看下净化版WebAPI的结构。



如上图所示,代码结构很简单,除开配置文件,整个Web项目只有2个文件;而需要被调用的WebAPI都被封装到了WebAPI程序集中了。


接下来我们一起看下编写这个净化版WebAPI的过程吧。


净化版WebAPI编写


WebApiConfig


首先,引入必要的Dll,如下图所示。



然后,我们编写Web项目的写WebApiConfig;代码如下:


public static class WebApiConfig
{
   public static void Register(HttpConfiguration config)
   
{
       config.Filters.Add(new WebApiAttribute());
       // 解决json序列化时的循环引用问题
   config.Formatters.JsonFormatter.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore;
       // 对 JSON 数据使用混合大小写。跟属性名同样的大小.输出
    config.Formatters.JsonFormatter.SerializerSettings.ContractResolver = new DefaultContractResolver();
       // Web API 路由
       config.MapHttpAttributeRoutes();
       config.Routes.MapHttpRoute(
           name: "DefaultApi",
           routeTemplate: "webapi/{controller}/{id}",
           defaults: new { id = RouteParameter.Optional }
       );
   }
}


可以看到WebApiConfig是个静态类中,我们在其中创建了静态注册方法Register,在方法内,我们主要在做一件事,那就是为HttpConfiguration对象做配置。


而在配置中,我们将WepApi的路由配置成了webapi/{controller}/{id},也就是说,我们的WebAPI未来的访问地址将为【http://localhost:5180/webapi/Login】这样的模式。


在WebApiConfig类中,我们还用到了这样一个类WebApiAttribute,我们在为HttpConfiguration对象的Filters属性,添加了这个类的对象。


通过Filters属性这个字样,我们可以得出,这个类主要应用应该是过滤。


下面我们看一下这个类的代码:


[AttributeUsage(AttributeTargets.Method | AttributeTargets.Class, Inherited = true, AllowMultiple = true)]
public class WebApiAttribute : ActionFilterAttribute
{
   public override void OnActionExecuting(HttpActionContext actionContext)
   
{
       //API执行前触发
       if (true)//当前设置,所有API都可以被调用
       {
           base.OnActionExecuting(actionContext);
       }
       else
       {
           throw new Exception("Error");
       }
   }
   public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)
   
{
       //API执行后触发 若发生例外则不在这边处理
       if (actionExecutedContext.Exception != null)
           return;
       base.OnActionExecuted(actionExecutedContext);
   }
}


通过阅读代码,我们应该可以发现,这是一个AOP的过滤器。


在执行真正WebAPI之前,会先进入这里进行过滤,过滤通过的API,才会调用 base.OnActionExecuting(actionContext)方法进行调用和执行。


结束调用同理,结束调用前,会在该类中进行拦截和过滤处理。


配置文件


WebApiConfig编写结束了,现在,我们需要将这个静态类注册到项目中。


打开Global.asax文件,编写如下代码:


protected void Application_Start()
{
   GlobalConfiguration.Configure(WebApiConfig.Register);
GlobalConfiguration.Configuration.Formatters.XmlFormatter.SupportedMediaTypes.Clear();//删除XML格式 回應
}


可以看到,我们已通过Configure方法,将我们编写好的WebApiConfig添加到了全局配置中了。


因为网站访问都存在跨域问题,所以我们再向Global.asax中添加如下代码处理:


protected void Application_BeginRequest(object sender, System.EventArgs e)
{
   var req = System.Web.HttpContext.Current.Request;
   if (req.HttpMethod == "OPTIONS")//过滤options请求,用于js跨域
   {
       Response.StatusCode = 200;
       Response.SubStatusCode = 200;
       Response.End();
   }
}


到此Web项目的编写就完成了,下面我们在WebAPI程序集中,编写个简单的WebAPI,代码如下:


public class LoginController : BaseApiController
{
   public BaseResult Get()
   
{
       try
       {
           return new BaseResult() { IsSuccess=true };
       }
       catch (Exception ex)
       {
           throw ex;
       }
   }
}
public class BaseApiController : ApiController
{  
   public string Options()
   
{
       return null;
   }
}


然后我们运行网站,进行WebAPI访问。



如上图所示,我们的WebAPI访问成功,到此C#净化版WebAPI框架就介绍完了。


Github地址:https://github.com/kiba518/WebApi


阅读原文:原文链接


该文章在 2025/7/1 22:50:45 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved