我有一个Web项目,它是ASp.net MVC,我的控制器是用于路由和api控制器的mvc控制器。我使用Managed Extensibility Framework(MEF)。 我刚开始登录页面,其中有mvc帐户控制器和ap帐户控制器。登录页面运行,当我提交用户名和密码时,它从角度控制器调用api控制器,然后它转到api控制器的构造函数然后在调用我的登录操作之前调用Dispose然后资源的错误页面可以&t找到请求的URL:/ account / login 我的登录操作使用WebSecurity Class(WebMatrix.WebData)
这是我的BaseApi控制器
public class ApiControllerBase : ApiController, IServiceAwareController
{
List<IServiceContract> _DisposableServices;
protected virtual void RegisterServices(List<IServiceContract> disposableServices)
{
}
void IServiceAwareController.RegisterDisposableServices(List<IServiceContract> disposableServices)
{
RegisterServices(disposableServices);
}
List<IServiceContract> IServiceAwareController.DisposableServices
{
get
{
if (_DisposableServices == null)
_DisposableServices = new List<IServiceContract>();
return _DisposableServices;
}
}
protected void ValidateAuthorizedUser(string userRequested)
{
string userLoggedIn = User.Identity.Name;
if (userLoggedIn != userRequested)
throw new SecurityException("Attempting to access data for another user.");
}
protected HttpResponseMessage GetHttpResponse(HttpRequestMessage request, Func<HttpResponseMessage> codeToExecute)
{
HttpResponseMessage response = null;
try
{
response = codeToExecute.Invoke();
}
catch (SecurityException ex)
{
response = request.CreateResponse(HttpStatusCode.Unauthorized, ex.Message);
}
catch (FaultException<AuthorizationValidationException> ex)
{
response = request.CreateResponse(HttpStatusCode.Unauthorized, ex.Message);
}
catch (FaultException ex)
{
response = request.CreateResponse(HttpStatusCode.InternalServerError, ex.Message);
}
catch (Exception ex)
{
response = request.CreateResponse(HttpStatusCode.InternalServerError, ex.Message);
}
return response;
}
}
这是我的帐户Api控制器
[Export]
[PartCreationPolicy(CreationPolicy.NonShared)]
[RoutePrefix("api/account")]
public class AccountApiController : ApiControllerBase
{
[ImportingConstructor]
public AccountApiController(ISecurityAdapter securityAdapter)
{
_SecurityAdapter = securityAdapter;
}
ISecurityAdapter _SecurityAdapter;
[HttpPost]
[Route("login")]
public HttpResponseMessage Login(HttpRequestMessage request, [FromBody]AccountLoginModel accountModel)
{
return GetHttpResponse(request, () =>
{
HttpResponseMessage response = null;
bool success = _SecurityAdapter.Login(accountModel.LoginEmail, accountModel.Password, accountModel.RememberMe);
if (success)
response = request.CreateResponse(HttpStatusCode.OK);
else
response = request.CreateErrorResponse(HttpStatusCode.Unauthorized, "Unauthorized login.");
return response;
});
}
}
我注册了我的mef扩展类,它在globa asax中处理MEF
AggregateCatalog catalog = new AggregateCatalog();
catalog.Catalogs.Add(new AssemblyCatalog(Assembly.GetExecutingAssembly()));
CompositionContainer container = MEFLoader.Init(catalog.Catalogs);
DependencyResolver.SetResolver(new MefDependencyResolver(container)); // view controllers
GlobalConfiguration.Configuration.DependencyResolver = new MefAPIDependencyResolver(container); // web api controllers
这里也是我的mef依赖解析器类
public class MefAPIDependencyResolver : IDependencyResolver
{
public MefAPIDependencyResolver(CompositionContainer container)
{
_Container = container;
}
CompositionContainer _Container;
public IDependencyScope BeginScope()
{
return this;
}
public object GetService(Type serviceType)
{
return _Container.GetExportedValueByType(serviceType);
}
public IEnumerable<object> GetServices(Type serviceType)
{
return _Container.GetExportedValuesByType(serviceType);
}
public void Dispose()
{
}
}
我失去了情节。提前感谢您的帮助。
答案 0 :(得分:0)
OOps这是我的错。 它是关于html表单对mvc控制器有一个动作,它不存在 所以而不是
<form class="loginForm" action="@Url.Action("Login","Account")" method="post" name="loginForm">
所以我用
替换它 <form class="loginForm" name="loginForm"> <!--Without action-->
<!--and submit button-->
<button type="submit" class="btn blue pull-right" ng-click="login()">