Pregunta

Me gustaría tener un sitio ASP.NET MVC muy ligero que incluye la eliminación de la mayor cantidad de HttpModules habituales como sea posible y deshabilitar el estado de sesión. Sin embargo cuando intento hacer esto, me sale el siguiente error:

The SessionStateTempDataProvider requires SessionState to be enabled.

He estado de sesión con discapacidad en web.config:

<sessionState mode="Off" />

Yo entiendo que ASP.NET MVC utiliza estado de sesión para TempData, pero no necesito / quiero TempData - Sólo quiero deshabilitar el estado de sesión. Ayuda!

¿Fue útil?

Solución

Se podría hacer su propia ControllerFactory y DummyTempDataProvider. Algo como esto:

public class NoSessionControllerFactory : DefaultControllerFactory
{
  protected override IController GetControllerInstance(Type controllerType)
  {
    var controller = base.GetControllerInstance(controllerType);
    ((Controller) controller).TempDataProvider = new DummyTempDataProvider();
    return controller;
  }
}


public class DummyTempDataProvider : ITempDataProvider
{
  public IDictionary<string, object> LoadTempData(ControllerContext controllerContext)
  {
    return new Dictionary<string, object>();
  }

  public void SaveTempData(ControllerContext controllerContext, IDictionary<string, object> values)
  {
  }
}

Y a continuación, sólo se necesita para registrar el controlador de la fábrica en el arranque de la aplicación - por ejemplo, usted puede hacer esto en Global.asax:

ControllerBuilder.Current.SetControllerFactory(new NoSessionControllerFactory());

Otros consejos

He encontrado una manera, que particularmente no me importa para:

Crea NoTempDataProvider

using System;
using System.Collections.Generic;
using System.Web.Mvc;

namespace Facebook.Sites.Desktop.Auth.Models
{
    public class NoTempDataProvider : ITempDataProvider
    {
        #region [ ITempDataProvider Members ]

        public IDictionary<String, Object> LoadTempData(ControllerContext controllerContext)
        {
            return new Dictionary<String, Object>();
        }

        public void SaveTempData(ControllerContext controllerContext, IDictionary<String, Object> values) { }

        #endregion
    }
}

Sobrescribir manualmente el proveedor en el controlador

public class AuthController : Controller
{
    public AuthController()
    {
        this.TempDataProvider = new NoTempDataProvider();
    }
}

Yo preferiría en gran medida una forma de hacerlo por completo a través de la configuración, pero esto funciona por ahora.

Si es necesario utilizar TempData para cadenas simples, se puede utilizar el CookieTempDataProvider en MvcFutures http://aspnet.codeplex.com/Release/ProjectReleases.aspx?ReleaseId=24471 .

De acuerdo con Brad Wilson, esto se ha solucionado en MVC 2 Vista Previa 1. Véase aquí y aquí .

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top