我不确定标题是否正确,但我会进一步解释。
目前我有两个网络应用程序;一个是ASP.NET MVC 5应用程序,另一个是WCF服务。 WCF服务是包含所有业务逻辑和数据访问层的服务。为了访问我的数据库,我使用Entity Framework 6。
我正在尝试创建一个控制器,通过MVC应用程序访问数据库中的某些数据。它应该具有常规CRUD操作以进行测试。我遇到的问题是,因为我的DAL在WCF服务中,所以我不断地将从服务检索的数据转换为模型在ASP.NET MVC应用程序中显示。
我的问题是:是否可以在我的WCF服务上使用EF生成的类作为ASP.NET MVC应用程序中的模型功能?
为了清晰起见,我添加了一些代码示例;
WCF EF生成对象
public class WCFPerson
{
public string Name { get; set; }
public int Age { get; set; }
}
WCF Service
[WebMethod]
public List<WCFPerson> GetAllPersons()
{
using (var db = new SomeDbcontext())
{
return db.WCFPersons.ToList();
}
}
ASP.NET MVC Model
public class Person
{
[Required]
public string Name { get; set; }
[Required, RegularExpression("([0-9]+)")]
public int Age { get; set; }
}
ASP.NET MVC 控制器
public class PersonController : Controller
{
private WCFService.WebServiceClient client = new WCFService.WebServiceClient();
public ActionResult Index()
{
var persons = client.GetAllPersons();
var model = new List<Person>();
//My problem:
foreach (var person in persons)
{
model.Add(new Person() { Name = person.Name, Age = person.Age });
}
return View(model);
}
}
我认为这种强制类型转换很烦人。想象一下,如果数据库发生了变化,那就更加麻烦了。此外,这个例子很小——我的当前模型有大约15个属性,把它们全部转换起来非常麻烦。
我不会直接将数据库连接放在MVC应用程序中。出于特定原因,它必须在WCF服务中。如果可能的话,我早就这样做了。
编辑1: 添加了DataAnnotations。这实际上非常重要。