简介:三层架构(3-tier application) 通常意义上的三层架构就是将整个业务应用划分为:表现层(WebUI)、业务逻辑层(BusinessLogicLayer)、数据访问层(DataAccessLayer),公共层(ModelLayer)。区分层次的目的即为了“高内聚,低耦合”的思想。

一、应用三层架构的优点

三层结构适合群体开发,每人可以有不同的分工,协同工作使效率倍增;各做各的模块,降低开发人员能力要求;方便系统功能的扩展以及后期的维护工作;最大优点是它的安全性。用户端只能通过逻辑层来访问数据层,减少了入口点,把很多危险的系统功能都屏蔽了。可以更好的支持分布式计算环境。逻辑层的应用程序可以有多个机器上运行,充分利用网络的计算功能。分布式计算的潜力巨大,远比升级CPU有效。

二、手动搭建三层架构

   软件 VS 2008

(当然可以用动软.Net代码生成器等自动生成三层架构)

1.建立空白的解决方案

   法1) 文件/新建/项目弹出对话框 选择“其他项目类型”下面的“Visual Studio 解决方案”  单击“空白解决方案” 名称:ling  位置:D/ 确定 完成空白方案搭建

法2) Shift+Ctrl+N 弹出对话框 选择“其他项目类型”下面的“Visual Studio 解决方案”

2.建立三个类库

1) 在解决方案资源管理器中,右击“解决方案ling”选择“ 添加”下面的“新建项目”

2) 在弹出对话框中选择“Visual C#”里面的“类库”

名称:ModelLayer(简写Model)  公共层 位置:D:/ling “确定” 完成一个类库的添加

用相同的方法建立以下两个类库:

名称:DataAccessLayer(简写DAL) 数据访问层    位置:D:/ling

名称:BusinessLogicLayer(简写BLL) 业务逻辑层 位置:D:/ling

3.建立表现层

在解决方案资源管理器中,右击“解决方案ling”选择“ 添加”下面的“新建网站”

在弹出对话框中选择“Asp.NET 网站” 位置:文件系统, D/ling/WebUI

语言:Visual C#(这里值得注意网站的路径为:D/ling/WebUI)

“确定” 完成表现层的搭建

这样我们就完成了基本结构的搭建

4.添加各层之间的引用

4.1 数据访问层(DataAccessLayer)对公共层(ModelLayer)引用

1) 在解决方案资源管理器中,右击“DataAccessLayer”选择“ 添加应用”

2) 弹出“添加引用”对话框,单击“项目” 选择“ModelLayer”

单击“确定” 完成对公共层的引用

4.2 业务逻辑层(BusinessLogicLayer)对DataAccessLayer和ModelLayer引用

1) 在解决方案资源管理器中,右击“BusinessLogicLayer”选择“ 添加应用”

2) 弹出“添加引用”对话框,单击“项目” 选择“DataAccessLayer、ModelLayer”

单击“确定” 完成对DataAccessLayer和ModelLayer引用

4.3 表现层(WebUI)对BusinessLogicLayer、DataAccessLayer、ModelLayer引用

1) 在解决方案资源管理器中,右击“D/ling/WebUI/”选择“ 添加应用”

2) 弹出“添加引用”对话框,单击“项目”选择“DataAccessLayer、ModelLayer、BusinessLogicLayer”

单击“确定” 完成对DataAccessLayer、ModelLayer、BusinessLogicLayer引用

这样我们的项目是不能运行的,不信自己试试。

5.设置起始项目以及起始页

1) 在解决方案资源管理器中,右击“D/ling/WebUI/”单击“ 设为启动项目(A)”

2) 在解决方案资源管理器中,单击“D/ling/WebUI/”里面的“Default.aspx”(默认的,可改名)右击“ 设为启始页(P)”

3) 在解决方案资源管理器中,右击“解决方案ling”单击“重新生成解决方案(R)”

OK了,这样就完成了一个三层B/S的框架了。至于具体实现的细节这里就不讨论了,改天空了再说。

原文链接:.NET完全手动搭建三层B/S架构

.NET完全手动搭建三层B/S架构的更多相关文章

  1. 关于ASP.NET或VS2005 搭建三层架构的理解

    最近想学习ASP.NET建网站,关于ASP.NET或VS2005 搭建三层架构的理解,网上摘录了一些资料,对于第(2)点的讲解让我理解印象深刻,如下: (1)为何使用N层架构? 因为每一层都可以在仅仅 ...

  2. CS通用项目系统搭建——三层架构第一天

    CS通用项目:使用三层架构进行搭建 三层架构: 表现层(UI(User Interface)):展示给用户的层面,包含窗体控件数据等信息. 业务逻辑层(BLL(Business Logic Layer ...

  3. 【从零开始搭建自己的.NET Core Api框架】(二)搭建项目的整体架构

    系列目录 一.  创建项目并集成swagger 1.1 创建 1.2 完善 二. 搭建项目整体架构 三. 集成轻量级ORM框架——SqlSugar 3.1 搭建环境 3.2 实战篇:利用SqlSuga ...

  4. OceanBase数据库实践入门——手动搭建OceanBase集群

    前言 目前有关OceanBase功能.案例.故事的文章已经很多,对OceanBase感兴趣的朋友都想安装一个数据库试试.本文就是分享初学者如何手动搭建一个OceanBase集群.这也是学习理解Ocea ...

  5. SSM框架手动搭建

    SSM框架手动搭建 创建web项目 IDEA创建Maven项目 [File]-->[new]-->[project..] 将项目变为web项目 [File]-->[Project S ...

  6. WindowsServer2012 R2 64位中文标准版(IIS8.5)下手动搭建PHP环境详细图文教程(二)安装IIS8.5

    //来源:http://www.imaoye.com/Technology/WindowsServer2012R264IIS85.html 阿里云服务器ECS Windows Server 2012 ...

  7. Linux手动搭建LAMP环境

    当你看到标题里的“手动搭建”,你是不是会想,难不成还有“自动搭建”?当然......不是,这里的“手动搭建”是指按部就班的搭建Apache.MySQL.PHP环境,是相对于集成软件包而言的.所以你是不 ...

  8. php 手动搭建环境

    php手动搭建环境有好多种组合,版本号不一致,会导致搭建失败. 我搭建的组合是: php5.6+MySQL5.6+Apache2.4的组合. 一.PHP语言包下载 首先从官网上下载php5.6 htt ...

  9. 混合式app ionic2.x 手动搭建开发环境教程分享(nodejs,jdk,ant,androidsdk)

    1.ionic简介 为什么选用ionic: 彻底开源且免费 性能优异 基于红的发紫的AngularJs 漂亮的UI 强大的命令行(基于更热门的nodejs) 开发团队非常活跃 ngCordova,将主 ...

随机推荐

  1. ORB-SLAM2实现(kinect V1/ROS)

    实验室电脑环境ubuntu14.04和ROS indigo已经装好. 1. 构建工作空间[非常重要的一步] mkdir -p ~/catkin_ws/src cd ~/catkin_ws/ catki ...

  2. 微信小程序button选中改样式-实现单选/多选

    小程序实现多button单选/多选 红色为选中状态 单选 多选 ①wxss /* pages/button-select/button-select.wxss */ .button_container ...

  3. HTTP2 概述

    HTTP/2,也就是超文本传输协议第2版,不论是1还是2,HTTP的基本语义是不变的,比如方法语义(GET/PUST/PUT/DELETE),状态码(200/404/500等),Range Reque ...

  4. golang 的md5加密

    先看实现代码: package main import (     "crypto/md5"     "encoding/hex"     "fmt& ...

  5. centos 安装cloud foundry CLI

    步骤: 1.wget -O /etc/yum.repos.d/cloudfoundry-cli.repo https://packages.cloudfoundry.org/fedora/cloudf ...

  6. LeetCode ImplementStrstr

    class Solution { public: char *strStr(char *haystack, char *needle) { if (haystack == NULL || needle ...

  7. 在js里面比较大小必须先转换成number

    利用js里面的Number函数从对象转换成数值

  8. ES6学习笔记(四)-数值扩展

    PS: 前段时间转入有道云笔记,体验非常友好,所以笔记一般记录于云笔记中,每隔一段时间,会整理一下, 发在博客上与大家一起分享,交流和学习. 以下:

  9. JQuery UI完成自动匹配的的下拉列表步骤

    1.先引入jquery ui相关的js,如:jquery-ui-1.10.4.js 2.写js <script type="text/javascript"> $(fu ...

  10. Web前端和后端开发的区别和要求

    Web前端和后端开发的区别和要求 有时候自己会分不清,其实是因为前后端都了解,类似于全栈工程师,但又什么都不是很精通.那到底什么是前端.后端呢,我整理了一些企业要求级别的前端/后端基础,开发框架等. ...