0

I'm working on a project (ASP.NET MVC) for school but today I ran into this error. I'm already trying to fix this for a few hours but nothing works. In this application you log in and your profile will load. This works, but as soon as I change the profile data (in a form), post it, and return the view with a refreshed viewmodel (this still works perfectly fine), I get this nullreferenceexception. I've been looking through this exception details but can't figure out whats null, and what's causing this exception.

This is my view:

@model SailyWebApp.Viewmodels.HomeUserViewmodel
@{
    ViewBag.Title = "Index";
    Layout = "~/Views/Shared/_Layout.cshtml";
}
<body>
    @if(Session["User"] != null && !string.IsNullOrEmpty(Convert.ToString(Session["User"])))
     {
    <h2>Profile of @Session["User"].ToString()</h2>
    <form runat="server" method="post" id="userdata">
        Name:<br>
        <input type="text" name="Name" value="@Model.user.UserName" required /><br>
        Adress:<br>
        <input type="text" name="Address" value="@Model.user.Adress" required /><br>
        City:<br>
        <input type="text" name="City" value="@Model.user.City" required /><br>
        E-mail:<br>
        <input type="text" name="Mail" value="@Model.user.MailAdress" required /><br>
        Phone number:<br>
        <input type="text" name="Phonenumber" value="@Model.user.PhoneNumber" required /><br>
        Profile description:<br>
        <input type="text" name="Description" value="@Model.user.Description" required /><br>
        <input type="submit" name="Save" value="Save" />
    </form>
    }
    else{
    <p>Please log in</p>
    }
</body>

My HomeController looks like this:

public ActionResult Index()
    {
        if (Session["User"] != null)
        {
            User currentUser = (User)Session["User"];
            HomeUserViewmodel viewmodel = new HomeUserViewmodel();
            viewmodel.user = currentUser;
            return View(viewmodel);
        }

        return View();
    }
    [HttpPost]
    public ActionResult Index(HomeUserViewmodel viewmodel)
    {
        User currentUser = (User)Session["User"];
        if (Logic.UserLogic.EditProfile(viewmodel.Address, viewmodel.City, viewmodel.Mail, viewmodel.Phonenumber, viewmodel.Description, currentUser.UserId))
        {
            currentUser = Logic.UserLogic.LoadUser(currentUser.UserId);
            HomeUserViewmodel newviewmodel = new HomeUserViewmodel();
            viewmodel.user = currentUser;
            Session.Clear();
            Session["User"] = currentUser;
            return View(newviewmodel);
        }
        else
        {
            return View();
        }
    } 

My HomeUserViewmodel

public class HomeUserViewmodel
{
    public User user;

    private string name;
    private string address;
    private string city;
    private string mail;
    private string phonenumber;
    private string description;

    public string Name
    {
        get { return name; }
        set { name = value; }
    }
    public string Address
    {
        get { return address; }
        set { address = value; }
    }
    public string City
    {
        get { return city; }
        set { city = value; }
    }
    public string Mail
    {
        get { return mail; }
        set { mail = value; }
    }
    public string Phonenumber
    {
        get { return phonenumber; }
        set { phonenumber = value; }
    }
    public string Description
    {
        get { return description; }
        set { description = value; }
    }
}

Exception details:

System.NullReferenceException: 'object reference not set to an instance of an object'

System.Web.Mvc.WebViewPage.Model.get. was null.

Thanks in advance, I just really don't know where I can find this null value

1 Answers1

1
if (Logic.UserLogic.EditProfile(viewmodel.Address, viewmodel.City, viewmodel.Mail, viewmodel.Phonenumber, viewmodel.Description, currentUser.UserId))
{
    currentUser = Logic.UserLogic.LoadUser(currentUser.UserId);
    HomeUserViewmodel newviewmodel = new HomeUserViewmodel();
    viewmodel.user = currentUser; // <- It's right here, this is your problem
    Session.Clear();
    Session["User"] = currentUser;
    return View(newviewmodel);
}

You're populating the user field on the wrong object, the view model you're sending to the view has a null field, and so you are having a null reference exception thrown.

Jonathon Chase
  • 9,396
  • 21
  • 39