Asp.Net MVC--Controller激活2
在使用MVC项目中,如果激活控制器,则就会向前台返回action执行的结果。
很多时候,根据需求,手动激活控制器来向客户端返回结果。
一、激活实例代码1
这是在Global文件中使用
var routeData = new RouteData(); routeData.Values["controller"] = "Sys"; routeData.Values["action"] = "NotFound"; var requestContext = new RequestContext(new HttpContextWrapper(httpContext), routeData); var controller = ControllerBuilder.Current.GetControllerFactory().CreateController(requestContext, "Sys") as SysController; //controller.ViewData.Model=model; (controller as IController).Execute(requestContext); ControllerBuilder.Current.GetControllerFactory().ReleaseController(controller);
激活实例代码2
这是在controller中的情况下
string controllerName = this.RequestContext.RouteData.Controller; IControllerFactory controllerFactory = ControllerBuilder.Current.GetControllerFactory(); IController controller = controllerFactory.CreateController(this.RequestContext, controllerName); controller.Execute(this.RequestContext);
实例代码3,激活指定controller中的action并返回视图到当前上下文:
//输出指定controller下的内容 RouteData routeData = new RouteData(); routeData.Values.Add("controller", "ViewOne"); routeData.Values.Add("action", "TempTwo"); routeData.Values.Add("name", "zhangsan"); IController one = new ViewOneController(); one.Execute(new RequestContext(new HttpContextWrapper(Context), routeData));
特别说明:
控制器都继承自IController,在控制器激活之后调用Execute()方法,执行请求处理,会向客户端返回运行结果。
namespace System.Web.Mvc { // // 摘要: // 定义控制器所需的方法。 public interface IController { // // 摘要: // 执行指定的请求上下文。 // // 参数: // requestContext: // 请求上下文。 void Execute(RequestContext requestContext); } }
更多:
分类:
Asp.Net MVC
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
2013-12-29 导入excel错误:外部表不是预期的格式 解决方案(Oledb)
2013-12-29 未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0”提供程序(Oledb)