首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在控制器中接收表单数据时出现问题。C# - MVC

在控制器中接收表单数据时出现问题。C# - MVC
EN

Stack Overflow用户
提问于 2021-01-07 17:44:45
回答 1查看 188关注 0票数 0

朋友们,我有三张桌子。人,学生和地址。人是一个通用的表格,有姓名、电子邮件、电话等字段。我有一个地址表来保存学生的地址。我在动态地从地址字段中获取信息和完成新的学生注册时遇到了困难,我很感谢任何人都能分析。

这是我的代码:我创建了一个AddressViewModel类来加入person和address字段。AddressViewModel.cs

代码语言:javascript
复制
public class AddressViewModel
    {

        public string PES_NAME { get; set; }
        public string PHONE { get; set; }
        public string PES_EMAIL { get; set; }
.
.
        //Address
        public string STREET { get; set; }
        public string CITY { get; set; }
        public string STATE{ get; set; }
.
.
    }

AddressContext.cs

代码语言:javascript
复制
public class AddressContext : DbContext
    {
        /*
         * EF Core - ORM
         * ORM -> Bibliteca mapear Objetos para Banco de Dados Relacionais
         */
        public AddressContext(DbContextOptions<AddressContext> options) : base(options)
        {
            
        }

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            modelBuilder.Entity<Person>()
                .HasOne<Address>(s => s.Address)
                .WithOne(ad => ad.Person)
                .HasForeignKey<Address>(ad => ad.PES_COD);

            modelBuilder.Entity<Person>()
                .HasOne<Aluno>(s => s.Student)
                .WithOne(ad => ad.Person)
                .HasForeignKey<Student>(ad => ad.PersonID);

        }
        public DbSet<Person> Person { get; set; }
        public DbSet<Student> Student { get; set; }
        public DbSet<Address> Address { get; set; }
    }
}

在这里,我不知道该怎么做才能以正确的方式将表单数据:

PersonRepository.cs

代码语言:javascript
复制
 public void create(Person person)
        {
            _banco.Add(person);
            
            Student student = new Student();
            student.Status = "A";
            student.DataCadastro = "10/10/2020";
            student.noFormularioRenach = "1010101";
            student.CodSetor = 10;
            student.PersonID = person.PES_COD;

            _banco.Student.Add(student);

            Address address = new Address();
            address.STREET = ????????;
            address.CITY = ????????;

            _banco.Address.Add(address);

            _banco.SaveChanges();
        }

在学生的情况下,信息是插入银行,因为我直接通知代码,但学生的地址,我不知道如何从表格!

我自动生成的表单如下:

代码语言:javascript
复制
@model LojaVirtual.Models.ViewModels.Student.AddressViewModel

@{
    ViewData["Title"] = "Add";
}

<hr />
<div class="row">
    <div class="col-md-4">
        <form asp-action="Add">
            <div asp-validation-summary="ModelOnly" class="text-danger"></div>
            <div class="form-group">
                <label asp-for="PES_NAME" class="control-label"></label>
                <input asp-for="PES_NAME" class="form-control" />
                <span asp-validation-for="PES_NAME" class="text-danger"></span>
            </div>
.
.
.
          
            <div class="form-group">
                <label asp-for=PHONE" class="control-label"></label>
                <input asp-for="PHONE" class="form-control" />
                <span asp-validation-for="PHONE" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="PES_EMAIL" class="control-label"></label>
                <input asp-for="PES_EMAIL" class="form-control" />
                <span asp-validation-for="PES_EMAIL" class="text-danger"></span>
            </div>


.
.
            <div class="form-group">
                <label asp-for="CITY" class="control-label"></label>
                <input asp-for="CITY" class="form-control" />
                <span asp-validation-for="CITY" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="STATE" class="control-label"></label>
                <input asp-for="STATE" class="form-control" />
                <span asp-validation-for="STATE" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="STREET" class="control-label"></label>
                <input asp-for="STREE" class="form-control" />
                <span asp-validation-for="STREE" class="text-danger"></span>

.
.
.
.
            </div>
            <div class="form-group">
                <input type="submit" value="Create" class="btn btn-default" />
            </div>
        </form>
    </div>
</div>

<div>
    <a asp-action="Index">Back to List</a>
</div>

PersonController.cs

代码语言:javascript
复制
public IActionResult Add([FromForm]Models.Person person, string returnUrl = null)
        {
            if (ModelState.IsValid)
            {
                _clienteRepository.Add(person);
                _loginCliente.Login(person);

                TempData["MSG_S"] = "Success";

                if (returnUrl == null)
                {
                    return RedirectToAction("Index", "Home", new { area = "" });
                }
                else
                {
                    return LocalRedirectPermanent(returnUrl);
                }
            }
            return View();
        }

如果有人能帮忙我很感激!

EN

回答 1

Stack Overflow用户

发布于 2021-01-07 18:35:04

Person具有要寻址的导航属性和映射的“学生实体”。查询数据库时,使用Linq利用地址/学生实体对Person实体的关系。

Person.cs应该如下所示:

代码语言:javascript
复制
public Address Address {get;set;}
public Student Student {get;set;}

人口实体:

代码语言:javascript
复制
public void Add(Person person)
{
     //instead initialize person.Student if the form doesn't pass this object
      person.Student = new Student();
        student.Status = "A";
        student.DataCadastro = "10/10/2020";
        student.noFormularioRenach = "1010101";
        student.CodSetor = 10;
        student.PersonID = person.PES_COD;
        //same thing with address
        person.Address = new Address();
        address.STREET = "123 street dr";
        address.CITY = "toronto";

        _context.SaveChanges();
}

然后,当检索person对象并需要填充外部实体时,应该如下所示:

代码语言:javascript
复制
using System.Linq;

_context.Person
.Include(x => x.Student)
.Include(x => x.Address)
.Where(x => x.Id == PersonId)
.FirstOrDefault();

表单应该是与您的人几乎相同的视图模型(DTO):

代码语言:javascript
复制
@model Person


<input asp-for="Address.Street" type="text"/>
<input asp-for"Student.Name" type="text" />

中填充外键属性

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65617409

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档