文章更新说明:2024-02-24
V3.2.0 版本:DefaultController 更名为:GlobalController,仅控制器名称变更,其余内容不变。
V3.4.2.1 版本:增加 OnError 方法。
系列目录
1、Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行。
2、Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World。
3、Taurus.MVC WebAPI 入门开发教程3:路由类型和路由映射。
4、Taurus.MVC WebAPI 入门开发教程4:控制器方法及参数定义、获取及基础校验属性【Require】。
5、Taurus.MVC WebAPI 入门开发教程5:控制器安全校验属性【HttpGet、HttpPost】【Ack】【Token】【MicroService】。
6、Taurus.MVC WebAPI 入门开发教程6:全局控制器GlobalController与全局事件。
7、Taurus.MVC WebAPI 入门开发教程7:业务逻辑基类LogicBase的使用。
8、Taurus.MVC WebAPI 入门开发教程8:WebAPI文档与自动化测试。
后续还有两个系列:
1、Taurus.MVC 微服务 入门开发教程系列。 2、Taurus.MVC Web应用 入门开发教程系列。
前言:
全局控制器的作用:
1、可接收所有的404请求,做统一处理。 2、可以实现一些公共的全局的事件。
接收404的过程详细的描述:
对于Taurus.MVC中运行的请求,如果没有对应的控制器接收,默认产生404;
如果项目中存在DefaultController全局控制器,则转交给DefaultController。
如果DefaultController没有对应的方法接收,仍产生404。
如果需要对所有的404请求,做统一的处理输出,则可以重载Default方法,
该方法为最终方法,它可以接收所有的404请求。
下面介绍:全局控制器中的全局事件,文件有点类似以前的Global.cs的味道。
全局控制器的完整方法与注释说明:
/// <summary> /// 全局控制器(适全全局事件处理) /// </summary> public class GlobalController : Taurus.Core.Controller { /// <summary> /// 所有寻址不到的请求都集中执行到此方法(不想接收404则删除此重载方法即可)。 /// </summary> public override void Default() { Write("DefaultController : Hello world"); } /// <summary> /// 用于所有的请求合法性验证,配合[Ack]属性 /// 启用时:局部的先执行(若存在),无局部才执行全局。 /// </summary> public static bool CheckAck(Controller controller, string ack) { //需要自己实现Ack验证 return !string.IsNullOrEmpty(ack); } /// <summary> /// 用于需要登陆后的身份验证,配合[Token]属性 /// 启用时:局部的先执行(若存在),无局部才执行全局。 /// </summary> public static bool CheckToken(Controller controller, string token) { //需要自己实现,或者通过配置Taurus.Auth启动自带的验证(自带的注释掉此方法即可)。 return !string.IsNullOrEmpty(token); } /// <summary> /// 用于校验微服务的内部身份验证,配合[MicroService]属性 /// 启用时:全局仅此一个生效,局部的失效。 /// </summary> public static bool CheckMicroService(Controller controller, string serverKey) { return MicroService.MsConfig.Server.RcKey == serverKey; } /// <summary> /// 全局【路由映射】 /// 启用时:所有请求都进入此地做映射(需要映射时,返回映射的地址;不需要映射的返回空即可)。 /// </summary> public static string RouteMapInvoke(HttpRequest request) { //if (request.Url.LocalPath.StartsWith("/api/") && RouteConfig.RouteMode == 2) //{ // return "/test" + request.RawUrl; //} return string.Empty; } /// <summary> /// 全局【方法执行前拦截】 /// 启用时:先全局,再执行局部(若存在)。 /// </summary> public static bool BeforeInvoke(IController controller) { return true; } /// <summary> /// 全局【方法执行后业务】 /// 启用时:先执行局部(若存在),再执行全局。 /// </summary> public static void EndInvoke(IController controller) { }
/// <summary>
/// 全局【方法执行发生异常时】 版本 >= V3.4.2.1
/// </summary>
public static string OnError(HttpContext context, Exception err)
{
context.Response.StatusCode = 404;
return err.Message;
}
}
全局方法都是静态方法,手写不太方便,对于有全局控制需要的,可以从此处Copy过去要用到的方法,不需要的忽略或注释掉。
下面补充其它说明:
其它1、全局拦截404的方法补充说明:
通过全局拦截后,默认会变成自定义方式:
1、正常处理流程,输出的状态码为200,如果需要返回404状态码,设置输出的状态码即可,如:
public override void Default() { Response.StatusCode = 404; Write("DefaultController : Hello world"); }
2、如果想返回自定义页面,有两种方式:
1、直接读取文件路径,然后Write出去即可。 2、利用小技巧,让它直接触发MVC的页面加载机制即可,按路径存放页面即可:/Views/Default/Default.html。
其它2、全局方法的效用补充说明:
在一个系统中,后续会有一些边缘需求,比如:
1、加强安全校验; 2、方法调用次数的统计; 3、请求日志的记录 4、......
都可以在全局方法中自由发挥,比如在方法结束后:
收集请求参数或处理结果,放置到全局队列中,开个线程在全局定时扫描处理等。
总结:
GlobalController的名字是约定好的,用处也比较实在,一般项目都会用到它。
具体各方法的执行顺序,可以看该方法上的注释。
下一篇介绍:业务逻辑基类LogicBase的使用,还有两篇,将转入微服务系列教程。
版权声明:本文原创发表于 博客园,作者为 路过秋天 本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。 |
个人微信公众号 |
Donation(扫码支持作者):支付宝: |
Donation(扫码支持作者):微信: |