Model view controller MVC设计模式模型逻辑
根据MVC设计模式,如果我们创建一个用户(数据库工作),并且我们必须向用户发送一封带有激活码的邮件,那么在模型创建数据库记录之后,这适合模型还是控制器?MVC模式用于创建业务逻辑(模型)和GUI之间的抽象(视图)。控制器只是这两个块之间的适配器(google适配器模式) 因此,控制器应仅具有用于从控制器获取所需信息的代码,并采用该代码以使其适合视图。任何其他逻辑都应位于模型中 只有当您理解模型不是单个类而是所有业务逻辑时,这才有意义 示例(具体实现,但我希望您理解):Model view controller MVC设计模式模型逻辑,model-view-controller,design-patterns,confirmation-email,Model View Controller,Design Patterns,Confirmation Email,根据MVC设计模式,如果我们创建一个用户(数据库工作),并且我们必须向用户发送一封带有激活码的邮件,那么在模型创建数据库记录之后,这适合模型还是控制器?MVC模式用于创建业务逻辑(模型)和GUI之间的抽象(视图)。控制器只是这两个块之间的适配器(google适配器模式) 因此,控制器应仅具有用于从控制器获取所需信息的代码,并采用该代码以使其适合视图。任何其他逻辑都应位于模型中 只有当您理解模型不是单个类而是所有业务逻辑时,这才有意义 示例(具体实现,但我希望您理解): 控制器是一个简化消息并将消
控制器是一个简化消息并将消息委托给模型对象的对象
您将在模型中拥有一个接口对象(或边界对象),它表示两个系统(您的系统和电子邮件)之间的链接。类EmailClient。您的模型对象将在需要时与此对象协作。MVC和MVC启发的设计模式由两层组成:
- 表示层
- 模型层
带有新创建用户激活码的电子邮件应该从模型层发送。控制器应该发送电子邮件。这是错误的。控制器中不应该存在业务逻辑。不知道是谁投了反对票,但你对我的回答非常好。+1如果你说模型不应该发送电子邮件,你还不理解MVC电子邮件。该模型不是一个单独的类。该模型可以包含每个控制器操作的几个类。但是您通常创建一个
UserService
类,该类具有Register
方法,该方法依次调用UserRepository
和EmailService
以执行所需的操作。@IonutFlaviusPogacian,因为您是PHP d伊夫洛普,请读一读。这可能会消除你的一些困惑。
public class UserController : Controller
{
// notice that it's a view model and not a model
public ActionResult Register(RegisterViewModel model)
{
UserService service;
User user = service.Register(model.UserName);
return View("Created");
}
}
// this class is located in the "model"
public class UserService
{
public User Register(string userName)
{
// another class in the "model"
var repository = new UserRepository();
var user = repository.Create(userName);
// just another "model" class
var emailService = new EmailService();
emailService.SendActivationEmail(user.Email);
return user;
}
}