6

我一直试图在 ASP.NET 中找到 MVC 和 3 层架构之间的区别。我参考了一些以前的一些以前的问题和一些页面,但可以找到一个明确的答案。
这是一个关于 MVC 实现的 msdn 页面:http: //msdn.microsoft.com/en-us/library/ff647462.aspx

考虑一下,我有这个代码:
Single page aspx UI and code as well

<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SqlClient" %>
<html>
   <head>
      <title>start</title>
      <script language="c#" runat="server">
         void Page_Load(object sender, System.EventArgs e)
         {
            String selectCmd = "select * from Recording";

            SqlConnection myConnection = 
               new SqlConnection(
                  "server=(local);database=recordings;Trusted_Connection=yes");
            SqlDataAdapter myCommand = new SqlDataAdapter(selectCmd, 
               myConnection);

            DataSet ds = new DataSet();
            myCommand.Fill(ds, "Recording");

            recordingSelect.DataSource = ds;
            recordingSelect.DataTextField = "title";
            recordingSelect.DataValueField = "id";
            recordingSelect.DataBind();
         }
       </script>
   </head>
   <body>
         <asp:dropdownlist id="recordingSelect" runat="server" />
         <asp:button runat="server" text="Submit" OnClick="SubmitBtn_Click" />
      </form>
   </body>
</html>

现在,考虑我有不同的文件
---- View 和 Code-behind spearated ----
.aspx

<%@ Page language="c#" Codebehind="Solution.aspx.cs" 
   AutoEventWireup="false" Inherits="Solution" %>
<html>
         <asp:dropdownlist id="recordingSelect" runat="server" />
      </form>
   </body>
</html>

.aspx.cs

using System;
using System.Data;
using System.Data.SqlClient;
public class Solution : System.Web.UI.Page
{
   private void Page_Load(object sender, System.EventArgs e)
   {
      if(!IsPostBack)
      {
         String selectCmd = "select * from Recording";
         SqlConnection myConnection = 
            new SqlConnection(
               "server=(local);database=recordings;Trusted_Connection=yes");
         SqlDataAdapter myCommand = new SqlDataAdapter(selectCmd, myConnection);
         DataSet ds = new DataSet();
         myCommand.Fill(ds, "Recording");
         recordingSelect.DataSource = ds;
         recordingSelect.DataTextField = "title";
         recordingSelect.DataValueField = "id";
         recordingSelect.DataBind();
      }
   }
  1. 看到上面这个类的msdn 页面链接Controller,我无法辨别业务逻辑(对于 3 层架构中的中间层来说是相似的)和控制器之间的区别。
  2. 3-tier 和 MVC 是完全不同的东西吗?Visual Studio 中的 ASP.NET 应用程序是否已经像 MVC 形式那样分离文件?如果这些没有不同,哪一种是首选风格?
  3. 如果 .aspx 和 .aspx.cs 已经分开,那么 MVC 框架是什么?
4

3 回答 3

6

我实际上为此苦苦挣扎了一段时间,关于如何正确实现它有不同的理念,所以这就是我如何用我自己的话理解它如何理解所涉及的不同事物之间的关系(模型/视图/控制器/业务逻辑):

  • 视图
    拥有所有的 Html / jQuery 代码,它们使用Model来自控制器的实例形式的数据
  • 模型
    保存视图需要呈现的信息的类(产品列表等)
  • 控制器
    • 他们接受传入的请求
    • 进行必要的准备(参数提取等)以调用您的实际业务逻辑代码。
    • 然后调用业务逻辑代码并检索结果
    • 然后他们获取结果并将其转换为 UI 可以理解的模型
  • 业务逻辑
    这是您实际的业务逻辑代码,调用数据库等。我认为这与整个 MVC 事物完全分开,实际上它甚至不应该知道它是从 MVC Web 应用程序执行的。通常我们将它放在不同的程序集(类库)中,以确保根本不依赖 MVC 代码。
    这使得仅对业务逻辑进行单元测试变得非常简单,因为对 MVC 没有依赖关系。

我见过其他将业务逻辑实际放入控制器的方法,但在我看来,这违背了目的。我们构建 MVC 应用程序不是为了有一个好的结构,也是为了能够更好地执行单元测试。

回到您的问题,这一切与 ASP.NET 3 层体系结构有何关系。
可以说,基本上整个 MVC Web 应用程序只不过是表示层(+ 将表示层与业务层连接起来)。

其他层与表示层保持分离和独立,就像它们以前应该有的那样。

于 2012-03-17T11:39:36.017 回答
5

MVC 和 3 层是完全不同的东西。
我看到很多人混淆了这两者,因为两者都有 3 个部分。

MVC是一种UI 模式
视图:仅包含 html 和 js(在 Web 项目的情况下)
控制器:是 UI(= 视图)和后端(= 模型)之间的一种中介
模型:这个是您的域对象以及业务和数据访问逻辑所在的位置

3 层涉及整个应用程序
UI:包含 html/js 以及页面背后的代码。
这里绝对没有逻辑,除了 UI 代码和调用业务层。
业务层:这是您放置计算、条件、验证等内容的地方。
因此,您的应用程序的实际行为。这里没有数据访问代码。
数据访问:在这里您与数据库对话并将数据返回给业务层。
没有别的,业务层应该知道如何处理它。

因此,如果将两者结合起来,您将获得:
UI:视图和控制器
业务层:模型的一部分
数据访问:模型的一部分
域对象:您需要放置正在使用的对象(产品、 order, ..) 在单独的层中。
这也是模型的一部分。

有问题就拍!

于 2012-03-17T13:59:10.070 回答
0

有关软件架构/设计中“层”和“层”之间的良好比较,请参见此处

MVC 模式完全是关于关注点分离,以及表示层(视图)和业务逻辑应该分离的事实。使用后面的代码很容易使事情变得混乱。您会发现新的 ASP.NET 视图引擎 (Razor) 甚至没有代码隐藏文件。

当您想自动测试控制器中的逻辑时,主要区别将开始变得更加重要,即控制器只是一个普通的旧类,但您的代码隐藏继承自 System.Web.UI.Page,因此是紧密相关的到 ASP.net 的内部。

另外,请阅读 http://ardalis.com/Codebehind-Files-in-ASP.NET-MVC-are-Evilhttps://msmvps.com/blogs/luisabreu/archive/2008/09/19/codebehind-files -in-asp-net-mvc-are-not-evil.aspx

于 2012-03-17T11:20:17.660 回答