当前位置:文档之家› 实验五三层架构设计

实验五三层架构设计

实验五三层架构设计
实验五三层架构设计

软件工程专业课程实验报告

此时,右边的解决方案资源管理器中多出了一个myweb,里面有许多文件。这里双击里面的web.config文件,向里面添加数据库连接代码。将原来里面的代码

connectionString="data source=.;Integrated

Security=SSPI;AttachDBFilename=|DataDirectory|\aspnetdb.mdf;User

Instance=true"

providerName="System.Data.SqlClient" />

换成

5、创建一个类库(Data)来连接数据库

步骤:文件--新建--项目,在弹出来的“新建项目”对话框中,已安装的模板中选择“Visual C#”--“类库”,名称:Data;解决方案:选择添加到解决方案;位置:E:\test\Solution1,然后点击“确定”。此时右边的解决方案资源管理器中多了一个Data。找到class1.cs文件,右击重命名改为DBConn.cs;然后双击这个文件,左边出现它的所有代码。这里开始做引用了,类型asp中的include file文件,过程比asp多一步。操作过程:右击Data目录下面的引用--添加引用。在弹出的添加引用对话框中,选择.net选择卡,找到System.Configuration,再点击确定。

这样,右边的引用中就多了System.Configuration了。引用这个文件的目的是获取web.config 文件中的值,这里主要用来获取连接数据库字符串。此时我们开始处理DBConn.cs文件了。先

在代码中引用刚才引用的文件,在这个文件顶部using System.Text;下面加上using

System.Configuration;还要加上一个操作sql server的文件using System.Data.SqlClient;然后开始定义一个连接数据库函数,如下:

public SqlConnection getconn()

{

string connstr =

System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionString"].ToString( );

SqlConnection conn = new SqlConnection(connstr);

return conn;

}

这段代码要放到

public class DBConn

{

//要放到这个地方

}

要放到这里的两个大括号之间。

6、Model层,直接对数据库的表中的字段赋值和取出某个字段中的值的层。

创建的方法同Data层只是最后的文件名叫Model而已。具体步骤:

步骤:文件--新建--项目,在弹出来的“新建项目”对话框中,已安装的模板中选择“Visual C#”--“类库”,名称:Model;解决方案:选择添加到解决方案;位置:E:\test\Solution1,然后点击“确定”。此时右边的解决方案资源管理器中多了一个Model。找到class1.cs文件,右击重命名改为User.cs;然后双击这个文件,左边出现它的所有代码。然后再

public class User

{

}

的代码之间添加以下代码:

public User() { }

private string _username;

public string username

{

set { _username = value; }

get { return _username; }

}

private string _password;

public string password

set { _password = password; }

get { return _password; }

}

到此为止,上面还未涉及到VS的三层架构,以上都是为三层架构做准备的,从下面开始正式开始三层架构。

三层架构是逻辑上的三层,只是有数据的调取方法的顺序有关,在开发的过程中没有多大的区别。

7、数据访问层(Dal),该层所做事务直接操作数据库,针对数据的增添、删除、修改、更新、查找等。

创建的步骤如第6条,名称:Dal;解决方案:添加到解决方案;路径为e:\test\Solution1

然后将Dal目录下面的class1.cs改名为UserDB.cs。这里要对Model层进行操作,所以要引用Model层。方法,右击引用--添加引用--选择“项目”选项卡--选择Model--确定;然后在UserDB.css 的顶部加上using Model;由于这层要对数据库进行操作,需要加上

using Data;(数据库连接字符串在这里)

using System.Data;

using System.Data.SqlClient;

然后在

public class UserDB

{

}

之间添加一个显示users表中的所有用户信息的函数,如下:

public string getlist()

{

string str = "";

Data.DBConn dbconn = new DBConn();

SqlConnection myconn = dbconn.getconn();

myconn.Open();

string sql = "select * from users order by id desc";

SqlDataAdapter da = new SqlDataAdapter(sql, myconn);

DataSet ds = new DataSet();

da.Fill(ds);

if (ds.Tables[0].Rows.Count > 0)

{

str = "

\r\n";

string username, password;

foreach (DataRow m in ds.Tables[0].Rows)

username = m["username"].ToString();

password = m["password"].ToString();

str += "

\r\n";

str += "

\r\n";

str += "

\r\n";

str += "

\r\n";

}

str += "

" + username + "" + password + "
\r\n";

}

da.Dispose();

da = null;

myconn.Dispose();

myconn.Close();

return str;

}

8、业务层(Bll),针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。创建的方法同上。名称为Bll;解决方案:添加到解决方案;路径为e:\test\Solution1;然后将Bll目录下面的class1.cs改名为UserBll.cs了。这层要引用Dal层,所以要添加引用Dal,方法同上;然后在UserBll.cs顶部加以下代码using Dal;然后双击UserBll.cs,在左边

public class UserBll

{

}

中间添加以下代码

public string getuserlist()

{

https://www.doczj.com/doc/ca3485019.html,erDB db = new UserDB();

return db.getlist();

}

9、表现层(UI),通俗讲就是展现给用户的界面,即用户在使用一个系统的时候他的所见所得。现在开始给页面添加代码了,让查询出来的内容显示到页面上来。步骤:展开myweb,找到default.aspx文件,双击。在左边的上面加上代码<%=str%>。此时str有个红色的下划线,因为没有定义这个变量。点击default.aspx前面的加号,展开default.aspx,展开后,双击default.aspx.cs。这里需要引用Bll文件,右击里面的引用,添加引用,选择“项目”,找到Bll,然后点击“确定”,最后在顶部加上using Bll;。接下来定义str变量,在protected void Page_Load(object sender, EventArgs e)上面加上public string str;然后在protected void

Page_Load(object sender, EventArgs e)两个大括号之间添加以下代码:

软件三层架构

本文转自 https://www.doczj.com/doc/ca3485019.html,/zzyoucan/article /details/8637376 基于软件三层架构的研究报告 引言 三层结构是传统的客户/服务器结构的发展,代表了企业级应用的未来,典型的有Web下的应用。多层结构和三层结构的含义是一样的,只是细节有所不同。之所以会有双层、三层这些提法,是因为应用程序要解决三个层面的问题。 一、软件架构和分层 (一)软件架构(software architecture) 是一系列相关的抽象模式,用于指导大型软件系统各个方面的设计。软件架构是一个系统的草图。软件架构描述的对象是直接构成系统的抽象组件。各个组件之间的连接则明确和相对细致地描述组件之间的通讯。在实现阶段,这些抽象组件被细化为实际的组件,比如具体某个类或者对象。在面向对象领域中,组件之间的连接通常用接口(计算机科学)来实现。软件体系结构是构建计算机软件实践的基础。与建筑师设定建筑项目的设计原则和目标,作为绘图员画图的基础一样,一个软件架构师或者系统架构师陈述软件构架以作为满足不同客户需求的实际系统设计方案的基础。 (二)分层 分层是表示将功能进行有序的分组:应用程序专用功能位于上层,跨越应用程序领域的功能位于中层,而配置环境专用功能位于低层。分层从逻辑上将子系统划分成许多集合,而层间关系的形成要遵循一定的规则。通过分层,可以限制子系统间的依赖关系,使系统以更松散的方式耦合,从而更易于维护。子系统的分组标准包含以下几条规则可见度。各子系统只能与同一层及其下一层的子系统存在依赖关系。 (三)使用分层架构开发的必要性 1、分层设计允许你分割功能进入不同区域。换句话说层在设计是就是逻辑组件的分组。例如,A层可以访问B层,但B层不能访问A 层。

分层架构与业务逻辑实现方式

分层架构与业务逻辑实现方式

分层架构与业务逻辑实现方式 一、分层架构 在当今软件系统中,常用的软件架构思想就是分层,分层思想是现代软件架构的主要思想。无论是企业级应用系统(如:CRM,ERP,OA,电子商务平台),专用软件(如:OS、SVN、IDE 等),还有协议之类(TCP/IP,OSI等)绝大部分都采用分层架构思想进行设计的。 分层(Layer)不一定就是人们常说的二,三层,多层系统,因为这些说法都是分层架构的一些具体表现形式,分层是一种设计思想,也可以称之为一种软件架构模式(Pattern),这种思想的核心在于:划分系统的职责(Responsibility),如果这个系统的职责你分析清楚了,你的基于设计思路差不多就定下来了。你可以去看看,很多的现在代软件,不是一定是web方面。例如:SVN这样的源代码管理软件、 图一:SVN架构图

.NET Framework也是分层,Eclipse也是,TCP/IP更加是,还有像操作系统(OS)、编译器(Compiler),很多流行框架(Framework)也是分层。其实,MVC不也是分层,也就是把模型(Model)、视图(View)、控制器(Controller)三个不同职责分开。 那我们看看今天的企业级应用系统(很多说是web项目,其他我不认为是这样,因为web只是一种外在表现形式,我们可以用desktop程序,flash等作为表现形式),企业级应用系统很多人一说就是三层架构,其实确实也是这样的。即:表示层,业务层,数据层。当然还有其他的分层,如:表示层,服务层(服务外观层),业务逻辑层,数据映射层,数据层。也有分成:表现层,中间层,数据访问层等等。(注意这些都是逻辑上分层结构一般用Layer,物理上的分层结构,一般讲的是部署结构一般用tier)总体上都可以看成是三层:表现层,业务逻辑层(也可以说是领域层或领域逻辑层),数据层。像Spring,Structs、ORM 等一些框架,他们都是在不同的层上的相关实现技术。 二、业务逻辑几种实现方式 现在我们再看看,企业级系统中最核心是哪一层?肯定是业务层,因为企业级系统主要是与业务打交道(其实几乎所有软件都是实现业务,企业级系统业务逻辑主要偏向于商业逻辑,其他系统,像游戏,自动化控制、支撑系统等把业务看成是算法),而且业务是每个系统都不尽相同的。“业务逻辑是最没有逻辑的东西” [Fowler PoEAA,2003]。而且企业级系统的变化与改变大多都在业务层上。那么,做好企业级系统,首先主要分析好业务系统。你可以看看,现今所有的框架在整体结构(spring,structs,等要求系统按MVC结构来开发),表示层(jquery,extjs等),与数据层(ORM之类)做得最多,有没有业务的框架?(有,但是很少,而且只能是业务比较有规律的地方,像一些财务系统,有些权限系统,当然还有工作流系统)因为业务逻辑每个系统都很可能不一样,没办法通用。那么有什么办法以比较好的方式实现业务逻辑呢。现在终于说到主要问题上来了:也就是业务逻辑(Business Logic)的实现方式,也叫做领域逻辑(Domain Logic)的实现方式。一般来说,有以下几种: 1.事务脚本(Transaction scripts) 2.领域模型(Domain Model)

web三层架构概述

web三层架构概述 web三层架构概述 2009-05-23 10:23 关于 三层架构(3-tier application) 通常意义上的三层架构就是将整个业务应用划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。区分层次的目的即为了“高内聚,低耦合”的思想。 1、表现层(UI):通俗讲就是展现给用户的界面,即用户在使用一个系统的时候他的所见所得。 2、业务逻辑层(BLL):针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。 3、数据访问层(DAL):该层所做事务直接操作数据库,针对数据的增、删、改、查。 概述

三层结构原理: 3个层次中,系统主要功能和业务逻辑都在业务逻辑层进行处理。 所谓三层体系结构,是在客户端与数据库之间加入了一个“中间层”,也叫组件层。这里所说的三层体系,不是指物理上的三层,不是简单地放置三台机器就是三层体系结构,也不仅仅有B/S应用才是三层体系结构,三层是指逻辑上的三层,即使这三个层放置到一台机器上。 三层体系的应用程序将业务规则、数据访问、合法性校验等工作放到了中间层进行处理。通常情况下,客户端不直接与数据库进行交互,而是通过COM/DCOM通讯与中间层建立连接,再经由中间层与数据库进行交互。 表示层位于最外层(最上层),离用户最近。用于显示数据和接收用户输入的数据,为用户提供一种交互式操作的界面。 业务逻辑层业务逻辑层(Business Logic Layer)无疑是系统架构中体现核心价值的部分。它的关注点主要集中在业务规则的制定、

业务流程的实现等与业务需求有关的系统设计,也即是说它是与系统所应对的领域(Domain)逻辑有关,很多时候,也将业务逻辑层称为领域层。例如Martin Fowler在《Patterns of Enterprise Application Architecture》一书中,将整个架构分为三个主要的层:表示层、领域层和数据源层。作为领域驱动设计的先驱Eric Evans,对业务逻辑层作了更细致地划分,细分为应用层与领域层,通过分层进一步将领域逻辑与领域逻辑的解决方案分离。 业务逻辑层在体系架构中的位置很关键,它处于数据访问层与表示层中间,起到了数据交换中承上启下的作用。由于层是一种弱耦合结构,层与层之间的依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对于其调用的底层而言没有任何影响。如果在分层设计时,遵循了面向接口设计的思想,那么这种向下的依赖也应该是一种弱依赖关系。因而在不改变接口定义的前提下,理想的分层式架构,应该是一个支持可抽取、可替换的“抽屉”式架构。正因为如此,业务逻辑层的设计对于一个支持可扩展的架构尤为关键,因为它扮演了两个不同的角色。对于数据访问层而言,它是调用者;对于表示层而言,它却是被调用者。依赖与被依赖的关系都纠结在业务逻辑层上,如何实现依赖关系的解耦,则是除了实现业务逻辑之外留给设计师的任务。

三层架构CS模式程序设计实例

三层架构C/S程序设计实例(C#描述) 1.三层之间的关系: 三层是指:界面显示层(UI),业务逻辑层(Business),数据操作层(Data Access) 文字描述: Clients对UI进行操作,UI调用Business进行相应的运算和处理,Business通过Data Access 对Data Base进行操作。 优点: l 增加了代码的重用。Data Access可在多个项目中公用;Business可在同一项目的不同地方使用(如某个软件B/S和C/S部分可以共用一系列的Business组件)。 l 使得软件的分层更加明晰,便于开发和维护。美工人员可以很方便地设计UI设计,并在其中调用Business给出的接口,而程序开发人员则可以专注的进行代码的编写和功能的实现。 2.Data Access的具体实现: DataAgent类型中变量和方法的说明: private string m_strConnectionString; //连接字符串 private OleDbConnection m_objConnection; //数据库连接 public DataAgent(string strConnection) //构造方法,传入的参数为连接字符串 private void OpenDataBase() //打开数据库连接 private void #region CloseDataBase() //关闭数据库连接 public DataView GetDataView(string strSqlStat) //根据传入的连接字符串返回DataView 具体实现代码如下: public class DataAgent { private string m_strConnectionString; private OleDbConnection m_objConnection; #region DataAgend ///

/// Initial Function /// /// public DataAgent(string strConnection) { this.m_strConnectionString = strConnection; } #endregion #region OpenDataBase /// /// Open Database /// private void OpenDataBase() { try { this.m_objConnection = new OleDbConnection();

架构设计之分层架构

架构设计之分层架构 分层架构的好处:1、它实现了一定程度的关注点分离,利于各层逻辑的重用;2、它规范化了层间的调用关系,可以降低层与层之间的依赖;3、如果层间接口设计合理,则用新的实现来替换原有层次的实现也不是什么难事。 常见模式:展现层、业务层、数据层(三层架构) 一、层的职责 a)展现层,或称为表现层,用于显示数据和接收用户输入的数据,主用户提 供一种交互工操作的界面。 b)业务层,或称为业务逻辑层,用来处理各种功能请求,实现系统的业务功 能,是一个系统最为核心的部分。 c)数据层,或称为数据访问层,主要与数据存储打交道,例如实现对数据库 的增、删、改、查等操作。 二、层间关系 a)展现层会向业务层传递参数,发出服务请求,并获取业务层返回的信息显 示在界面上。 b)业务层接收展现层的命令,解析传递过来的参数,判断各种合法性,并具 体实现功能的各种“运算”要求,返回展现层所要的信息。 c)数据访问层不能被展现层直接调用,而必须由业务层来调用。 例如,《基于动态链接库的复杂信息分层框架设计》一文中用图-1刻画三层架构,体现了层之间的经典调用关系;图-2进一步说明了分层架构下的模块重用。即图中的业务层之“模块2”和数据访问层之“模块2”,都在一定程度上被重用了。

图-1 三层架构示意图-调用关系 图-2三层架构示意图-模块重用 常见模式:UI层、SI层、PD层、DM层(四层架构) 一、UI层,即用户界面层(User Interface),负责封装与用户的双向交互、屏蔽具体交互方式。 二、SI层,即系统交互层(System Interaction),负责封装硬件的具体交互方式,以及封装外部系统的交互。 三、PD层,即问题领域层(Problem Domain),负责问题领域或业务领域的抽象、领域功能的实现。

系统架构设计典型案例

系统架构典型案例 共享平台逻辑架构 如上图所示为本次共享资源平台逻辑架构图,上图整体展现说明包括以下几个方面: 1 应用系统建设 本次项目的一项重点就是实现原有应用系统的全面升级以及新的应用系统的开发,从而建立行业的全面的应用系统架构群。整体应用系统通过SOA面向服务管理架构模式实现应用组件的有效整合,完成应用系统的统一化管理与维护。 2 应用资源采集 整体应用系统资源统一分为两类,具体包括结构化资源和非机构化资源。本次项目就要实现对这两类资源的有效采集和管理。对于非结构化资源,我们将通过相应的资源采集工具完成数据的统一管理与维护。对于结构化资源,我们将通过全面的接口管理体系进行相应资源采集模板的搭建,采集后的数据经过有效的资源审核和分析处理后进入到数据交换平台进行有效管理。 3 数据分析与展现 采集完成的数据将通过有效的资源分析管理机制实现资源的有效管理与展现,具体包括了对资源的查询、分析、统计、汇总、报表、预测、决策等功能模块的搭建。 4 数据的应用 最终数据将通过内外网门户对外进行发布,相关人员包括局内各个部门人员、区各委办局、用人单位以及广大公众将可以通过不同的权限登录不同门户进行相关资源的查询,从而有效提升了我局整体应用服务质量。 综上,我们对本次项目整体逻辑架构进行了有效的构建,下面我们将从技术角度对相关架构进行描述。 一般性技术架构设计案例 如上图对本次项目整体技术架构进行了设计,从上图我们可以看出,本次项目整体建设内容应当包含了相关体系架构的搭建、应用功能完善可开发、应用资源全面共享与管理。下面我们将分别进行说明。整体架构设计案例 上述两节,我们对共享平台整体逻辑架构以及项目搭建整体技术架构进行了分别的设计说明,通过上述设计,我们对整体项目的架构图进行了归纳如下: 综上,我们对整体应用系统架构图进行了设计,下面我们将分别进行说明。 应用层级说明

解读三层架构技术

解读三层架构技术 三层架构将数据层、应用层和业务层分离,业务层通过应用层访问数据库,保护数据安全,利于负载平衡,提高运行效率,方便构建不同网络环境下的分布式应用; 业务层主要作用是接收用户的指令或者数据输入,提交给应用层做处理,同时负责将业务逻辑层的处理结果显示给用户。相比传统的应用方式,业务层对硬件的资源要求较低; 应用层依据应用规模的不同,所承受的负荷会有较大的差异,另外客户端的数目,应用的复杂程度都会对其造成一定的影响。 ERP三层结构提供了非常好的可扩张性,可以将逻辑服务分布到多台服务器来处理,从而提供了良好的伸缩方案; 数据层包括存储数据的数据库服务器和处理数据和缓存数据的组件。组件将大量使用的数据放入系统的缓存库,以提高数据访问和处理的效率. 同时ERP采用大型数据库提供高性能、可靠性高的海量数据存储能力存储ERP 的业务数据。

三层架构(3-tier application) 通常意义上的三层架构就是将整个业务应用划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。区分层次的目的即为了“高内聚,低耦合”的思想。 概念简介 1、表现层(UI):通俗讲就是展现给用户的界面,即用户在使用一 个系统的时候他的所见所得。 2、业务逻辑层(BLL):针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。 3、数据访问层(DAL):该层所做事务直接操作数据库,针对数据的增添、删除、修改、更新、查找等。 概述 在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。微软推荐的分层式结构一般分为三层,从下至上分别为:数据访问层、业务逻辑层(又或成为领域层)、表示层。 三层结构原理: 3个层次中,系统主要功能和业务逻辑都在业务逻辑层进行处理。 所谓三层体系结构,是在客户端与数据库之间加入了一个“中间层”,也叫组件层。这里所说的三层体系,不是指物理上的三层,不是简单地放 置三台机器就是三层体系结构,也不仅仅有B/S应用才是三层体系结构, 三层是指逻辑上的三层,即使这三个层放置到一台机器上。 三层体系的应用程序将业务规则、数据访问、合法性校验等工作放到 了中间层进行处理。通常情况下,客户端不直接与数据库进行交互,而是 通过COM/DCOM通讯与中间层建立连接,再经由中间层与数据库进行交互。

软件架构设计之通用架构模式

电子知识 软件架构(4) 1.分层架构:分层架构是使用最多的架构模式,通过分层使各个层的职责更加明确,通过定义的接口使各层之间通讯,上层使用下层提供的服务。分层分为:严格意义上的分层,一般意义的分层。严格意义的分层是n+1层使用n层的服务。而一般意义的分层是上层能够使用它下边所有层的服务。领域驱动设计的分层定义:UI层,UI控制层,服务层,领域层,基础设施层。 2.MVC架构:MVC架构相信做软件的都听说,主要是为了让软件的各部分松耦合,现在好多根据MVC思想构建的框架如:Spring MVC,Structs2,https://www.doczj.com/doc/ca3485019.html, MVC等。MVC是Model View Control的简写,他的原理是什么那,比如拿web来举例吧。当一个web请求来了以后View接收这个请求,随即把请求转发给Control进行处理,Control通过分析请求的类型等信息决定加载哪些Model,当Model加载完成以后Control通知Model已经加载完毕,这是View就去读取Model数据进行显示自己。MVC还有一个衍生架构叫MVP,因为MVC的View跟Control和Model都有耦合关系所以为了解除View和Model之间的关系,View不直接读取Model而是通过Control来转发View 需要的数据。还有一个衍生架构叫MVVP,就是增加了一个ViewControl的层,用来辅助视图的生成,这样View的功能更加简单只是用来显示不包含其它的功能,而且有了ViewControl 使多视图或替换视图很方便。MVP微软的WPF就是使用这种架构。 3.微内核架构:微内核架构就是做一个稳定通用的内核,也就是给软件设计一个强劲的心脏。如果需要更多功能通

软件系统的架构设计方案

软件系统的架构设计方 案 集团标准化工作小组 #Q8QGGQT-GX8G08Q8-GNQGJ8-MHHGN#

软件系统的架构设计方案 架构的定义 定义架构的最短形式是:“架构是一种结构”,这是一种正确的理解,但世界还没太平。若做一个比喻,架构就像一个操作系统,不同的角度有不同的理解,不同的关切者有各自的着重点,多视点的不同理解都是架构需要的,也只有通过多视点来考察才能演化出一个有效的架构。 从静态的角度,架构要回答一个系统在技术上如何组织;从变化的角度,架构要回答如何支持系统不断产生的新功能、新变化以及适时的重构;从服务质量的角度,架构要平衡各种和用户体验有关的指标;从运维的角度,架构要回答如何充分利用计算机或网络资源及其扩展策略;从经济的角度,架构要回答如何在可行的基础上降低实现成本等等 软件系统架构(SoftwareArchitecture)是关于软件系统的结构、行为、属性、组成要素及其之间交互关系的高级抽象。任何软件开发项目,都会经历需求获取、系统分析、系统设计、编码研发、系统运维等常规阶段,软件系统架构设计就位于系统分析和系统设计之间。做好软件系统架构,可以为软件系统提供稳定可靠的体系结构支撑平台,还可以支持最大粒度的软件复用,降低开发运维成本。如何做好软件系统的架构设计呢 软件系统架构设计方法步骤 基于体系架构的软件设计模型把软件过程划分为体系架构需求、设计、文档化、复审、实现和演化6个子过程,现逐一简要概述如下。

体系架构需求:即将用户对软件系统功能、性能、界面、设计约束等方面的期望(即“需求”)进行获取、分析、加工,并将每一个需求项目抽象定义为构件(类的集合)。 体系架构设计:即采用迭代的方法首先选择一个合适的软件体系架构风格(如C/S、B/S、N层、管道过滤器风格、C2风格等)作为架构模型,然后将需求阶段标识的构件映射到模型中,分析构件间的相互作用关系,最后形成量身订做的软件体系架构。 体系架构文档化:即生成用户和研发人员能够阅读的体系架构规格说明书和体系架构设计说明书。 体系架构复审:即及早发现体系架构设计中存在的缺陷和错误,及时予以标记和排除。 体系架构实现:即设计人员开发出系统构件,按照体系架构设计规格说明书进行构件的关联、合成、组装和测试。 体系架构演化:如果用户需求发生了变化,则需相应地修改完善优化、调整软件体系结构,以适应新的变化了的软件需求。 以上6个子过程是软件系统架构设计的通用方法步骤。但由于软件需求、现实情况的变化是难以预测的,这6个子过程往往是螺旋式向前推进。 软件系统架构设计常用模式

C_三层架构_简单实例分析

基于3层架构的课程管理系统 本模块工作任务 任务3-1:三层架构划分 任务3-2:数据访问层的实现 任务3-3:业务逻辑层的实现 任务3-4:表示层的实现 本模块学习目标 1、掌握三层架构的划分原理 2、掌握各层的设计思路,和层之间的调用关系 3、利用三层架构实现对课程管理模块的重构 4、巩固OOP 的基本概念和 OOP 的编程思路 ---------------------------------------------------------------------------------------------------------------------------------http://211.147.15.119/mmdy.html 任务3-1:三层架构划分 效果与描述 图3.1 包含多个项目的3层架构解决方案 本任务要求学生能够将原来的只有1个项目的课程管理模块,重构为标准的具有5个项目的3层架构的模块,并进行恰当的初始化,仍能实现课程记录的添加、浏览功能。在此过程中理解3层架构的划分原理,各层的任务,层之间的调用关系。 本任务的业务流程: 将原项目改为UI 层 新建BLL/ DAL/COMMON/MODL 项 目并初始化 初始化后仍能实现课程记录的浏览和添 加 业务逻辑层 数据访问层 界面层

图3.2 单层转化为3层架构的业务流程 相关知识与技能 3-1-1 三层架构的划分原理 三层架构的划分如下图: 图3.3 三层架构原理图 1、各层的任务 数据访问层:使用https://www.doczj.com/doc/ca3485019.html,中的数据操作类,为数据库中的每个表,设计1个数据访问类。类中实现:记录的插入、删除、单条记录的查询、记录集的查询、单条记录的有无判断等基本的数据操作方法。对于一般的管理信息软件,此层的设计是类似的,包含的方法也基本相同。此层的任务是:封装每个数据表的基本记录操作,为实现业务逻辑提供数据库访问基础。 业务逻辑层:为用户的每个功能模块,设计1个业务逻辑类,此时,需要利用相关的数据访问层类中,记录操作方法的特定集合,来实现每个逻辑功能。 界面层:根据用户的具体需求,为每个功能模块,部署输入控件、操作控件和输出控件,并调用业务逻辑层中类的方法实现功能。 2、层之间的调用关系 数据访问层的类,直接访问数据库,实现基本记录操作。 业务逻辑层的类,调用相关的数据访问类,实现用户所需功能。 界面层:部署控件后,调用业务逻辑层的类,实现功能。 将应用程序的功能分层后,对于固定的DBMS,数据访问层基本可以不变,一旦用户的需求改变,首先修改业务逻辑层,界面层稍做改动即可。这种做法使程序的可复用性、可修改性,都得到了很好的改善,大大提高了软件工程的效率。 3-1-2 ORM(对象关系映射) 在图3.1中看到,除了界面层、业务逻辑层和数据访问层之外,还有2个项目。其中,Common项目中一般放的是公用文件,如数据操作类DBHelper等,被数据访问层的类调用,其必要性在上个模块已述。Modal项目中存放的是实体类。 所谓的对象关系映射Object Relational Mapping,简称ORM,是为了解决面向对象的类,与关系数据库的表之间,存在的不匹配的现象,通过使用描述对象和关系之间映射的元数据,在程序中的类对象,与关系数据库的表之间建立持久的关系,用于在程序中描述数据库表。本质上就是将数据从一种形式转换到另外一种形式。 ORM是一个广义的概念,适应于关系数据库与应用程序之间的各类数据转换,目前有许多自动转换工具可用,如codesmith 等。在本教材中,利用手工书写代码的形式,实现ORM。

软件架构文档(样例)

4In1 System 软件架构文档 版本<1.1>

修订文档历史记录

目录 1. 简介 (4) 1.1 目的 (4) 1.2 范围 (4) 1.3 定义、首字母缩写词和缩略语 (4) 1.4 参考资料 (4) 2. 架构表示方式 (4) 3. 架构目标和约束 (4) 4. 用例视图 (4) 4.1 主要用例 (5) 4.1.1 申请注册 (5) 4.1.2 用户注册审核 (5) 4.1.3 用户角色管理 (5) 4.1.4 角色权限管理 (6) 4.1.5 车型信息管理 (6) 4.1.6 配件信息管理 (6) 5. 逻辑视图 (6) 5.1 概述 (6) 5.2 Application层 (7) 5.3 Business Service层 (7) 5.3.1 Service包 (7) 5.3.2 Model包 (8) 5.4 Middleware层 (8) 6. 部署视图 (8) 6.1 User Client (9) 6.2 Server (9) 6.3 DB Server (9) 7. 数据视图 (9) 8. 大小和性能 (10) 9. 质量 (10)

软件架构文档 1.简介 1.1目的 本文档将从架构方面对系统进行综合概述,其中会使用多种不同的架构视图来描述系统的各个方面。它用于记录并表述已对系统的架构方面作出的重要决策。 1.2范围 本文档用于4In1小组正在开发中的4In1系统。4n1系统是为ABC汽车4S店设计的业务管理系统,将提供汽车的整车销售、配件销售、售后服务以及信息反馈等功能。 1.3定义、首字母缩写词和缩略语 见4In1系统术语表 1.4参考资料 1. 4In1系统术语表,1.0版,4In1小组 2. 4In1系统前景文档,1.1版,4In1小组 3. 4In1系统软件需求规约,1.0版,4In1小组 4. 4In1系统软件开发计划,1.1版,4In1小组 5. 4In1系统初始迭代计划,1.1版,4In1小组 6. 4In1系统细化迭代计划,1.0版,4In1小组 7. 4In1系统风险列表,1.0版,4In1小组 8. RUP的软件架构文档模板 2.架构表示方式 本文档将通过以下一系列视图来表示4In1系统的软件架构:用例视图、逻辑视图、部署视图。本文档不包括进程视图和实施视图。这些视图都是通过PowerDesigner工具建立的UML模型。 3.架构目标和约束 1.系统在开发过程中有如下设计约束:开发语言为Java,采用关系型数据库存放数据, 采用基于UML的面向对象分析与设计方法进行开发,采用B/S架构。 2.系统应支持100人以上同时访问服务器并支持500人以上同时访问数据库,服务器 的响应时间不应该超过5秒。 3.所有用户在保证网络连接的情况下可同时通过局域网和互联网访问系统。 4.系统必须保证数据的安全访问,用户需要通过用户名和密码进行身份认证,同时对 数据的访问要进行授权认证。 4.用例视图

基于分层结构的管理信息系统架构设计探究

基于分层结构的管理信息系统架构设计探 究 引言 管理信息系统(Management Information System ,MIS)是一个由人、计算机及其他外围设备等组成的、能进行信息的收集、传递、存贮、加工、维护和使用的系统。管理信息系统属于是一门新兴的科学, 其主要任务是最大限度地利用现代计算机及网络通讯技术加强企业的信息管理, 通过对企业拥有的人力、物力、财力、设备、技术等资源的调查了解, 建立正确的数据, 加工处理并编制成各种信息资料及时提供给管理人员, 以便进行正确的决策, 不断提高企业的管理水平和经济效益。完善的管理信息系统(MIS)由信源、信宿、信息处理、信息用户和信息管理者五个部分组成。其中信息处理是整个系统的核心, 该部分的主要作用是分离和选择信息、对于信息进行分类与识别、确保信息的准确性与有效性。衡量M IS 的优劣, 主要通过以下标准:需求信息的确定性与有效性、信息的可采集性与可加工性、能否通过程序为管理人员提供有用信息、能否对信息进行有效管理的同时进行分析与判断这四个方面来进行判断。同时, 必须考虑到随着信源、信宿、信息用户和信息管理者的变化, 评价MIS 的标准的具体内容也随之发生变化, 使得信息处理的方法与要求也随之改变,如何在发展中使得现有系统能够最大限度地适应变化, 保持信息处理的准确性与有效性, 一直是MIS 面临的挑战之一。

1 技术发展带来的新挑战 由于MIS 的基础在于最大限度地利用现代计算机及网络通讯技术, 因此MIS 必然是随着现代计算机及网络通讯技术的发展而不断发展的。现有的管理信息系统在为使用单位带来很多的优越性的同时, 也面临了更多新的挑战。概括起来, 目前, 采用的各种管理信息系统, 大都面临以下新的需求: (1)随着M IS 的深入, 各种信息数据共享的需求逐步提高, 同时,M IS 也面临着不断提高的安全要求。 (2)管理对信息数据统一查询、提取、管理的需求,种类日益增加, 数量日益庞大, 要求的速度越来越高。 (3)对经过管理信息系统中的信息数据缺乏集成,难以为管理信息系统内外用户提供全面、详细、快速、准确的信息。 (4)目前管理信息系统主要支持的功能还局限于事后追踪, 还不能够支持如:辅助决策与机器学习等功能。为了能够更好地发挥管理信息系统的功效, 就必须结合技术发展的成果对于信息系统来进行重新思考。 2 现代软件体系结构建模 为了能够充分利用现有的MIS , 同时易于进行功能的扩充, 需要利用技术发展的新成果来进行MIS 架构的重新分析与设计。软件架构理论是近年来研究的热点, 它代表的是面向系统的高层结构指导思想, 是对软件系统结构的总体设计与分析, 对于设计大型复杂的应用系统更具有重要的指导意义。采用软件体系结构的思想来设计架构,

三层架构

三层架构 三层系统的分层式结构 三层架构(3-tier architecture) 通常意义上的三层架构就是将整个业务应用划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。区分层次的目的即为了“高内聚,低耦合”的思想。 概念简介 1、表现层(UI):通俗讲就是展现给用户的界面,即用户在使用一个系统的时候他的所见所得。 2、业务逻辑层(BLL):针对具体问题的操作,也可以说是对数据层的操作,对数据业务逻辑处理。 3、数据访问层(DAL):该层所做事务直接操作数据库,针对数据的增添、删除、修改、查找等。 在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构。微软推荐的分层式结构一般分为三层,从下至上分别为:数据访问层、业务逻辑层(又或称为领域层)、表示层。 三层结构原理: 3个层次中,系统主要功能和业务逻辑都在业务逻辑层进行处理。 所谓三层体系结构,是在客户端与数据库之间加入了一个“中间层”,也叫组件层。这里所说的三层体系,不是指物理上的三层,不是简单地放置三台机器就是三层体系结构,也不仅仅有B/S应用才是三层体系结构,三层是指逻辑上的三层,即使这三个层放置到一台机器上。

三层体系的应用程序将业务规则、数据访问、合法性校验等工作放到了中间层进行处理。通常情况下,客户端不直接与数据库进行交互,而是通过COM/DCOM通讯与中间层建立连接,再经由中间层与数据库进行交互。 各层的作用 1:数据访问层:主要是对原始数据(数据库或者文本文件等存放数据的形式)的操作层,而不是指原始数据,也就是说,是对数据的操作,而不是数据库,具体为业务逻辑层或表示层提供数据服务. 2:业务逻辑层:主要是针对具体的问题的操作,也可以理解成对数据层的操作,对数据业务逻辑处理,如果说数据层是积木,那逻辑层就是对这些积木的搭建。 3:表示层:主要表示WEB方式,也可以表示成WINFORM方式,WEB方式也可以表现成:aspx,如果逻辑层相当强大和完善,无论表现层如何定义和更改,逻辑层都能完善地提供服务。具体的区分方法 1:数据访问层:主要看你的数据层里面有没有包含逻辑处理,实际上他的各个函数主要完成各个对数据文件的操作。而不必管其他操作。 2:业务逻辑层:主要负责对数据层的操作。也就是说把一些数据层的操作进行组合。 3:表示层:主要对用户的请求接受,以及数据的返回,为客户端提供应用程序的访问。 表示层 位于最外层(最上层),离用户最近。用于显示数据和接收用户输入的数据,为用户提供一种交互式操作的界面。 业务逻辑层 业务逻辑层(Business Logic Layer)无疑是系统架构中体现核心价值的部分。它的关注点主要集中在业务规则的制定、业务流程的实现等与业务需求有关的系统设计,也即是说它是与系统所应对的领域(Domain)逻辑有关,很多时候,也将业务逻辑层称为领域层。例如Martin Fowler在《Patterns of Enterprise Application Architecture》一书中,将整个架构分为三个主要的层:表示层、领域层和数据源层。作为领域驱动设计的先驱Eric Evans,对业务逻辑层作了更细致地划分,细分为应用层与领域层,通过分层进一步将领域逻辑与领域逻辑的解决方案分离。 业务逻辑层在体系架构中的位置很关键,它处于数据访问层与表示层中间,起到了数据交换中承上启下的作用。由于层是一种弱耦合结构,层与层之间的依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对于其调用的底层而言没有任何影响。如果在分层设计时,遵循了面向接口设计的思想,那么这种向下的依赖也应该是一种弱依赖关系。因而在不改变接口定义的前提下,理想的分层式架构,应该是一个支持可抽取、可替换的“抽屉”式架构。正因为如此,业务逻辑层的设计对于一个支持可扩展的架构尤为关键,因为它扮演了两个不同的角色。对于数据访问层而言,它是调用者;对于表示层而言,它却是被调用者。依赖与被依赖的关系都纠结在业务逻辑层上,如何实现依赖关系的解耦,则是除了实现业务逻辑之外留给设计师的任务。 数据层 数据访问层:有时候也称为是持久层,其功能主要是负责数据库的访问,可以访问数据库系统、二进制文件、文本文档或是XML文档。 简单的说法就是实现对数据表的Select,Insert,Update,Delete的操作。如果要加入ORM 的元素,那么就会包括对象和数据表之间的mapping,以及对象实体的持久化。 优点 1、开发人员可以只关注整个结构中的其中某一层;

基于三层架构的人口数据管理平台设计

基于三层架构的人口数据管理平台设计 本文主要研究三层架构技术下的人口数据管理平台,从人口数据平台的研究意义与价值出发,在三层架构技术的基础上,总体设计了人口数据管理平台,且就数据平台划分为数据层、中间层、业务应用层,分别就三个层次进行系统的分析与设计,在中间层,利用了数据的存储过程访问方式,提高了数据平台的数据读取效率,重点设计与实现了人口数据的添加、数据查询功能。论文对人口数据平台的研究,最提高我国人口管理的信息化发展,具有一定的研究价值。 标签:三层架构人口管理数据管理数据库 我国是人口大国,庞大的人口数据的管理工作成为了难点和重点。对于人口数据的管理,也随着信息技术的发展,逐渐地朝着网络化、数字化趋势演变,实施人口数据的管理平台将直接影响到人口管理工作的效率和准确度。在人口数据管理工作流程中,利用网络技术、信息技术,以实现人口数据管理的信息化是研究的关键。本文则是在此背景下,研究了三层架构下的人口数据管理平台的分析与设计,以此提高人口数据管理的信息化水平。 1 人口数据管理平台价值 人口数据平台针对政府部门的人口数据统计和管理人员而开发的,实施计算机模式下的人口数据统计和管理方式,成为了目前各个国家对人口管理的一种趋势。在我国,由于人口统计方式和普查制度的改革,人为手工和纸质的方式进行人口数据统计,不仅仅浪费工作人员的时间,也浪费人口管理部门的人力和物力资源;另外,手工的人口数据统计,也不可避免的存在一定的差错。利用计算机数据管理系统,对人口数据进行统计和管理,将有效地提高人口管理工作的效率,尤其在我国这样一个人口数量庞大的国家,只需要将人口数据进行计算机方式的采集,管理人员就能进行数据分析与管理,极大减少人口管理工作量。 建立人口综合管理平台是大势所趋,同时由政府人口信息管理与服务平台的协同,可以直接和间接产生经济和社会效益。经济发展以及社会进步,引起了政府和公众的需求,信息资源在广度和深度都在发生着深刻的变化,信息的质量、范围、准确性、及时性都有非常大的提高。实现网络化的数据采集管理和共享,实现即时灵活的数据统计分析能力,实现全系统各部门网上协同办公,以提高工作水平,为相关部门提供信息服务。 本文所研究的人口数据管理平台,将基于三层架构的技术进行开发,三层架构将整个数据管理平台划分为数据层、中间层和业务访问层,其先进的数据读取方式,将有效地提高系统的数据访问速率,有效地提高人口数据管理工作效率。本文将利用https://www.doczj.com/doc/ca3485019.html,技术,在三层架构体系下设计与研究人口数据管理系统,技术的先进性和优越性将提高系统平台的优越性,从而对人口数据的管理工作具有重要的研究价值。 2 人口数据管理平台总体设计 根据三层架构的技术体系,如图1所示,设计了人口数据管理平台的总体架构,整个系统由数据层即系统的数据库、数据中间访问层、人口数据管理的主要业务功能应用层组成,通过三层体系之间的联系,实现人口数据的管理与分析。 人口数据管理的主要业务分为、人口数据采集、人口数据信息办公、人口数据管理维护、人口数据交换,再加上系统自身的登录模块、系统维护管理模块,将这几个模块设计在人口数据管理平台的应用层上,通过数据存储过程和C#编

分层架构模式.NET架构和模式

分层架构模式:.NET架构和模式 疯狂代码 https://www.doczj.com/doc/ca3485019.html,/ ?:http:/https://www.doczj.com/doc/ca3485019.html,/Programing/Article60049.html 什么是架构 软件Software体系结构通常被称为架构指可以预制和可重构软件Software框架结构架构尚处在发展期对于其定义学术界尚未形成个统意见而区别角度视点也会造成软件Software体系结构区别理解以下是些主流标准观点 ANSI/IEEE 610.12-1990软件Software工程标准词汇对于体系结构定义是:“体系架构是以构件、构件的间关系、构件和环境的间关系为内容某系统基本组织结构以及知道上述内容设计和演化原理(principle)” Mary Shaw和David Garlan认为软件Software体系结构是软件Software设计过程中超越计算中算法设计和数据结构设计个层次体系结构问题包括各个方面组织和全局控制结构通信协议、同步数据存储给设计元素分配特定功能设计元素组织规模和性能在各设计方案的间进行选择Garlan & Shaw模型基本思想是:软件Software体系结构={构件(component),连接件(connector)约束(constrain)}.其中构件可以是组代码如模块;也可以是个独立如数据库服务器连接件可以是过程、管道、远程过程(RPC)等用于表示构件的间相互作用约束般为对象连接时规则或指明构件连接形式和条件例如上层构件可要求下层构件服务反的不行;两对象不得递规地发送消息;代码复制迁移致性约束;什么条件下此种连接无效等 有关架构定义还有很多其他观点比如Bass定义、Booch & Rumbaugh &Jacobson定义、Perry & Wolf模型[7]、Boehm模型等等虽然各种定义关键架构角度区别研究对象也略有侧重但其核心内容都是软件 Software系统结构其中以Garlan & Shaw模型为代表强调了体系结构基本要素是构件、连接件及其约束(或者连接语义)这些定义大部分是从构造角度来甚至软件Software体系结构而IEEE定义不仅强调了系统基本组成同时强调了体系结构环境即和外界交互 什么是模式 模式(Pattern)概念最早由建筑大师Christopher Alexander于 2十世纪 7十年代提出应用于建筑领域 8十年代中期由Ward Cunningham和Kent Beck将其思想引入到软件Software领域Christopher Alexander将模式分为 3个部分:首先是周境(Context也可以称着上下文),指模式在何种状况下发生作用;其 2是动机( of Forces),意指问题或预期目标;其 3是解决方案(Solution),指平衡各动机或解决所阐述问题个构造或配置(Configuration)他提出模式是表示周境、动机、解决方案 3个方面关系个规则每个模式描述了个在某种周境下不断重复发生问题以及该问题解决方案核心所在模式即是个事物(thing)又是个过程(process)不仅描述该事物本身而且提出了通过怎样过程来产生该事物这定义已被软件Software界广为接受 软件Software模式应用对软件Software开发产生了重大作用主要表现在: 软件Software模式是人们在长期设计软件Software、管理组织软件Software开发等实战中大量经验提炼和抽象是复用软件Software设计思路方法、过程管理经验有力工具模式类似于拳击中组合拳它提供了系列软件Software开发中思维套路如通过模式使用有利于在复杂系统中产生简洁、精巧设计

系统(erp)架构设计方案

房产物业管理信息系统架构设计方案 2015 年7月 版本控制

一、前言 二、架构设计 2.1架构分析 2.2架构定义 2.3架构说明 2.4软件逻辑结构 三、具体功能简述 3.1自定义工作流解决方案 3.2多语言解决方案 3.3消息发布/订阅系统方案 3.4报表&打印方案 四、系统平台&支撑组件 五、系统网络结构 六、开发管理层面

一、前言 一个企业级的商业软件能够满足用户需要、正常运行、易于维护、易于扩展,必须拥有一个良好的软件架构支撑。本文主要是分析和构建一个企业级商业软件架构。 二、架构设计 2.1架构分析 企业级的商业软件架构在技术层面的要求主要体系在高性能、健壮性和低成本。 ●高性能 对于企业级商业软件来说,软件架构需要尽可能地使软件具有最高的性能,支持最大的并发性。 ●健壮性 企业级的商业软件要求软件是可靠的和无缺陷的。现在的架构一般是,服务器模式的。软件的可靠和健壮主要依赖与服务器。服务器的稳定通过良好的代码和完备的测试能够解决这个问题。 ●低成本 企业级商业软件还有一个很重要的要求:低成本。软件架构要求简单、易掌握,复杂度低,易于维护和扩展,易于测试。 2.2架构定义 本架构以XML为整个系统的交互接口,包括系统架构内部和外部。整个系统分为界面展示层,流程控制层和数据存储层。 2.3架构说明 系统架构 图 Erp架构中各核心服务之间满足松散耦合特性,具有定义良好的接口,可通过拆分与组合,

可以有针对性地构建满足不同应用场景需求的Erp应用系统。 2.3.1 适配器 在集成环境中需要复用已有的应用系统和数据资源,通过适配器可以将已有应用系统和数据资源接入到ERP应用系统中。 通过适配器可以实现已有资源与ERP系统中其它服务实现双向通讯和互相调用。首先通过适配器可以实现对已有资源的服务化封装,将已有资源封装为一个服务提供者,可以为ERP应用系统中的服务消费者提供业务和数据服务,其次通过适配器,也可以使已有资源可以消费ERP应用系统中的其它服务。 2.3.2 资源仓库 资源仓库主要功能是提供服务描述信息的存储、分类和查询功能。对于广义的资源仓库而言,除了提供服务类型的资源管理外,还需要提供对其它各种资源的管理能力,可管理对象包括:人员和权限信息、流程定义和描述、资源封装服务、服务实现代码、服务部署和打包内容、以及环境定义和描述信息。 资源仓库首先需要提供服务描述能力,需要能够描述服务的各种属性特征,包括:服务的接口描述、服务的业务特性、服务的质量特征(如:安全、可靠和事务等)以及服务运行的QoS属性。 2.3.3 连通服务 连通服务是ERP基础技术平台中的一个重要核心服务,典型的连通服务就是企业服务总线(Enterprise Service Bus,ESB),它是服务之间互相通信和交互的骨干。连通服务的主要功能是通信代理,如服务消费的双向交互、代理之间的通信、代理之间的通信质量保障以及服务运行管理功能等。 连通服务还需要保证传输效率和传输质量。连通服务一般应用于连接一个自治域内部的各个服务,在自治域内部服务都是相对可控的,所以连通服务更多应该考虑效率问题。 2.3.4 流程服务 流程服务是为业务流程的运行提供支撑的一组标准服务。业务流程是一组服务的集合,可以按照特定的顺序并使用一组特定的规则进行调用。业务流程可以由不同粒度的服务组成,其本身可视为服务。 流程服务是业务流程的运行环境,提供流程驱动,服务调用,事务管理等功能。流程服务需要支持机器自动处理的流程,也需要支持人工干预的任务操作,它支持的业务流程主要适用于对运行处理时间要求不高的,多方合作操作的业务过程。 2.3.5 交互服务

相关主题
文本预览
相关文档 最新文档