我有这个MVC4控制器(ControllerB):
public class MyControllerB : Controller
{
public bool Check(string actionName, ControllerBase controllerBase)
{
ControllerContext controllerContext = new ControllerContext(this.ControllerContext.RequestContext, controllerBase);
...
}
}我从"ControllerA“调用ControllerB的Check方法,如下所示:
bool b = new MyControllerB().Check("Index", this);我得到Object reference not set to an instance of an object是因为this.ControllerContext为空。
如果我将Check方法移到ControllerA,它就能正常工作。但是我需要这个方法在一个不同的控制器中。如何修复代码,使this.ControllerContext`不为空?
发布于 2013-10-01 22:43:01
ControllerContext为空,因为您是从ControllerA手动创建ControllerB实例。
通常,IController实例是由注册的IControllerFactory创建的,通常是System.Web.Mvc.DefaultControllerFactory。控制器工厂将对实例执行new()操作并正确初始化设置。
正如@DZL所说,通常情况下,让两个控制器都子类化一个BaseController类要好得多,该类可以具有共享的初始化和共享的属性和方法。
我不明白你想要做什么的业务逻辑,但这里有一个使用两个控制器的基类的代码示例:
namespace MyNamespace.Controllers
{
public class MyControllerBase : Controller
{
public bool Check(string actionName, ControllerBase controllerBase)
{
ControllerContext controllerContext = new ControllerContext(this.ControllerContext.RequestContext, controllerBase);
return false;
}
}
public class MyControllerA : MyControllerBase
{
ActionResult Index()
{
bool b = base.Check("Index", this);
return View();
}
}
public class MyControllerB : MyControllerBase
{
ActionResult Index()
{
bool b = base.Check("Index", this);
return View();
}
}
}如果你真的想做你所要求的事情,你必须调用IControllerFactory.CreateController(requestContext, controllerName)而不是new ControllerB(),但这是一种非常复杂的方式-我不推荐这样做。
https://stackoverflow.com/questions/19055119
复制相似问题