web-dev-qa-db-fra.com

Comment utiliser la variable de session dans MVC

J'ai déclaré la variable Session dans le fichier "Global.asax" comme,

protected void Application_Start()
        {
            AreaRegistration.RegisterAllAreas();
            FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
            RouteConfig.RegisterRoutes(RouteTable.Routes);
            BundleConfig.RegisterBundles(BundleTable.Bundles);
            int temp=4;
            HttpContext.Current.Session.Add("_SessionCompany",temp);
        }

Et je veux utiliser cette variable de session dans l'action de mon contrôleur comme,

 public ActionResult Index()
        {
            var test = this.Session["_SessionCompany"];
            return View();
        }

Mais je reçois une exception lors de l'accès à la variable de session. Veuillez m'aider à ce sujet: Comment puis-je accéder à la variable de session dans l'action de mon contrôleur.

Je reçois une exception comme "Object Reference not set to an Insatance of an object" dans Application_Start dans Global.asax en ligne

HttpContext.Current.Session.Add("_SessionCompany",temp);
13
Rahul

Le thread qui démarre l'application n'est pas le thread de demande utilisé lorsque l'utilisateur fait une demande à la page Web.

Cela signifie que lorsque vous définissez le Application_Start, vous ne le définissez pour aucun utilisateur.

Vous souhaitez définir la session sur Session_Start un événement.

Modifier:

Ajoutez un nouvel événement à votre fichier global.asax.cs appelé Session_Start et supprimez les éléments liés à la session de Application_Start

protected void Session_Start(Object sender, EventArgs e) 
{
   int temp = 4;
   HttpContext.Current.Session.Add("_SessionCompany",temp);
}

Cela devrait résoudre votre problème.

21
Phill

Vous ne devez pas définir de variables de session dans Application_Start (), car cette méthode n'est appelée qu'une seule fois, lorsque l'application démarre dans IIS. Ce n'est pas basé sur la session.

De plus, je suppose que votre contrôleur a une propriété Session? L'avez-vous réglé correctement?

Utilisation HttpContext.Current.Session["_SessionCompany"] plutôt que this.Session["_SessionCompany"] - Cela devrait fonctionner.

4
Spikeh

Dans le contrôleur, vous pouvez accéder comme ceci ..

YourControllerID.ControllerContext.HttpContext.Session ["_ SessionCompany"]

1
Hozefa Laxmidhar

Utilisez cette classe d'assistance:

namespace Projectname.UI.HtmlHelpers
{
    //[DebuggerNonUserCodeAttribute()]
    public static class SessionHelper
    {
        public static T Get<T>(string index)
        {
            //this try-catch is done to avoid the issue where the report session is timing out and breaking the entire session on a refresh of the report            


            if (HttpContext.Current.Session == null)
            {
                var i = HttpContext.Current.Session.Count - 1;

                while (i >= 0)
                {
                    try
                    {
                        var obj = HttpContext.Current.Session[i];
                        if (obj != null && obj.GetType().ToString() == "Microsoft.Reporting.WebForms.ReportHierarchy")
                            HttpContext.Current.Session.RemoveAt(i);
                    }
                    catch (Exception)
                    {
                        HttpContext.Current.Session.RemoveAt(i);
                    }

                    i--;
                }
                if (!HttpContext.Current.Request.AppRelativeCurrentExecutionFilePath.Equals("~/Home/Default"))
                {
                    HttpContext.Current.Response.Redirect("~/Home/Default");
                }
                throw new System.ComponentModel.DataAnnotations.ValidationException(string.Format("You session has expired or you are currently logged out.", index));
            }

            try
            {
                if (HttpContext.Current.Session.Keys.Count > 0 && !HttpContext.Current.Session.Keys.Equals(index))
                {

                    return (T)HttpContext.Current.Session[index];
                }
                else
                {
                    var i = HttpContext.Current.Session.Count - 1;

                    while (i >= 0)
                    {
                        try
                        {
                            var obj = HttpContext.Current.Session[i];
                            if (obj != null && obj.GetType().ToString() == "Microsoft.Reporting.WebForms.ReportHierarchy")
                                HttpContext.Current.Session.RemoveAt(i);
                        }
                        catch (Exception)
                        {
                            HttpContext.Current.Session.RemoveAt(i);
                        }

                        i--;
                    }
                    if (!HttpContext.Current.Request.AppRelativeCurrentExecutionFilePath.Equals("~/Home/Default"))
                    {
                        HttpContext.Current.Response.Redirect("~/Home/Default");
                    }
                    throw new System.ComponentModel.DataAnnotations.ValidationException(string.Format("You session does not contain {0} or has expired or you are currently logged out.", index));
                }
            }
            catch (Exception e)
            {
                var i = HttpContext.Current.Session.Count - 1;

                while (i >= 0)
                {
                    try
                    {
                        var obj = HttpContext.Current.Session[i];
                        if (obj != null && obj.GetType().ToString() == "Microsoft.Reporting.WebForms.ReportHierarchy")
                            HttpContext.Current.Session.RemoveAt(i);
                    }
                    catch (Exception)
                    {
                        HttpContext.Current.Session.RemoveAt(i);
                    }

                    i--;
                }
                if (!HttpContext.Current.Request.AppRelativeCurrentExecutionFilePath.Equals("~/Home/Default"))
                {
                    HttpContext.Current.Response.Redirect("~/Home/Default");
                }
                return default(T);
            }
        }

        public static void Set<T>(string index, T value)
        {
            HttpContext.Current.Session[index] = (T)value;
        }
    }
}

et dans votre contrôleur, vous définissez tout, par exemple un contrôleur de connexion:

Session Helper.Set<string>("Username", Login User.User Name);
Session Helper.Set<int?>("Tenant Id", Login User.Tenant Id);
SessionHelper.Set<User Type>("User Type");
SessionHelper.Set<string>("", Login User To String());
SessionHelper.Set<int>("Login User Id", Login User.Login UserId);
SessionHelper.Set<string>("Login User", Login User.To String());
SessionHelper.Set<string>("Tenant", Tenant);
SessionHelper.Set<string>("First name", Login User.First Name);
SessionHelper.Set<string>("Surname", Login User.Surname);
SessionHelper.Set<string>("Vendor ", Vendor );
SessionHelper.Set<string>("Wholesaler ", Wholesaler );
SessionHelper.Set<int?>("Vendor Id", Login User );
SessionHelper.Set<int?>("Wholesaler Id", Login User Wholesaler Id);

et vous l'appelez simplement où vous voulez:

var CreatedBy = SessionHelper.Get<int>("LoginUserId"),

il s'agit d'un simple accès à l'entité ou d'un ensemble pour l'attribuer.

0
Quintin moodley