Search code examples
c#entity-frameworkrazor-pagesargumentnullexception

ArgumentNullException: Value cannot be null. Parameter name: entity


I am encountering the following Internal Server Error whenever I try to save the data entered on a website: ArgumentNullException: Value cannot be null. Parameter name: entity

I am able to write from the database and see it on the website but I am not able to write on the website to store it in database and display it on the website. I am working with Razor Pages

C# Code is shown here. PFA.

C# Code:

public class AddPreferenceModel : PageModel
    {
        [BindProperty]
        public CUser User{ get; set; }
        public CStudent Stu{ get; set; }
        public CPreference Prefer { get; set; }

        private readonly IHostingEnvironment _environment;
        private readonly CWebApplication _context;
        private readonly IEmailService _emailServices;
        private readonly IUserService _UserService;

        public AddPreferenceModel(IUserService UserService, CWebApplication context, IHostingEnvironment IHostingEnvironment, INTUserService INTUserService, IEmailService emailService)
        {
            _environment = IHostingEnvironment;
            _UserService = UserService;
            _context = context;
            _emailServices = emailService;

            User = _UserService.GetUser();
        }

        public ActionResult OnGet()             
        {
            if (NTUser.Role != Role.Admin)
            {
                return RedirectToPage("/Denied");
            }
            return Page();
        }

        [HttpPost]
        public async Task<IActionResult> OnPostAsync()
        {
            if (!ModelState.IsValid)
            {
                return Page();
            }

            if (NTUser.Role != Role.Admin && false)
            {
                return RedirectToPage("/Denied");
            }
            _context.Preference.Add(Prefer);
            await _context.SaveChangesAsync();

            return RedirectToPage("Index");
        }
    }

HTML:

<div class="Custom-Content Custom-Max-Width-800">
    <h2 class="h2">Add your preference</h2>

    <p>
        Please check all the details before submitting
    </p>
    <form enctype="multipart/form-data" id="orderForm" method="post">
        <div class="col-md-12"><hr/></div>
        <h4 class="h4 Custom-H4-Less-Margin-Bottom">Preference</h4>
        <div class="Custom-Form col-sm-6">
            NTUser
            <input asp-for="Prefer.StudentUserID" type="text" value="" required="" />
        </div>
        <div class="Custom-Form col-sm-6">
            Preference One
            <input asp-for="Prefer.name" type="text" value="" required="" />
        </div>
        <div class="Custom-Form col-sm-12">
            Priority

            <select asp-for="Prefer.Priority" required>
                <option value="High">High</option>
                <option value="Medium">Medium</option>
                <option value="Low">Low</option>
            </select>
        </div>
        <hr/>
        <button class="Custom-Button" type="submit" name="save">Save</button>
    </form>
</div>

Preference Class:

 public enum Priority { HIGH = 0, MEDIUM = 1, LOW = 2 }

        public class CPreference
        {
            public string StudentUserID{ get; set; }
            public Priority Priority { get; set; }
            public string name { get; set; }

            public CStudent Student { get; set; }
         }

The values entered on the website needs to be stored in a table in the database and displayed in "Index" page. But whenever I hit save, the Internal Server Error with

ArgumentNullException: Value cannot be null. Parameter name: entity

gets thrown. As I already mentioned, I am able to write to the page from the database.

The full stack:

Microsoft.EntityFrameworkCore.Utilities.Check.NotNull<T>(T value, string parameterName)
Microsoft.EntityFrameworkCore.DbContext.Add<TEntity>(TEntity entity)
Microsoft.EntityFrameworkCore.Internal.InternalDbSet<TEntity>.Add(TEntity entity)
LearnAngebot.Pages.Preference.AddPreferenceModel.OnPostAsync() in AddPreference.cshtml.cs

                _context.Preference.Add(Prefer);

Microsoft.AspNetCore.Mvc.RazorPages.Internal.ExecutorFactory+GenericTaskHandlerMethod.Convert<T>(object taskAsObject)
Microsoft.AspNetCore.Mvc.RazorPages.Internal.ExecutorFactory+GenericTaskHandlerMethod.Execute(object receiver, object[] arguments)
Microsoft.AspNetCore.Mvc.RazorPages.Internal.PageActionInvoker.InvokeHandlerMethodAsync()
Microsoft.AspNetCore.Mvc.RazorPages.Internal.PageActionInvoker.InvokeNextPageFilterAsync()
Microsoft.AspNetCore.Mvc.RazorPages.Internal.PageActionInvoker.Rethrow(PageHandlerExecutedContext context)
Microsoft.AspNetCore.Mvc.RazorPages.Internal.PageActionInvoker.Next(ref State next, ref Scope scope, ref object state, ref bool isCompleted)
Microsoft.AspNetCore.Mvc.RazorPages.Internal.PageActionInvoker.InvokeInnerFilterAsync()
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeNextResourceFilter()
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Rethrow(ResourceExecutedContext context)
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Next(ref State next, ref Scope scope, ref object state, ref bool isCompleted)
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeFilterPipelineAsync()
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeAsync()
Microsoft.AspNetCore.Builder.RouterMiddleware.Invoke(HttpContext httpContext)
Microsoft.AspNetCore.StaticFiles.StaticFileMiddleware.Invoke(HttpContext context)
Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)

Solution

  • Hope this help you. Remove [BindProperty] from CUser and add [BindProperty] on Prefer see below

    public CUser User{ get; set; }
    public CStudent Stu{ get; set; }
    [BindProperty]
    public CPreference Prefer { get; set; }