Tên bài viết: 3 Tiers
Tác giả: Quang IT
Cấp độ bài viết: Chưa đánh giá
Tóm tắt:
Mô hình 3 lớp mà Microsoft đề nghị dùng cho các hệ thống phát triển trên nền .NET như sau:
Tác giả: Quang IT
Cấp độ bài viết: Chưa đánh giá
Tóm tắt:
Trong phát triển ứng dụng, để dễ quản
lý các thành phần của hệ thống, cũng như không bị ảnh hưởng bởi các
thay đổi, người ta hay nhóm các thành phần có cùng chức năng lại với
nhau và phân chia trách nhiệm cho từng nhóm để công việc không bị
chồng chéo và ảnh hưởng lẫn nhau.
Ví dụ trong một công ty bạn có từng
phòng ban, mỗi phòng ban sẽ chịu trách nhiệm một công việc cụ thể nào
đó, phòng này không được can thiệp vào công việc nội bộ của phòng kia
như Phòng tài chính thì chỉ phát lương, còn chuyện lấy tiền đâu phát
cho các anh phòng Marketing thì các anh không cần biết. Trong phát
triển phần mềm, người ta cũng áp dụng cách phân chia chức năng này.
Bạn sẽ nghe nói đến thuật ngữ kiến trúc đa tầng/nhiều lớp, mỗi lớp sẽ
thực hiện một chức năng nào đó, trong đó mô hình 3 lớp là phổ biến nhất.
3 lớp này là gì? Là psentation, Business Logic, và Data Access. Các
lớp này sẽ giao tiếp với nhau thông qua các dịch vụ(services) mà mỗi
lớp cung cấp để tạo nên ứng dụng, lớp này cũng không cần biết bên trong
lớp kia làm gì mà chỉ cần biết lớp kia cung cấp dịch vụ gì cho mình
và sử dụng nó mà thôi.
Mô hình 3 lớp mà Microsoft đề nghị dùng cho các hệ thống phát triển trên nền .NET như sau:
Lớp này làm nhiệm vụ giao tiếp với người dùng cuối để thu thập dữ
liệu và hiển thị kết quả/dữ liệu thông qua các thành phần trong giao
diện người sử dụng. Lớp này sẽ sử dụng các dịch vụ do lớp Business
Logic cung cấp. Trong .NET thì bạn có thể dùng Windows Forms, ASP.NET hay Mobile Forms để hiện thực lớp này.
Trong lớp này có 2 thành phần chính là User Interface Components và User Interface Process Components.
UI Components là những phần tử chịu trách nhiệm thu
thập và hiển thị thông tin cho người dùng cuối. Trong ASP.NET thì
những thành phần này có thể là các TextBox, các Button, DataGrid...
UI Process Components: là thành phần chịu trách
nhiệm quản lý các qui trình chuyển đổi giữa các UI Components. Ví dụ
chịu trách nhiệm quản lý các màn hình nhập dữ liệu trong một loạt các
thao tác định trước như các bước trong một Wizard...
Lưu ý : lớp này không nên sử dụng trực
tiếp các dịch vụ của lớp Data Access mà nên sử dụng thông qua các dịch
vụ của lớp Business Logic vì khi bạn sử dụng trực tiếp như vậy, bạn
có thể bỏ qua các ràng buộc, các logic nghiệp vụ mà ứng dụng cần phải
có.
Business Logic Layer
Lớp này thực hiện các nghiệp vụ chính của hệ thống, sử dụng các dịch vụ do lớp Data Access cung cấp, và cung cấp các dịch vụ cho lớp presentation.
Lớp này cũng có thể sử dụng các dịch vụ của các nhà cung cấp thứ 3
(3rd parties) để thực hiện công việc của mình(ví dụ như sử dụng dịch vụ
của các cổng thanh tóan trực tuyến như VeriSign, Paypal...).
Trong lớp này có các thành phần chính là Business Components, Business Entities và Service Interface.
Service Interface là giao diện lập trình mà lớp này cung cấp cho lớp psentation sử dụng. Lớp psentation chỉ cần biết các dịch vụ thông qua giao diện này mà không cần phải quan tâm đến bên trong lớp này được hiện thực như thế nào.
Business Entities là những thực thể mô tả những
đối tượng thông tin mà hệ thống xử lý. Các business entities này cũng
được dùng để trao đổi thông tin giữa lớp psentation và lớp Data Access.
Business Components là những thành phần chính thực hiện các dịch vụ mà Service Interface
cung cấp, chịu trách nhiệm kiểm tra các ràng buộc logic(constraints),
các qui tắc nghiệp vụ(business rules), sử dụng các dịch vụ bên ngoài
khác để thực hiện các yêu cầu của ứng dụng.
Data Access Layer
Lớp này thực hiện các nghiệp vụ liên quan đến lưu trữ và truy xuất
dữ liệu của ứng dụng. Thường lớp này sẽ sử dụng các dịch vụ của các hệ
quản trị cơ sở dữ liệu như SQL Server, Oracle,... để thực hiện nhiệm
vụ của mình. Trong lớp này có các thành phần chính là Data Access Logic, Data Sources, Servive Agents.
Data Access Logic components (DALC) là thành phần
chính chịu trách nhiệm lưu trữ vào và truy xuất dữ liệu từ các nguồn
dữ liệu - Data Sources như RDMBS, XML, File systems.... Trong .NET Các
DALC này thường được hiện thực bằng cách sử dụng thư
viện ADO.NET để giao tiếp với các hệ cơ sở dữ liệu hoặc sử dụng các O/R
Mapping Frameworks để thực hiện việc ánh xạ các đối tượng trong bộ
nhớ thành dữ liệu lưu trữ trong CSDL. Chúng ta sẽ tìm hiểu các thư
viện O/R Mapping này trong một bài viết khác.
Service Agents là những thành phần trợ giúp việc
truy xuất các dịch vụ bên ngòai một cách dễ dàng và đơn giản như truy
xuất các dịch vụ nội tại.
0 comments:
Post a Comment