Đăng ký Đăng nhập
Trang chủ Sử dụng công nghệ windows communication foundation trong các ứng dụng trên diện ...

Tài liệu Sử dụng công nghệ windows communication foundation trong các ứng dụng trên diện rộng

.PDF
79
154
117

Mô tả:

ĐẠI HỌC QUỐC GIA HÀ NỘI TRƯỜNG ĐẠI HỌC CÔNG NGHỆ NGUYỄN QUANG HÙNG SỬ DỤNG CÔNG NGHỆ WINDOWS COMMUNICATION FOUNDATION TRONG CÁC ỨNG DỤNG TRÊN DIỆN RỘNG KHOÁ LUẬN TỐT NGHIỆP ĐẠI HỌC HỆ CHÍNH QUY Ngành: Công nghệ thông tin HÀ NỘI - 2009 ĐẠI HỌC QUỐC GIA HÀ NỘI TRƯỜNG ĐẠI HỌC CÔNG NGHỆ NGUYỄN QUANG HÙNG SỬ DỤNG CÔNG NGHỆ WINDOWS COMMUNICATION FOUNDATION TRONG CÁC ỨNG DỤNG TRÊN DIỆN RỘNG KHOÁ LUẬN TỐT NGHIỆP ĐẠI HỌC HỆ CHÍNH QUY Ngành: Công nghệ thông tin Cán bộ hướng dẫn: ThS. Đào Kiến Quốc Cán bộ đồng hướng dẫn: ThS.Nguyễn Xuân Hoàng HÀ NỘI - 2009 2 TÓM TẮT KHÓA LUẬN Hiện nay đã có rất nhiều phần mềm dành cho doanh nghiệp. Tuy nhiên một số các phần mềm này lại có giá quá cao khiến doanh nghiệp không đủ kinh phí để triển khai. Còn đối các sản phẩm giá thấp hơn thì lại không thể đáp ứng được nhu cầu sử dụng dữ liệu tập trung và tổng hợp dữ liệu một cách thường xuyên của các doanh nghiệp có nhiều chi nhánh tại nhiều vị trí địa lý khác nhau. Nội dung của khóa luận này sẽ trình bày về một công nghệ mới nằm trong .NET 3.0 của Microsoft, đó là công nghệ Windows Communication Foundation (WCF). Đây là một công nghệ được Microsoft đưa ra để xây dựng các ứng dụng theo kiến trúc hướng đối tượng (SOA). Đó là chìa khóa để giải quyết các vấn đề trên. Đồng thời, khóa luận cũng nói đến việc áp dụng WCF để xây dựng phần mềm Quản lý quan hệ khách hàng (CRM) – một giải pháp đang được áp dụng ở khá nhiều doanh nghiệp. 3 MỤC LỤC LỜI MỞ ĐẦU ........................................................................................................................ 8 1. Tính cấp thiết của đề tài:.................................................................................................... 8 2. Mục tiêu của đề tài: ......................................................................................................... 10 CHƯƠNG 1: CÔNG NGHỆ WINDOWS COMMUNICATION FOUNDATION................. 13 1.1. Tổng quan về Windows Communication Foundation.................................................... 13 1.1.1. Windows Communication Foundation là gì?.......................................................... 13 1.1.2. Tại sao sử dụng WCF?.......................................................................................... 14 1.2. Kiến trúc của Windows Communication Foundation .................................................... 16 1.2.1. Hợp đồng (Contracts) ............................................................................................ 17 1.2.2. Dịch vụ thực thi (Runtime service) ........................................................................ 18 1.2.3. Bản tin (Message) .................................................................................................. 19 1.2.4. Chứa và kích hoạt (Host and activation)................................................................. 19 1.3. Các tính năng của WCF................................................................................................ 19 1.3.1. Giao dịch (Transaction) ......................................................................................... 19 1.3.2. Chứa (Host) ........................................................................................................... 20 1.3.3. Bảo mật (Security)................................................................................................. 20 1.4. Mô hình lập trình với WCF........................................................................................... 20 1.4.1. Các phương pháp lập trình ..................................................................................... 21 1.4.2. Nguyên lý ABCs.................................................................................................... 26 1.4.3. Địa chỉ (Address)................................................................................................... 26 1.4.4. Liên kết (Binding) ................................................................................................. 29 1.4.5. Hợp đồng (Contract).............................................................................................. 33 CHƯƠNG 2: GIỚI THIỆU GIẢI PHÁP CRM CHO DOANH NGHIỆP............................... 45 2.1. CRM là gì?................................................................................................................... 45 2.2. Lịch sử học thuyết CRM............................................................................................... 47 2.3. Các khái niệm liên quan trọng trong CRM.................................................................... 49 2.3.1. Tiềm năng.............................................................................................................. 49 2.3.2. Tổ chức ................................................................................................................. 49 2.3.3. Liên hệ .................................................................................................................. 49 2.3.4. Cơ hội.................................................................................................................... 49 2.3.5. Chiến dịch ............................................................................................................. 49 2.3.6. Hợp đồng............................................................................................................... 49 2.3.7. Tình huống ............................................................................................................ 49 2.3.8. Sản phẩm............................................................................................................... 50 2.3.9. Đối tác................................................................................................................... 50 2.3.10. Đối thủ................................................................................................................. 50 2.4. Lợi ích của CRM .......................................................................................................... 50 CHƯƠNG 3: SỬ DỤNG CÔNG NGHỆ WCF ĐỂ XÂY DỰNG HỆ THỐNG CRM WCF 2010 ............................................................................................................................................. 52 3.1. Vấn đề đặt ra ................................................................................................................ 52 3.2. Tổng quan về CRM WCF 2010 .................................................................................... 54 3.3. Quy trình tác nghiệp của CRM WCF 2010 .................................................................... 56 3.3.1. Quy trình tiếp thị ................................................................................................... 56 3.3.2. Quy trình Bán hàng................................................................................................ 57 3.3.3. Quy trình dịch vụ sau bán hàng.............................................................................. 58 4 3.4. Các use case chính của hệ thống CRM WCF 2010........................................................ 59 3.4.1. Quản lý tổ chức ..................................................................................................... 59 3.4.2. Quản lý cơ hội ....................................................................................................... 60 3.4.3. Quản lý hợp đồng .................................................................................................. 61 3.4.4. Quản lý tiềm năng.................................................................................................. 62 3.4.5. Quản lý chiến dịch ................................................................................................. 64 3.4.6. Quản lý báo cáo ..................................................................................................... 65 3.5. Biểu đồ tuần tự của hệ thống ........................................................................................ 66 3.5.1. Thêm, sửa tổ chức ..................................................................................................... 66 3.5.2. Xóa tổ chức ............................................................................................................... 66 3.5.3. Thêm, sửa tiềm năng ................................................................................................... 67 3.5.4. Xóa tiềm năng ........................................................................................................... 67 3.5.5. Thêm, sửa cơ hội ....................................................................................................... 68 3.5.6. Xóa cơ hội................................................................................................................. 68 3.5.7. Thêm, sửa hợp đồng .................................................................................................. 69 3.5.8. Xóa hợp đồng ............................................................................................................ 69 3.5.9. Thêm, sửa liên hệ ...................................................................................................... 70 3.5.10. Xóa liên hệ .............................................................................................................. 70 3.5.11. Thêm, sửa chiến dịch ............................................................................................... 71 3.5.12. Xóa chiến dịch......................................................................................................... 71 3.5. Kiến trúc và công cụ phát triển CRM WCF 2010.......................................................... 72 3.5.1. Kiến trúc của CRM WCF 2010 .............................................................................. 72 3.5.2. Môi trường phát triển CRM WCF 2010 ................................................................. 73 3.6. Giao diện minh họa các phân hệ chính của CRM WCF 2010 ........................................ 73 3.6.1. Phân hệ Tổ chức ..................................................................................................... 73 3.6.2. Phân hệ liên hệ ...................................................................................................... 75 3.6.3. Phân hệ cơ hội ....................................................................................................... 76 KẾT LUẬN .......................................................................................................................... 78 TÀI LIỆU THAM KHẢO..................................................................................................... 78 5 BẢNG CÁC KÝ HIỆU VIẾT TẮT Ký hiệu Từ viết tắt Ý nghía SOA Service-oriented architecture Kiến trúc hướng dịch vụ WCF Windows Communication Foundation Công nghệ mới của Microsoft trong .NET 3.0 CRM Customer relationship Quản lý quan hệ khách hàng management BẢNG DANH SÁCH CÁC HÌNH VẼ Hình vẽ Trang Hình 1 1: Kiến trúc của mô hình CORBA 7 Hình 1 2: Kiến trúc của mô hình EJB 7 Hình 1 3: Kiến trúc của mô hình DCOM 8 Hình 1 4: Kiến trúc cơ bản của SOA 9 Hình 1 5: Kiến trúc .NET 3.0 11 Hình 1 6: Khả năng hợp nhất của WCF 13 Hình 1 7: Kiến trúc của WCF (microsoft.com) 15 Hình 1 8: Mô hình lập trình WCF 24 Hình 1 9: Sơ đồ lựa chọn Binding 31 Hình 1 10: “Khách hàng là trung tâm của mọi hoạt động” 45 Hình 1 11: Quy trình chung của hệ thống CRM 51 Hình 1 12: Quy trình tiếp thị 54 Hình 1 13: Quy trình bán hàng 55 Hình 1 14: Quy trình dịch vụ sau bán hàng 56 Hình 1 15: Sơ đồ use case quản lý tổ chức 57 6 Hình 1 16: Sơ đồ use case quản lý cơ hội 58 Hình 1 17: Sơ đồ use case quản lý hợp đồng 59 Hình 1 18: Sơ đồ use case quản lý tiềm năng 60 Hình 1 19: Sơ đồ use case quản lý chiến dịch 62 Hình 1 20: Sơ đồ use case quản lý báo cáo 63 Hình 1 21: Biểu đồ tuần tự thêm ,sửa tổ chức 64 Hình 1 22: Biểu đồ tuần tự xóa tổ chức 64 Hình 1 23: Biểu đồ tuần tự thêm, sửa tiềm năng Hình 1 24: Biểu đồ tuần tự xóa tiềm năng 65 65 Hình 1 25: Biểu đồ tuần tự thêm, sửa cơ hội 66 Hình 1 26: Biểu đồ tuần tự xóa cơ hội 66 Hình 1 27: Biểu đồ tuần tự thêm, sửa hợp đồng 67 Hình 1 28: Biểu đồ tuần tự xóa hợp đồng 67 Hình 1 29: Biểu đồ tuần tự thêm, sửa liên hệ 68 Hình 1 30: Biểu đồ tuần tự xóa liên hệ 68 Hình 1 31: Biểu đồ tuần tự thêm, sửa chiến dịch Hình 1 32: Biểu đồ tuần tự xóa chiến dịch 69 69 Hình 1 33: Kiến trúc CRM WCF 2010 70 Hình 1 34: Giao diện phân hệ Tổ chức 71 Hình 1 35: Giao diện phân hệ Liên hệ 73 Hình 1 36: Giao diện phân hệ Cơ hội 74 7 LỜI MỞ ĐẦU 1. Tính cấp thiết của đề tài: Hiện tại đã có rất nhiều phần mềm dành cho các doanh nghiệp ra đời nhằm nâng cao hiệu quả kinh doanh. Tuy nhiên do tính phức tạp và không đồng nhất của các nền tảng công nghệ hiện nay nên việc các doanh nghiệp tái sử dụng các hệ thống cũ và vấn đề giao tiếp giữa các hệ thống khác nhau chưa thể đáp ứng được. Đồng thời với các doanh nghiệp muốn triển khai các hệ thống ứng dụng của mình trên diện rộng với nhiều chi nhánh thì vẫn gặp nhiều khó khăn do các phần mềm chưa đáp ứng được vấn đề bảo mật khi trao đổi thông tin qua môi trường Internet cũng như khó khăn trong việc triển khai và quản lý hệ thống. Điều này dẫn đến doanh nghiệp nói chung và nhà quản lý doanh nghiệp nói riêng gặp rất nhiều khó khăn và không thể tập trung thời gian cho việc quản lý và hoạch định chiến lược kinh doanh cho doanh nghiệp. Ví dụ, với các doanh nghiệp đa chi nhánh thì hiện tại việc thống kê, hạch toán sẽ phải thực hiện riêng rẽ trên từng chi nhánh rồi mới được người quản lý tổng hợp lại, điều này gây lãng phí thời gian và công sức, đồng thời có thể gây thiếu đồng bộ về thông tin giữa các chi nhánh. Các kiến trúc phân tán đã ra đời để giải quyết vấn đề này như CORBA, EJB, DCOM. Tuy nhiên chúng vẫn còn khá hạn chế và chưa đáp ứng được nhu cầu của khách hàng.  CORBA - Common Object Requesting Broker Architecture - CORBA được định nghĩa bởi Object Management Group (OMG) là một kiến trúc phân tán mở, độc lập nền tảng và độc lập ngôn ngữ. Với CORBA các thành phần của hệ thống có thể được viết trên nhiều ngôn ngữ và chạy trên các nền tảng khác nhau vẫn có thể làm việc được với nhau. - Ưu nhược điểm của CORBA là các lập trình viên có thể chọn bất kỳ ngôn ngữ, nền tảng phần cứng, giao tiếp mạng và các công nghệ để phát triển mà vẫn thỏa mãn các tính chất của CORBA. Tuy nhiên, CORBA có một số nhược điểm là: nó là ngôn ngữ lập trình bậc thấp, rất phức tạp, khó học, và cần một đội ngũ phát triển có kinh nghiệm. Ngoài ra các đối tượng CORBA cũng khó tái sử dụng. 8 Hình 1 36: Kiến trúc của mô hình CORBA  EJB - Enterprise JavaBeans - Kiến trúc EJB là một kiến trúc thành tố bên phía máy chủ dùng cho việc phát triển và triển khai các ứng dụng phân tán hướng đối tượng cỡ vừa và lớn - EJB là một kiến trúc tốt cho việc tích hợp các hệ thống vì nó là độc lập nền tảng nhưng nó cũng gặp vấn đề là: nó không phải một chuẩn mở, khả năng giao tiếp với các chuẩn khác vẫn còn hạn chế. Hình 1 37: Kiến trúc của mô hình EJB 9  DCOM - Distributed Component Object Model - DCOM là một mô hình phân tán dễ triển khai với chi phí thấp. Mô hình Component Object Model (COM) định nghĩa cách thức các thành phần và Client liên lạc trao đổi với nhau trong cùng một máy. DCOM mở rộng COM bằng cách sử dụng các giao thức mạng chuẩn khi cần trao đổi dữ liệu với máy khác trên mạng. DCOM hỗ trợ kết nối giữa các đối tượng và các kết nối này có thể thay đổi khi ứng dụng đang chạy. - DCOM mang đến nhiều ưu điểm như tính ổn định, không phụ thuộc vị trí địa lý, quản lý kết nối hiệu quả và dễ dàng mở rộng, là một lựa chọn tốt cho các doanh nghiệp sử dụng công nghệ trên Windows để chạy các ứng dụng có yêu cầu cao về sự chính xác và ổn định. Tuy nhiên các công nghệ của Microsoft có một nhược điểm lớn là chúng bị giới hạn trên nền tảng Windows, đặc biệt các hệ thống DCOM khó tái sử dụng và bị chặn bởi Firewall khi giao tiếp qua Internet. Hình 1 38: Kiến trúc của mô hình DCOM 2. Mục tiêu của đề tài: Trước các khó khăn trên thì các doanh nghiệp cần có một cách tiếp cận mới để giải quyết vấn môi trường không đồng nhất và tốc độ thay đổi đến chóng mặt của thực tế trong khi phải xoay sở với nguồn ngân sách hạn hẹp và nền kinh tế khó khăn. May thay, đã có một hướng tiếp cận giải quyết khá toàn diện các vấn đề trên và đã được triển khai trong thực tế. Đó là “Kiến trúc hướng dịch vụ” – Service Oriented Architecture (SOA). Kiến trúc hướng dịch vụ là một hướng tiếp cận với việc thiết kế và tích hợp các phần mềm, chức năng, hệ thống theo dạng các module. Trong đó mỗi module đóng vai trò là một “dịch vụ”, và có khả năng được truy cập qua môi trường mạng. Hiểu một 10 cách đơn giản thì một hệ thống SOA là một tập các dịch vụ được chuẩn hóa trên môi trường mạng và trao đổi với nhau trong ngữ cảnh một tiến trình nghiệp vụ.. Hình 1 39: Kiến trúc cơ bản của SOA SOA tách riêng phần thực hiện dịch vụ (phần mềm) với giao tiếp gọi dịch vụ. Điều này tạo nên một giao tiếp nhất quán cho ứng dụng khách (client) sử dụng dịch vụ bất chấp công nghệ thực hiện dịch vụ. Thay vì xây dựng các ứng dụng đơn lẻ và đồ sộ, nhà phát triển sẽ xây dựng các dịch vụ tinh gọn có thể triển khai và tái sử dụng trong toàn bộ quy trình nghiệp vụ. Điều này cho phép tái sử dụng phần mềm tốt hơn, cũng như tăng sự linh hoạt vì nhà phát triển có thể cải tiến dịch vụ mà không làm ảnh hưởng đến ứng dụng client sử dụng dịch vụ.  Ưu điểm của kiến trúc hướng dịch vụ - Tái sử dụng phần mềm: Nếu gói mã mà tạo thành một dịch vụ có quy mô và kích thước phù hợp sau đó nó có thể được tái sử dụng cho lần kế tiếp, một đội phát triển cần chức năng cụ thể đó cho một ứng dụng phần mềm mới mà nó mong muốn xây dựng. Họ không cần biết bất cứ thứ gì về việc mã được gói chặt như thế nào hay nó có nguồn gốc từ đâu. Tất cả những thứ mà họ cần làm đó là xây dựng một sự kết nối đến mã đó. 11 - Tính linh hoạt và dễ dàng triển khai: Phía triệu gọi dịch vụ không cần quan tâm đến công nghệ nền tảng của phía Service. Nó mang đến khả năng linh hoạt cao và nhiều lợi ích khác. Trong một hệ thống SOA ta gọi dịch vụ thông qua các interface theo một dạng thức chuẩn nên khi cần kết nối với các đối tác thương mại thì những interface chuẩn càng đem lại nhiều lợi ích hơn. Với một hệ thống SOA thật dễ dàng khi cung cáp một loạt những dịch vụ ra bên ngoài cho một đối tác nào đó sử dụng. Tương tự cho điều ngược lại, nếu các đối tác đã xây dựng một hệ thống SOA thì việc đem sử dụng chức năng một số dịch vụ của họ vào sử dụng bên trong hệ thống của mình cũng thật dễ dàng và nhanh chóng. - Khả năng thích ứng cao với những thay đổi trong tương lai: Các phương pháp tiếp cận truyền thống trong quy trình phát triển phần mềm có thể mô tả ngắn gọn là người dùng mô tả họ cần gì và công ty phát triển phần mềm sẽ triển khai theo yêu cầu. Quy trình này đôi khi gặp khó khăn khi gặp những tình huống thay đổi không định trước. Với SOA, công ty phát triển phần mềm có thể tạo nên những quy trình nghiệp vụ uyển chuyển , phức tạp có khả năng biến đổi tuy theo yêu cầu của khách hàng. WCF là một công nghệ được Microsoft đưa ra trong bản .NET 3.0. WCF là nền tảng giúp xây dựng các ứng dụng theo kiến trúc hướng dịch vụ. WCF không phải là công nghệ để hỗ trợ việc xử lý các nghiệp vụ cho ứng dụng mà nó giúp xây dựng các dịch vụ mà việc xử lý nghiệp vụ được thực hiện bởi các ngôn ngữ lập trình quen thuộc trong .NET như C# hay VB.NET. WCF sẽ giúp các tầng của ứng dụng có thể gọi nhau qua môi trường Internet hay LAN. Điều này giải quyết được vấn đề mở rộng phạm vi hoạt động đa chi nhánh của doanh nghiệp và giúp doanh nghiệp cũng như nhà phát triển phần mềm có thể tái sử dụng các hệ thống đang có. Luận văn này sẽ giới thiệu về công nghệ WCF cùng việc sử dụng nó để xây dựng hệ thống CRM, là một hệ thống quan trọng trong việc nâng cao hiệu quả kinh doanh trong doanh nghiệp. 12 CHƯƠNG 1: CÔNG NGHỆ WINDOWS COMMUNICATION FOUNDATION 1.1. Tổng quan về Windows Communication Foundation 1.1.1. Windows Communication Foundation là gì? Windows Communication Foundation (WCF) là một công nghệ được Microsoft giới thiệu tại Hội nghị các nhà phát triển sản phẩm Microsoft (Microsoft Product Developers Conference 2003) ở Los Angeles, California năm 2003. WCF được biết đến với cái tên quen thuộc hơn là Indigo trong công cụ phát triển Visual Studio 2005. WCF là một bộ các thư viện lớp được xậy dựng trên nền tảng .NET Framework 2.0 CLR và tích hợp trong .NET Framework 3.0 cùng với WF, WPF và Windows Cardspace. Hình 1 40: Kiến trúc .NET 3.0 WCF là công nghệ nền tảng nhằm thống nhất nhiều mô hình lập trình giao tiếp được hỗ trợ trong .NET 2.0 thành một mô hình duy nhất. Vào tháng 11 năm 2005, .NET 2.0 được Microsoft phát hành trong đó có cung cấp các hàm API riêng biệt cho các liên lạc dựa trên SOAP để tối đa hoá sự làm việc giữa các nền tảng sử dụng Web Services, đồng thời .NET 2.0 còn cung cấp các API để tối ưu việc liên lạc dựa trên mã nhị phân giữa các ứng dụng chạy trên hệ thống Windows gọi là .NET Remoting, các API cho các giao dịch phân tán, và API cho liên lạc dị bộ. WCF thống nhất các API này thành một mô hình duy nhất nhằm đáp ứng mô hình lập trình hướng dịch vụ. WCF có thể sử dụng các bản tin SOAP giữa hai tiến trình, do đó làm cho các ứng dụng dựa trên WCF có thể làm việc với các tiến trình khác thông qua việc giao tiếp sử dụng bản tin SOAP. Khi một tiến trình WCF liên lạc với một tiến trình không là WCF, các bản tin SOAP được mã hoá trên cơ sở XML, nhưng khi nó liên lạc với 13 một tiến trình WCF khác, bản tin SOAP có thể được tối ưu hoá dựa trên mã hoá nhị phân. WCF không chỉ là một phương pháp khác để xây dựng hệ thống phân tán mà còn đem đến nhiều tính năng mới hơn so với các công nghệ trước đó. 1.1.2. Tại sao sử dụng WCF? Như phần trên đã trình bày, .NET 2.0 hỗ trợ rất nhiều phương pháp liên lạc giữa các ứng dụng khác nhau nhằm vào các mục tiêu khác nhau. Các phương pháp liên lạc này khá phức tạp và phải mất nhiều thời gian để làm chủ được công nghệ. Tuy nhiên kiến thức thu được từ việc triển khai một phương pháp ít có khả năng dùng được khi làm việc với phương pháp khác. Với việc ra đời của WCF, mọi phương pháp liên lạc trước kia đều có thể thực hiện trên WCF. Do vậy nhà phát triển chỉ cần làm chủ được công nghệ WCF là có thể xây dựng các ứng dụng một cách nhanh chóng. WCF là một mô hình lập trình cho phép nhà phát triển xây dựng các giải pháp dịch vụ đảm bảo tính ổn định, và bảo mật và thậm chí là đảm bảo giao dịch. Nó làm đơn giản hoá việc phát triển các ứng dụng kết nối và đưa ra cho nhà phát triển những giá trị mà có thể họ chưa nhận ra ngay, đó là cách tiếp cận phát triển hệ thống phân tán thống nhất, đơn giản, và quản lý được. Do WCF được xây dựng trên cơ sở của .NET Framework 2.0 CLR, nó là tập các lớp cho phép các nhà phát triển xây dựng các ứng dụng hướng dịch vụ bằng môi trường lập trình quen thuộc của họ như VB.NET hay C#. Microsoft đưa ra WCF với kỳ vọng WCF sẽ giải quyết được ba mục tiêu: - Hợp nhất công nghệ đã tồn tại - Tương tác đa nền - Phát triển hướng dịch vụ 14 Hình 1 41: Khả năng hợp nhất của WCF  Mục tiêu 1: Hợp nhất công nghệ Bài toán xử lý với các ứng dụng phân tán luôn là một bài toán khó với các nhà phát triển. Sự cạnh tranh của các công nghệ phân tán đầu những năm 1990 đã dẫn đến sự tranh cãi: Sẽ chọn công nghệ nào là công nghệ tốt nhất, phù hợp nhất để phát triển hệ thống phân tán trong thời gian dài. Nếu như một hệ thống được phát triển dựa trên môi trường HTTP thì chắc chắn phải thay đổi mô hình lập trình nếu muốn triển khai trên môi trường TCP. Hoặc như ta có một hệ thống xây dựng theo mô hình Web Services, hệ thống này không thể hỗ trợ các giao dịch hướng Message nếu như không thay đổi mô hình lập trình. Vậy tại sao lại không có một công nghệ tập hợp tất cả những ưu điểm của các công nghệ trước đó. Microsoft đưa ra giải pháp WCF giúp giải quyết điều đó. WCF tránh được việc thay đổi mô hình giao tiếp khi làm việc với nhiều công nghệ phân tán, cho phép sử dụng một API đơn giản và trong sáng. WCF tổng hợp được những gì tốt nhất của các công nghệ phân tán hiện có. WCF mang đến sự hiệu quả của ASMX, xử lý giao dịch của Enterprise Service, linh hoạt của .NET Remoting, ưu điểm trong hướng message của MSMQ, bảo mật của WSE. Microsoft đã mang tất cả những điều đó để xây dựng một nền cơ sở công nghệ độc lập và vững chắc. 15  Mục tiêu 2: Tương tác đa nền Hầu hết các công ty phần mềm lớn đều sử dụng những giao thức riêng gắn liền với một nền tảng nhất định nào đó. Mặt khác một doanh nghiệp lớn thường có các hệ thống riêng rẽ, mua ở những thời điểm khác nhau, của những công ty khác nhau. Và tất nhiên chúng sẽ không tương thích tốt với nhau. Việc liên kết các hệ thống lại thành một thể thống nhất và làm việc hiệu quả là một yêu cầu cần thiết. WCF sẽ làm điều đó thay vì chúng ta. Thế giới công nghệ sẽ không nói chuyện với nhau bằng các ngôn ngữ khác nhau nữa, các hệ thống có thể tồn tại một cách hòa bình với nhau.  Mục tiêu 3: Phát triển hướng dịch vụ Công nghệ và nghiệp vụ thay đổi rất nhanh, doanh nghiệp phải đầu tư một lượng lớn kinh phí cho việc phát triển ứng dụng. Trong nhiều năm, các lập trình viên và các tổ chức cố gắng xây dựng phần mềm trên mô hình hướng đối tượng (OOP) để phù hợp với thực tế. Nhưng thiết kế hệ thống cần phải linh hoạt và chuẩn mực để việc phát triển nghiệp vụ sau này không gặp khó khăn. Chính vì vậy các dịch vụ nghiệp vụ ra đời. WCF là một công cụ phát triển hướng dịch vụ. WCF đảm bảo các dịch vụ được xây dựng một cách tự động theo nguyên tắc SOA. Điều đó đảm bảo giảm giá thành bảo trì, cho phép thay đổi và tương tác đa nền. 1.2. Kiến trúc của Windows Communication Foundation Windows Communication Foundation là một Framework trong .NET 3.0. Nó gồm rất nhiều các thư viện, không gian tên (namespace) cho việc lập trình ứng dụng WCF. Dưới đây là hình ảnh mô tả kiến trúc WCF và các tầng chính của nó. 16 Hình 1 42: Kiến trúc của WCF (microsoft.com) 1.2.1. Hợp đồng (Contracts) Khái niệm contract trong WCF cũng giống như các hợp đồng mà ta ký trong đời sống thật. Một hợp đồng ta ký có thể chứa các thông tin như kiểu công việc ta sẽ làm, và những thông tin mà ta muốn đưa ra cho các bên khác. WCF contract cũng chứa các thông tin tương tự như vậy. Contract định nghĩa các đặc tả trong hệ thống bản tin.Thông thường có các loại contract sau:  Data Contract: Mô tả các tham số cho các bản tin mà một dịch vụ có thể tạo ra hay sử dụng. Các tham số bản tin được định nghĩa bằng các tài liệu sử dụng ngôn ngữ đặc tả XML Schema (XSD), điều này cho phép các hệ thống hiểu XML có thể xử lý tài liệu dễ dàng. Các dịch vụ khi liên lạc với nhau có thể không cần đồng ý với nhau về các kiểu, nhưng cần đồng ý về contract dữ liệu, nghĩa là đồng ý về các tham số và các kiểu trả về.  Message Contract: Định nghĩa các phần có trong bản tin sử dụng các giao thức SOAP, và nó cho phép điều khiển sâu hơn tới các phần trong bản tin khi có yêu cầu sự chính xác như vậy. 17  Services Contract: Đặc tả chi tiết các phương thức của dịch vụ, và được phân phối như là một giao diện trong các ngôn ngữ lập trình như Visual Basic hay Visual C#. Có thể hình dung về contract dịch vụ một cách gián tiếp như sau: “Đây là các kiểu dữ liệu của các bản tin của tôi, đây là nơi tôi cung cấp, và đây là các giao thức mà tôi có thể liên lạc”. Policy and Bindings: Mô tả các điều kiện cần có để giao tiếp với một dịch vụ. Các chính sách sẽ bao gồm cả các yêu cầu về bảo mật và các điều kiện khác cần phải có khi kết nối với một dịch vụ. 1.2.2. Dịch vụ thực thi (Runtime service) Lớp dịch vụ thực thi chứa các hành xử sẽ xảy ra trong quá trình thực hiện của dịch vụ, nghĩa là các hành xử thực thi của dịch vụ. Ta sẽ thấy một số các hành xử như sau:  Throttling behavior: Điều khiển luồng nhằm quy định xem có bao nhiêu bản tin được xử lý.  Error behavior: Hành xử lỗi quy định những hành động khi lỗi xảy ra trong hệ thống.  Metadata behavior: Hành xử với các siêu dữ liệu quy định xem làm thế nào và khi nào thì các siêu dữ liệu được đưa ra bên ngoài dịch vụ.  Instance behavior: Hành xử thực thể quy định xem có bao nhiêu thực thể của dịch vụ đó được chạy.  Transaction behavior: Hành xử giao dịch cho phép việc rollback các giao dịch nếu xảy ra lỗi.  Message inspection: Kiểm tra bản tin đem lại cho dịch vụ khả năng kiểm tra tất cả hay một số phần của bản tin.  Dispatch behavior: Khi một bản tin được xử lý bởi nền tảng WCF, dịch vụ Dispatch behavior xác định xem bản tin được xử lý như thế nào.  Concurrency behavior: Hành xử đồng thời xác định xem việc xử lý thế nào với việc đa luồng của mỗi dịch vụ hay mỗi thực thể của dịch vụ. Hành xử này giúp cho việc điều khiển số lượng luồng có thể truy nhập tới một thực thể của dịch vụ. 18  Parameter filtering: Khi một bản tin được đưa tới một dịch vụ, sẽ xảy ra một số hành động dựa trên nội dung phần đầu đề của bản tin. Phần lọc tham số sẽ thực hiện lọc các đầu đề bản tin và thực hiện các hành động đặt sẵn dựa trên việc lọc đầu đề bản tin. 1.2.3. Bản tin (Message) Lớp bản tin là tập hợp các kênh. Mỗi kênh là một thành phần xử lý bản tin theo một cách nào đó. Một tập các kênh thường được gọi là ngăn xếp kênh. Các kênh làm việc trên bản tin và trên đầu đề của bản tin. Lớp này khác với lớp thực thi dịch vụ chủ yếu bởi sự khác nhau trong việc xử lý nội dung bản tin. Có hai kênh khác nhau là kênh vận chuyển (transport channel) và kênh điều khiển (control channel).  Kênh vận chuyển phụ trách việc đọc và ghi các bản tin từ mạng (network) hoặc từ một số điểm giao dịch bên ngoài.  Kênh điều khiển thực hiện xử lý bản tin theo giao thức, thông thường làm việc bằng cách đọc và ghi thêm các đầu đề cho bản tin. 1.2.4. Chứa và kích hoạt (Host and activation) Nhìn một cách tổng thể thì một dịch vụ thực chất là một chương trình. Cũng giống như các chương trình khác, một dịch vụ cần phải chạy trong một tệp thực thi. Dịch vụ này thường được gọi là dịch vụ tự chứa. Các dịch vụ còn có thể được chứa, hoặc chạy trong một tệp thực thi được quản lý bởi một agent bên ngoài như IIS hay Windows Activation Services (WAS). WAS cho phép WCF được kích hoạt một cách tự động khi phân phối tới một máy tính có chạy WAS. 1.3. Các tính năng của WCF 1.3.1. Giao dịch (Transaction) Một giao dịch là một đơn vị của công việc. Một giao dịch đảm bảo chắc chắn rằng mọi thứ diễn ra trong giao dịch thành công hay thất bại đều là kết quả tổng thể. Ví dụ, nếu một giao dịch chứa ba mục công việc cần thực hiện, trong quá trình thực hiện giao dịch, một trong số các mục đó bị thất bại, khi đó cả ba mục sẽ là thất bại. Giao dịch chỉ thành công khi cả ba mục công việc đều thành công. Giao dịch thường thấy trong các thao tác với cơ sở dữ liệu. 19 WCF cho phép đưa vào việc xử lý giao dịch như trên với các liên lạc. Nhà phát triển có thể nhóm các liên lạc với nhau thành các giao dịch. Ở mức doanh nghiệp, tính năng này cho phép bạn thực hiện các công việc giao dịch qua các nền tảng khác nhau. 1.3.2. Chứa (Host) WCF cho phép các dịch vụ được chứa trong một số lớn các môi trường khác nhau, như Windows NT Services, Windows Forms, và ứng dụng console, cũng như ở trên IIS (Internet Information Server) và WAS (Windows Activation Services). Chứa ứng dụng trên IIS còn có thêm các lợi điểm khác là dịch vụ có thể nhận các ưu điểm của rất nhiều tính năng có sẵn trên IIS, ví dụ IIS có thể điều khiển một cách tự động việc bắt đầu hay kết thúc một dịch vụ. 1.3.3. Bảo mật (Security) Bảo mật là tính năng không thể thiếu trong WCF nói riêng và trong liên lạc nói chung. Trong WCF, tất cả mọi thứ từ các bản tin tới các client hay server đều phải xác thực và WCF có tính năng để đảm bảo rằng các bản tin không bị lẫn trong quá trình vận chuyển. WCF bao gồm việc đảm bảo tính toàn vẹn và bảo mật của bản tin. WCF còn cho phép bạn tích hợp ứng dụng của bạn với cơ sở hạ tầng bảo mật sẵn có, bao gồm cả các chuẩn bên ngoài môi trường Windows bằng cách sử dụng các bản tin SOAP bảo mật. 1.4. Mô hình lập trình với WCF Nếu bạn đã từng làm việc với dịch vụ web, bạn sẽ thấy mô hình này quen thuộc với bạn theo một cách nào đó. Khi bạn tạo một dịch vụ web, bạn thực sự tạo ra một dịch vụ (service). Dịch vụ web chứa một tài liệu XML để mô tả tất cả mọi thứ cần biết về dịch vụ đó. Tài liệu này được mô tả bằng ngôn ngữ Web Service Description Language (ngôn ngữ mô tả dịch vụ web). Nó chứa ba phần:  Dịch vụ (Service): Chứa thông tin về vị trí của dịch vụ  Liên kết (Binding): Chứa thông tin về cách liên lạc với dịch vụ, như dịch vụ sử dụng giao thức gì, vv.  Kiểu cổng (PortType): Giải thích về dịch vụ sẽ làm gì 20
- Xem thêm -

Tài liệu liên quan