Domanda

Mi piacerebbe avere un sito molto leggero ASP.NET MVC, che include la rimozione come molti dei soliti HttpModules possibile e disabilitando lo stato della sessione. Tuttavia quando provo a fare questo, ottengo il seguente errore:

The SessionStateTempDataProvider requires SessionState to be enabled.

Ho disattivato lo stato della sessione in web.config:

<sessionState mode="Off" />

Capisco che ASP.NET MVC utilizza stato sessione per TempData, ma non ho bisogno / voglia TempData - voglio solo disattivare lo stato della sessione. Aiuto!

È stato utile?

Soluzione

Si potrebbe rendere il proprio ControllerFactory e DummyTempDataProvider. Qualcosa di simile a questo:

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)
  {
  }
}

E allora si avrebbe solo bisogno di registrare il controller fabbrica su App avvio - per esempio si potrebbe fare questo in Global.asax:

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

Altri suggerimenti

Ho trovato un modo, che non mi interessa particolarmente per:

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
    }
}

sovrascrivere manualmente il provider nel controller

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

Io preferirei fortemente un modo per farlo completamente tramite la configurazione, ma questo funziona per il momento.

Se avete bisogno di utilizzare TempData per semplici stringhe, è possibile utilizzare il CookieTempDataProvider in MvcFutures http://aspnet.codeplex.com/Release/ProjectReleases.aspx?ReleaseId=24471 .

Secondo Brad Wilson, questo è stato risolto in MVC 2 Anteprima 1. Vedere qui e qui .

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top