Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web

MDA (Model Driven Architecture) là một hướng tiếp cận mới trong việc phát triển các hệ thống phần mềm. 1. Tổng quan 1.1. Tổng quan về MDA 1.2. Các frameworks sử dụng cho ứng dụng web 2. Áp dụng MDA vào quá trình phát triển ứng dụng Web 2.1. Các hướng tiếp cận hỗ trợ cho MDA 2.2. Lập mô hình ứng dụng web với UX 2.3. Giới thiệu về MDA Toolkit 2.4. Quy trình phát triển MDA với Rational XDE và MDA Toolkit 3. Hiện thực 3.1. Pattern và Code Template 3.2. Plugin 3.3. Ứng dụng web: WebLog

pdf115 trang | Chia sẻ: lvcdongnoi | Lượt xem: 3001 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ội bộ hoặc trên Web site. Mỗi nhà phát triển cài đặt các chuyển đổi mong muốn và các plugin đi kèm (plugin phụ thuộc). Khi chúng đã được cài đặt, nhà phát triển sẽ có một menu các mục chọn mới và tập các preference mặc định mà khi được triệu gọi nó sẽ nhắc nhà phát triển các thông số được yêu cầu trước khi triệu gọi chuyển đổi đó. Tất cả luận lý chuyển đổi trong ánh xạ được lập code ở trong chuyển đổi được tải xuống (từ trên mạng nội bộ hay mạng intranet) và được thực thi với các chuyển đổi này. Chỉ riêng điều này thôi thì không đủ để đảm bảo rằng bất kỳ chuyển đổi nào cũng được sử dụng một cách chính xác. Do đó, hầu hết các chuyển đổi được xây dựng tốt sẽ bao gồm các phần mới để được thêm vào phần help online của Eclipse. Những phần này sẽ chỉ ra khi nào, tại sao và làm như thế nào một chuyển đổi được triệu gọi. Dĩ nhiên, trong mỗi môi trường, quy trình này sẽ được cập nhật và được giao tiếp sao cho phù hợp. Toolkit MDA cho IBM Rational XDE Java đã xuất hiện từ cuối năm 2003, và được sử dụng trong nhiều trường hợp khách hàng khác nhau và đã được đúc kết thành các bài học kinh nghiệm như sau. 2.4.5. Các bài học trong việc thiết kế và ứng dụng các giải pháp MDA Khi tạo các giải pháp MDA các bước sau cần được theo một cách nhất quán • Kiểm tra các mô hình đang được sử dụng trong quy trình phát triển, và các kết nối ngữ nghĩa giữa các thành phần thuộc các mô hình có mức trừu tượng khác nhau. • Xác định các chuyển đổi cần thiết cho sự tự động hóa. • Lập tài liệu các yêu cầu (requirement) chuyển đổi. • Tạo ra các profile UML cần thiết. • Phát triển code chuyển đổi. • Lập tài liệu cách sử dụng, sau đó đóng gói và triển khai. Những bước này thiết lập nên cơ sở của các project MDA khác nhau, và cùng với thiết kế lặp điển hình và sự phát triển giảm rủi ro, chúng đã đề ra một hướng dẫn đắc lực đến cách tiếp cận MDA. 2.4.5.1. Về vấn đề các kết nối mô hình ngữ nghĩa Hướng dẫn 1: Phát triển các chuyển đổi chỉ khi các kết nối ngữ nghĩa giữa các thành phần mô hình được hiểu rõ. Trước bất kỳ nỗ lực nào để đưa sự tự động vào trong quy trình phát triển, ta phải có một cái nhìn thông suốt và đầy đủ về tất cả các mô hình được sử dụng và được quản lý trong quy trình. Đã thường xuyên xảy ra việc các nỗ lực phát triển bắt đầu với sự tạo ra các mô hình không cần thiết, chỉ vì quy trình phát triển chưa phù hợp, đúng đắn cho rằng Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 82 các mô hình này là cần thiết. Các mô hình chỉ nên được tạo ra khi chúng cung cấp các thông tin rõ ràng và có ích cho nỗ lực phát triển. Mặt khác, nhiều project thường bị mất một số mô hình quan trọng và các khái niệm trừu tượng kết nối nhiều phần khác nhau của hệ thống. Do đó bất kỳ khi nào một số lượng đáng kể sự thông dịch và hoạt động của con người được sử dụng trong một phần cụ thể của project, ta có thể cần một mô hình hình thức nhằm nắm bắt các quá trình suy nghĩ và các quyết định thiết kế được làm trong suốt các hoạt động này. Kết nối ngữ nghĩa giữa các thành phần trong các mô hình thuộc các mức trừu tượng khác nhau có tầm quan trọng đặc biệt trong ngữ cảnh MDA. Hầu hết các hoạt động hiện nay xung quanh vấn đề MDA liên quan đến sự tự động của các chuyển đổi mô hình, đặc biệt là chuyển đổi giữa các mô hình ở mức trừu tượng cao hơn với các mô hình ở mức trừu tượng thấp hơn. Điển hình là các kết nối kiểu “fan out”; nghĩa là một thành phần mô hình đơn ở mức trừu tượng cao (ví dụ: use case) được kết nối đến nhiều thành phần mô hình (ví dụ: các boundary, entity, controller) trong các mô hình cấp thấp hơn Khả năng theo vết của các kết nối này quan trọng vì một số lý do, trong đó, lý do quan trọng nhất là khả năng hỗ trợ các chuyển đổi tự động. Nhưng nó cũng có tầm quan trọng trong môi trường phát triển lặp, nơi mà các chuyển đổi thường được triệu gọi nhiều lần. Thông thường một chuyển đổi hiếm khi chuyển đổi một mô hình nguồn thành một mô hình đích. Thường là có một mô hình nguồn chính cùng với một số thông số đa mục đích sẽ tạo ra một tập các mô hình đích. Ví dụ, trong một hệ thống J2EE, một mô hình phân tích chứa các thông tin sẽ được chuyển đổi thành một thiết kế cơ sở dữ liệu, một Java interface, một số Java ServerPages (JSPs), và một số bản mô tả việc cấu hình hoặc triển khai. Tất cả các mô hình này sẽ chi tiết hơn mô hình phân tích ban đầu và phải được đồng bộ hóa để thực thi chính xác. Do đó, việc phát triển một chuyển đổi quản lý việc truyền thông tin từ mô hình nguồn cấp cao thành một nhóm các mô hình cấp thấp, sẽ lợi hơn việc phát triển các chuyển đổi riêng biệt cho từng cặp mô hình input và output. Chính khả năng này cùng với nội dung ngữ nghĩa giữa các mô hình cấp thấp khác nhau làm cho MDA trở thành một công nghệ thu hút mọi người. Hơn thế nữa, một tính chất quan trọng của một chuyển đổi là khi được thực thi, chỉ có những thành phần của mô hình đích có phụ thuộc trực tiếp vào mô hình nguồn thì mới được cập nhật. Bất kỳ thông tin nào trong mô hình đích mà không phải được tạo ra bởi sự chuyển đổi lần đầu tiên thì nên được giữ nguyên. Ngoài ra, các thành phần mô hình được tạo bởi sự chuyển đổi không nên bị nhân bản trong mô hình đích trong mỗi lần gọi, tốt hơn là chúng chỉ nên được cập nhật (hoặc được tạo nếu chưa có trong mô hình). Hàm API của MDA Toolkit được xây dựng để các chuyển đổi tuân theo các quy luật thiết kế này. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 83 2.4.5.2. Về vấn đề xác định các chuyển đổi cần thiết Hướng dẫn 2: Không phải tất cả các kết nối ngữ nghĩa đều tạo nên các chuyển đổi MDA tốt. Khi các kết nối ngữ nghĩa được xác định giữa các phần tử trong mô hình, chúng nên được kiểm tra xem các luật quản lý các mối quan hệ của chúng có phù hợp cho sự tự động hay không. Một chuyển đổi thích hợp chỉ có thể thực thi khi các luật này rõ ràng và không bị nhập nhằng. Các luật có thể lớn và phức tạp hoặc cũng có thể nhỏ và đơn giản, trong cả hai trường hợp đều có thể cần tạo nên một chuyển đổi để hiện thực chúng. Tuy nhiên, nếu các luật định nghĩa các kết nối này sau đó sẽ xây dựng các phần tử mới trong các mô hình khác, mà các phần tử mới này lại yêu cầu kinh nghiệm hay sự phán đoán của người phát triển, thì sự tự động dễ dàng bị loại bỏ sau đó. Một lý do khác để loại bỏ sự tự động là khả năng các mô hình không thể truy xuất các phần tử cần thiết thông qua việc lập trình. Ví dụ, nếu hầu hết các bước chuyển đổi đều liên quan đến việc đọc các tài liệu ngôn ngữ tự nhiên, bất chấp mức độ hình thức của nó, thì cũng không thể phù hợp với sự tự động của MDA. Để minh hoạ cho điều này, ta có thể thấy việc chuyển đổi một tài liệu đặc tả use case thành một mô hình phân tích thường không thể thực hiện. Tuy nhiên, chuyển đổi một lược đồ tuần tự UML, hay lược đồ hoạt động cùng với một use case, có thể phù hợp cho sự tự động. 2.4.5.3. Về vấn đề lập tài liệu các yêu cầu chuyển đổi Hướng dẫn 3: Việc viết các chuyển đổi MDA nên được xem là một dự án phát triển phần mềm Chuyển đổi hiệu quả nhất là các chuyển đổi thực hiện tự động các công việc quá nhàm chán hoặc quá phức tạp một cách nhất quán và đáng tin cậy. Sự động hóa MDA đảm bảo tính nhất quán và trong hầu hết các trường hợp tiết kiệm được đáng kể thời gian cũng như công sức lập trình cho các lập trình viên. Không có gì ngạc nhiên rằng hầu hết các chuyển đổi thành công là các ví dụ phần mềm quan trọng. Khi sử dụng sự động hóa MDA và sự tạo ra các chuyển đổi quan trọng, ta nên coi chúng như là một sự phát triển phần mềm riêng biệt Một chuyển đổi, đặc biệt khi được tạo ra với MDA Toolkit, là một ví dụ của phần mềm tạo ra theo nhu cầu. Các requirement nên được hiểu rõ ràng và nên được kiểm tra cả về mặt ngữ nghĩa và kỹ thuật. Tập hợp các đặc tả requirement được chứa trong tài liệu ánh xạ. Tài liệu ánh xạ mô tả chi tiết các kết nối ngữ nghĩa giữa các thành phần lập mô hình trong nhiều mô hình khác nhau tham gia trong chuyển đổi. Các requirement khác có thể bao gồm vấn đề hiệu suất, vấn đề bảo mật, vấn đề khả mở rộng… Hầu hết các chuyển đổi mà chúng ta quan tâm đến đều phải trải qua các giai đoạn phân tích và thiết kế và kết quả cuối là một tập các class hiện thực chuyển đổi đó. Các vấn đề khác, như test, triển khai và hướng dẫn cách sử dụng cũng nên có đầy đủ như trong quy trình phát triển phần mềm truyền thống. Tuy các chuyển đổi MDA không đòi hỏi Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 84 phải có một nhóm phát triển lớn hiện thực nó, nhưng việc phát triển chúng như một phần độc lập (tức là phải trải qua đầy đủ các giai đoạn) sẽ đảm bảo chất lượng của chuyển đổi. Khi xác định các requirement cho một chuyển đổi hiện thực bằng MDA Toolkit, ta phải xét ba hành vi khác nhau: • Kiểm tra tính hợp lệ của các thông số nhập. • Thực thi các logic hoặc các ánh xạ chuyển đổi cốt lõi. • Kiểm tra các kết hợp ngữ nghĩa giữa các thành phần mô hình tham gia trong chuyển đổi. Sự thực thi logic chuyển đổi và sự bổ sung vào các mô hình đích là công việc quan trọng nhất trong toàn bộ chuyển đổi. Tuy nhiên, kiểm tra tính hợp lệ của dữ liệu nhập và kiểm tra việc chuyển đổi đã hoàn chỉnh chưa cũng rất quan trọng trong môi trường phát triển lặp (việc chuyển đổi có thể được áp dụng nhiều lần trên cùng một mô hình nguồn). Hướng dẫn 4: Kiểm tra tính toàn vẹn của tất cả các thông số và các artifact tham gia trong một chuyển đổi trước khi thực thi chuyển đổi đó Hầu hết các thứ đều có thể được triệu gọi và xử lý trong một chuyển đổi được tạo ra bởi MDA Toolkit và MDA Toolkit không cung cấp cơ chế giám sát quy trình giao dịch. Trong một số trường hợp, một chuyển đổi bắt đầu nhưng phải dừng trước khi được hoàn tất, không có cơ chế đảm bảo rằng việc dừng chuyển đổi này sẽ xác lập lại (reset) tất cả các thông số đầu vào trở về trạng thái trước khi chuyển đổi. Điều này là bởi vì MDA Toolkit không giới hạn hay hạn chế các kiểu artifact có thể tham gia vào một chuyển đổi. Điều này thì rất hữu ích khi trong một chuyển đổi có thể triệu gọi các Web services bên ngoài hoặc có thể chỉnh sửa, bổ sung các artifact. Nói chung, nhà phát triển chuyển đổi phải đảm bảo vào tính toàn vẹn của các artifact được xử lý trong một chuyển đổi. Kết quả là cần phải đảm bảo rằng tập các artifact đầu vào phải thuộc vào một trạng thái được định nghĩa (nghĩa là tất cả các thông số được yêu cầu phải được xác định, các profile cần thiết phải được thêm vào trong mô hình và nội dung cần thiết trong các mô hình là các artifact được kiem Hướng dẫn 5: Cần một đặc tả của việc kiểm tra để duy trì sự toàn vẹn của chuyển đổi sau khi thực hiện các thay đổi trong mô hình đích Khi các chuyển đổi trở thành một phần trong quy trình phát triển lặp, dường như sau mỗi chuyển đổi được thực thi, các artifact, cả input và output đều phải được cập nhật bằng tay. Điều này là theo một quy tắc chung của phát triển hướng mô hình: các thay đổi được đưa vào hệ thống trong các mô hình với mức trừu tượng thích hợp nhất, bất kể mức trừu tượng đó là mức nào. Ví dụ, một thực thể Customer được mô tả trong mô hình phân tích cấp cao có thể không chứa thông tin về cách lưu trữ (optimistic, pessimistic…). Vì vậy các thay đổi đối với cách lưu trữ này không cần đưa vào mô hình phân tích, mà nên đưa vào mô hình thiết kế nơi chúng có sẽ có ảnh hưởng nhiều nhất. Do do sự thêm vào một thuộc tính khóa mới đối với class Customer sẽ có thể đòi hỏi một thay đổi trực tiếp lên mô hình phân tích cấp cao. Khi chính xác và sau một ước lượng có thể, thay đổi này sẽ Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 85 được phản ánh chính xác lên mô hình cấp thấp, như kết quả của một chuyển đổi MDA tự động. Vì các quy trình phát triển lặp đều khuyến khích sự phát triển của mô hình thông qua một quy trình phát triển, một đặc tính quan trọng cũa một chuyển đổi tốt là khả năng phân tích trạng thái hiện tại của các artifact và so sánh chúng với trạng thái mong muốn sau khi thực hiện xong chuyển đổi. Bước này được khuyến khích trong các chuyển đổi được tạo bằng MDA Toolkit là bước kiểm chứng (verification). Thông thường bước kiểm chứng này chạy riêng biệt và chạy sau khi các artifact đã trải qua chuyển đổi và các điều chỉnh sau đó. Do đó, các mô hình và artifact cuối có thể trải qua sự tính chế thêm mà sự tinh chế này không liên quan đến bất kỳ thông tin ngữ nghĩa nào được quản lý bởi quy trình chuyển đổi. Trong suốt quá trình tinh chế này, các thay đổi (mặc dù không mong muốn) có thể làm đứt các liên kết về ngữ nghĩa giữa các mô hình. Thực thi tường minh bước kiểm chứng trong một chuyển đổi sẽ tạo ra một bản tường trình cho nhà phát triển về bất kỳ các đứt quãng trong ánh xạ ngữ nghĩa được thiết lập bởi chuyển đổi ban đầu. Các đứt quãng này sau đó có thể được thực hiện một cách chính xác hơn bởi nhà phát triển, kết quả là sẽ có một số thay đổi trong mô hình đích hoặc mô hình nguồn hoặc cả hai. Hướng dẫn 6: Trong hầu hết các trường hợp MDA, các ánh xạ mô hình đến mô hình thường phức tạp và đòi hỏi sự thiết kế và hiện thực cẩn thận. Logic cốt lõi trong một chuyển đổi thường là thuật toán trong đó một tập hợp các thành phần mô hình được chuyển đổi thành một tập hợp khác. Trong một ánh xạ kiểu khai báo đơn giản, các kết nối là tương đối đơn giản, dễ thực hiện, và có ít sự nhập nhằng. Trong các chuyển đổi MDA có quy mô lớn, các ánh xạ luôn không quá đơn giản. Thường một thành phần trong mô hình nguồn sẽ ánh xạ dến một cấu hình của các thành phần theo một tập hợp các điều kiện phức tạp bao gồm các thành phần mô hình khác, các kết nối và các stereotype và tag value của các profile UML khác nhau. Lấy một ví dụ đơn giản một thực thể có tên là Addres. Thực thể này gồm nhiều thuộc tính, một trong các thuộc tính đó được được đánh tag là khóa chính (trong profile đánh dấu). Ánh xạ một class trừu tượng như thực thể này thành một đối tượng Java và thiết kế cơ sở dữ liệu là tương đối dễ thực hiện (xem hình 2-20). Một đối tượng Java được tạo ra với các thuộc tính được phản chiếu và các kiểu dữ liệu được hiệu chỉnh cho chính xác. Các hàm get và set cũng được tạo thêm. Trong thiết kế cơ sở dữ liệu, một table và các column được tạo ra với tên được điều chỉnh cho phù hợp với các chuẩn đặt tên của cơ sở dữ liệu. Khóa chính (được xác định bởi tag trong profile đánh dấu) được gán. Các kiểu dữ liệu được chuyển đổi với sự trợ giúp của profile đánh dấu. Profile đánh dấu có thể được sử dụng để xác định các giá trị null và các thuộc tính cở sở dữ liệu điển hình khác. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 86 Hình 2-20: Ánh xạ một thực thể đơn giản vào các mô hình đối tượng và mô hình thiết kế Ví dụ đơn giản này đã minh họa cho việc ánh xạ một class trong mô hình trừu tượng thành một class trong mô hình đối tượng và một table trong mô hình dữ liệu. Các thuộc tính trong mô hình trừu tượng ánh xạ một-một các thuộc tính trong mô hình đối tượng và các column trong mô hình dữ liệu. Các phương thức trong mô hình đối tượng tất cả đều có thể truy ngược lại một thuộc tính mô hình trừu tượng. Tuy nhiên, trong ví dụ khác, việc ánh xạ không còn quá dễ dàng. Xét một ví dụ thứ hai là một tập các class tham gia trong hệ thống phân cấp trong mô hình phân tích (hình 2-21) Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 87 Hình 2-21: Mô hình phân tích Các class RestrictedProduct và CommercialProduct là sự phân loại từ Product. Class Product cũng xác định hai thuộc tính (code và supplier) là định danh đối tượng hay khóa chính. Tuy nhiên chúng thường được xác định bằng tag value hoặc stereotype mà tag value hay stereotype này có thể không xuất hiện trực tiếp trên lược đồ (có thể xem bằng cách xem property của thuộc tính). Bằng cách sử dụng các quy tắc đặt tên của tổ chức và các chiến lược ánh xạ thuộc tính, vẫn có ba cách rất khác nhau để một tập các class có thể được chuyển đổi thành một mô hình cơ sở dữ liệu. Chúng ta có thể gọi đó là ba chiến lược như sau “Roll Up”, “Roll Down” và “Separate Tables”, và các chiến lược này được hỗ trợ bởi Data Modeler của IBM Rational XDE, như trong hình 2-22. Hình 2-22: Chiến lược Roll up Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 88 Trong chiến lược đầu tiên, một bảng mới T_PRODUCT_TYPE được tạo ra bằng cách lấy class cơ sở và thêm tiền tố _TYPE. Các column trong bảng này được định nghĩa trước bởi ánh xạ và luôn được tạo ra giống nhau trong các lần áp dụng chuyển đổi. Table này được sử dụng để cung cấp một phương tiện mở rộng để thêm vào các kiểu mới. Tất cả các thuộc tính của các class con được đưa vào (roll up) trong một bảng chính. Trong chiến lược Roll Down, được minh họa trong hình 2-23, tất cả các class cụ thể (concrete class) được tạo bảng riêng cho nó. Trong đó các column trong class cơ sở được nhân bản vào trong tất cả các bảng. Hình 2-23: Chiến lược Roll Down Cuối cùng là chiến lược Separate Tables, được minh họa trong hình 2-24, mỗi class được ánh xạ thành một bảng, và các quan hệ định danh được tạo ra giữa class cơ sở và class con để các thuộc tính của class cơ sở được ánh xạ trong table class cơ sở có thể được truy xuất bởi các hàng dữ liệu tương ứng trong các table con. Trong cả ba chiến lược, các table sử dụng khóa tổng hợp (composite key) được ngầm định bởi class cơ sở chính. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 89 Hình 2-24: Chiến lược Separate tables Từ ví dụ này, rõ ràng các chiến lược ánh xạ không còn đơn giản và một số thành phần trong mô hình trừu tượng có thể ánh xạ đồng thời đến nhiều thành phần khác nhau trong thiết kế cơ sở dữ liệu. Ngoài ra, trong trường hợp Roll Up, ba class phân tích được ánh xạ thành hai table, với chỉ một trong số chúng dùng chung tên với class phân tích. Mô hình đối tượng cũng có thể có các yêu cầu cho chỉ một thuộc tính như một khóa đối tượng (như trong J2EE). Kết quả chuyển đổi thành mô hình đối tượng Java được minh họa trong hình 2-25. Vì có hai thuộc tính tạo nên một khóa đối tượng, một class khóa (key class) mới được tạo ra và một quan hệ định hướng (direction association) được thêm vào thiết kế đối tượng ngoài hàm get và set. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 90 Hình 2-25: Thiết kế đối tượng java với quan hệ tổng quát hóa và khóa kết hợp Trường hợp này cũng minh họa cho các phức tạp tiềm ẩn trong các ánh xạ sử dụng trong thực tế. Trương hợp này sẽ trở nên phức tạp hơn nhiều khi các luật quyết định chiến lược ánh xạ phụ thuộc vào sự kết hợp giữa các tag value và cấu hình mô hình phân tích (nghĩa là sử dụng Roll Up khi có nhiều nhất là ba class, thay thế các khóa tổng hợp với một khóa integer được tạo tự động nếu giá trị tag override không được gán là False…) Trong một tầm nhìn nhỏ, không có vấn đề nào là không vượt qua được, và mỗi trường hợp, được kiểm tra tách biệt, làm rất tốt, thường tương ứng với những gì các nhà thiết kế và phát triển đã phải làm bằng tay trong nhiều năm. Tuy nhiên, khi được tập họp lại vào một chuyển đổi, mà cần phải cộng tác với cấu trúc và nội dung của các mô hình đích, các logic phức tạp và đan xen lẫn nhau thường gây khó khăn cho việc biểu diễn các chuyển đổi đơn thuần là kiểu khai báo. Trong các trường hợp này, các chuyển đổi tốt nhất là được biểu diễn và hiện thực theo thuật toán. Đây cũng là kiểu sử dụng mặc định của MDA Toolkit. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 91 Hướng dẫn 7. Các chuyển đổi có thể được thể hiện bằng khai báo hoặc bằng câu lệnh. Nói chung, cách tiếp cận bằng câu lệnh thì phù hợp hơn khi mô tả các chuyển đổi phức tạp. Trong khi MDA Toolkit nhấn mạnh đến việc thể hiện theo kiểu câu lệnh, nó cũng cho phép các pattern XDE triệu gọi, hoặc hỗ trợ các hàm khai báo. MDA Toolkit cho phép các nhà phát triển chuyển đổi tạo ra các mô hình tham chiếu (reference model) với tập các thành phần mô hình đã được định nghĩa trước, mà các thành phần mô hình này có thể được copy có chọn lọc đến một mô hình đích và được thay đổi trong suốt quá trình sao chép. Hình 2-26 là một đoạn mẫu mô hình tham chiếu chứa các class và các quan hệ. Một số class có thuộc tính và hàm. Các hàm có code template (code mẫu) cho chúng, được sử dụng để tạo ra nội dung code của hàm hoàn chỉnh. Tên của các thành phần mô hình không phải là tên Java hợp lệ, vì tập các class này không được sử dụng để tạo ra code trực tiếp. Đúng hơn là, tập các class này sẽ được copy vào trong một code model, và trong lúc copy, các tên thành phần sẽ được cập nhật cho phù hợp với tên thật của các class có trong mô hình nguồn của chuyển đổi. Hình 2-26: Một pattern của các thành phần mô hình trong mô hình tham chiếu Quy trình tổng quan của chuyển đổi là xử lý một mô hình nguồn (một mô hình độc lập platform, PIM) và tìm kiếm các class có tag là class được quản lý (<<managed class>>), nghĩa là các class có stereotype hoặc tag value được xác định trong chuyển đổi. Việc đánh dấu trong mô hình PIM chỉ ra rằng class nào cần được chuyển đổi thành một tập các class trong mô hình PSM đích. Do đó đối với mỗi class được quản lý trong PIM, tập hợp các class trong hình 2-26 sẽ được copy vào vị trí thích hợp trong PSM, và trong suốt quá trình copy này, các tên sẽ được chỉnh sửa cho phù hợp với thông tin trong class PIM nguồn. Hình 2-27 thể hiện các kết quả của việc chuyển đổi một class trong PIM có stereotype là > vào trong PSM. Kết quả là có 4 class mới được tạo Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 92 thành, các tên của các class này dựa trên tên của class PIM nguồn. Chuyển đổi không chỉ copy trên cấu trúc và các thuộc tính class từ đoạn mẫu mô hình tham chiếu, mà còn tăng cường thêm cho các class mới được tạo các thuộc tính và hàm của class PIM. Các hàm get và set cũng được tạo thêm trong class PSM. Hình 2-27: Áp dụng một pattern dựa trên mô hình tham chiếu Loại tiếp cận này tăng cường kiểu định nghĩa pattern khai báo và trực quan với sự điều khiển code bến dưới. Trong suốt quá trình chuyển đổi, các hàm callback được gán và có thể được triệu gọi trong quá trình copy. Điều này cho phép nhà phát triển có cơ hội để xác định và tinh chế các tên đích của tất cả các thành phần được copy. Sau khi tạo và copy các thông tin trong mô hình tham chiếu, phần còn lại của chuyển đổi sẽ copy tất cả các thuộc tính và hàm publuc của các class PIM và tạo ra các hàm get và set. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 93 2.4.5.4. Về vấn đề tạo UML Profile Hướng dẫn 8: UML Profile có thể được sử dụng để để quản lý sự đánh dấu (markup) như là một phần của sự chuyển đổi (transformation). UML Profile được sử dụng trong hai cách riêng biệt và tách rời. Đầu tiên, vai trò truyền thống của UML profile là cung cấp một cơ chế để mở rộng ngữ nghĩa của UML theo các domain khác nhau. Profile lập mô hình dữ liệu và profile lập mô hình nghiệp vụ là các ví dụ của các profile UML cho phép IBM Rational XDE lập mô hình các quá trình nghiệp vụ và các thiết kế cơ sở dữ liệu vật lý, luận lý tương ứng. Các profile cũng là cơ chế hữu ích để quản lý sự đánh dấu mô hình (model marking), một yếu tố cần thiết của quá trình chuyển đổi mô hình của MDA. Đánh dấu là một bước hoặc một kĩ thuật ở trong MDA mà trong đó, các thông tin thêm vào không phải thuộc ngữ nghĩa của chính mô hình, và được dùng cho quá trình tự động sau này. Đánh dấu mô hình thường chỉ được làm ngay trước khi một chuyển đổi đã sẵn sàng để triệu gọi. Dĩ nhiên, một mô hình có thể được đánh dấu trong lúc nó đang được phát triển. Tuy nhiên, vai trò và kỹ năng của các nhà phát triển tạo ra các mô hình không thích hợp cho việc hiểu ý nghĩa và mục đích của các đánh dấu khác nhau. Ví dụ, giả sử một mô hình thực thể trừu tượng đơn giản (một phần của mô hình phân tích truyền thống) dùng UML để phát triển bởi các nhà phân tích. Mô hình này định nghĩa một số thực thể persistent trong hệ thống, bao gồm các thuộc tính của chúng và các mối quan hệ giữa chúng. Mô hình này sẽ được chuyển đổi sang một thiết kế cơ sở dữ liệu luận lý (hoặc vật lý). Nhưng vấn đề xãy ra là khi sử dụng một mô hình phân tích để chuyển sang một mô hình dữ liệu mới, bởi vì các thông tin lưu trong mô hình phân tích là không đủ cho một mô hình dữ liệu làm việc. Ví dụ, một kiểu một thuộc tính String của một thực thể có thể hiện thực thành một column kiểu char, varchar hoặc text. Thông tin về chiều dài tối đa của cột cũng là một thông tin thường không được biểu diễn trong mô hình phân tích. Các chuyển đổi đi từ một mô hình trừu tượng cao sang mô hình trừu tượng thấp rồi sang các mô hình có mức trừu tượng thấp hơn và chi tiết hơn nữa thường phải đối mặt với bài toán thông tin chưa hoàn tất trong mô hình. Ngay cả khi ánh xạ các association vào các field trong Java, việc xác định cách chuyển đổi các association có bậc là “1..n” cũng không rõ ràng. Các ngữ nghĩa của set, list, và map cũng vượt quá phạm vi ngữ nghĩa của hầu hết các mô hình phân tích UML, nhưng chúng lại được sử dụng trong các class Java. UML profile như là một giải pháp ở đây để sử dụng cho giai đoạn chuyển đổi. Một profile đánh dấu, phân biệt và tách hẳn khỏi bất kỳ một profile ngữ nghĩa nào, có thể được áp dụng vào mô hình bao gồm các stereo type và các tag value chỉ dùng duy nhất cho việc chuyển đổi. Một profile lập mô hình dữ liệu có thể chứa các tag mô tả chiều dài của cột... Một Java profile chứa các thông tin về cách chuyển đổi một association thành một phần tử trong class của Java. Bộ MDA toolkit cho phép tạo ra các profile sử dụng cho bất kỳ mô hình nào có thể mở được bởi Rational XDE. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 94 2.4.5.5. Về vấn đề phát triển chuyển đổi Hướng dẫn 9: Các chuyển đổi nên được tạo ra theo cách mà chúng có thể tham gia vào một quá trình phát triển lặp đi lặp lại. Trong khi các chuyển đổi chỉ sử dụng một lần có vẻ dễ dàng để phát triển, tuy vậy người ta cũng thấy rằng mức độ và khả năng sử dụng của các chuyển đổi này cũng thấp như công sức đã bỏ ra để hiện thực chuyển đổi đó. Phát triển các chuyển đổi với MDA Toolkit để các chuyển đổi này tham gia vào quá trình phát triển lặp yêu cầu người phát triển chú ý kỹ đến các thành phần trong thiết kế và hiện thực. MDA API cung cấp các phương thức chính cho sự truy xuất và thao tác trên mô hình chính là các API phục vụ cho quá trình phát triển chuyển đổi lặp. Ví dụ, khi tạo một thuộc tính trên một class, phương thức createAttribute() của đối tượng MdaClass mặc định đầu tiên sẽ kiểm tra kiểm tra xem có tồn tại một thuộc tính với tên đó trong mô hình hay chưa, nếu đã có, nó sẽ không tạo một thuộc tính trùng lắp với thuộc tính đó. Một điều thú vị là đây không phải là một hành vi mặc định của các API cung cấp để truy xuất UML bởi vì bảng đặc tả UML không hề yêu cầu tên của các thuộc tính là duy nhất. Do đó, về lý thuyết, các API này nên cho phép điều trùng lắp trên. Tuy nhiên, hầu hết các chuyển đổi của chúng ta đều nhắm vào một ngôn ngữ lập trình như là Java hay C++, do đó, trên thực tế ta sẽ không cho phép sự trùng lắp tên thuộc tính. MDA Toolkit API có cách hiện thực như sau: khi nó so sánh các tên class cũng như các tên của thuộc tính, nó tìm kiếm sự duy nhất trong container và sử dụng các so sánh phân biệt chữ hoa và chữ thường (case-sensitive); khi so sánh các phương thức, nó thực hiện các so trùng tên phương thức (có phân biệt chữ hoa và chữ thường) kết hợp với so sánh kiểu dữ liệu của danh sách các đối số input và bỏ qua kiểu trả về của phương thức. Do vậy, MDA toolkit API cho phép các nhà phát triển chuyển đổi với đích là C++ hoặc Java phát triển một chuyển đổi cho phép sử dụng lặp một cách dễ dàng hơn. Quá trình phát triển một chuyển đổi dựa vào MDA Toolkit nhỏ hơn nhiều so với một bài tập phát triển code trong Java và cụ thể là trong phát triển một Eclipse Java Plugin. MDA Toolkit wizard cung cấp hầu hết code mà Eclipse yêu cầu và để cho các nhà phát triển chuyển đổi nhắm vào việc hiện thực chuyển đổi logic. Hướng dẫn 10: Một chuyển đổi tốt hiện thực các thủ tục kiểm chứng (validation), chuyển đổi và xác nhận (verify). Khi MDA Toolkit wizard tạo một project, nó cung cấp các stub cho ba phương thức quan trọng này như trong ví dụ sau: public boolean validate() throws Exception{ boolean valid = true; return valid; } Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 95 public void transform() throws Exception { } public boolean verify() throws Exception { boolean verified; return verified; } Phương thức quan trọng nhất là transform(), phương thức này được triệu gọi khi nhà phát triển muốn triệu gọi quá trình chuyển đổi. Trong phương thức này các logic nghiệp vụ của chuyển đổi được coding. Các logic nghiệp vụ của chuyển đổi thường được giao cho các phương thức helper và các class xây dựng theo nhu cầu chuyển đổi riêng của từng người để chúng thực hiện công việc chuyển đổi thật sự. Trong suốt quá trình chuyển đổi, sẽ rất hữu ích khi viết các thông điệp chuyển đổi vào một nơi có thể thấy được để các nhà phát triển có thể giám sát quá trình. Một ví dụ chuyển đổi mẫu được chỉ ra trong ví dụ sau. Các tên các file mô hình phân tích và mô hình thiết kế là các thông số. Các giá trị của thông số có thể được truy xuất thông qua việc gọi một phương thức của class cha. Sau đó chúng sẽ được chuyển sang các tham chiếu thành phần của mô hình MDA. Trong bảng này, mô hình phân tích được quét để tìm các class có stereotype là “Persistent Object” (trong một profile) và không là class con của class khác, bởi vì toàn bộ cây phân cấp được xử lý trong một chức năng. Hầu hết công việc là phối hợp nhờ vào phương thức helper processPersistenceObject(), một phương thức sử dụng các class được phân công (delegate) để thực hiện công việc chuyển đổi. Ví dụ: Hiện thực mẫu tìm các class có stereotype “PersistentObject” trong mô hình phân tích. public void transform() throws Exception { writeln("Transformation has started ..."); String analysisModelFilename = getStringParameter(TransformationParameters. P_FILE_PIM_MODEL); String designModelFilename = getStringParameter(TransformationParameters. P_FILE_PSM_MODEL); MdaModel designModel = openModel("psm", designModelFilename); MdaModel analysisModel = openModel("pim", analysisModelFilename); if( pim != null && psm != null && stereotype.length()>0 ) { MdaClass[] classes = analysis.getMdaClasses(MdaOption.RECURSE); for(int i=0;i<classes.length;i++) { Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 96 MdaClass pimCls = classes[i]; MdaGeneralization ger=pimCls.getMDAGenaralizations(); if(ger.length()==0 && pimCls.isStereotyped(“MyCustomProfile”, PersistentObject)){ processPersistentObject(); } } } writeln("Transformation has completed."); } Phương thức validate() được gọi trước khi gọi phương thức transform() và nếu validate() trả về một giá trị false, phương thức transform sẽ không được thực thi. Trong hiện thực mẫu trong ví dụ sau, mô hình phân tích được kiểm tra để đảm bảo chắc chắn rằng nó thật sự đang tồn tại và nó áp dụng một profile theo yêu cầu. Mô hình thiết kế được kiểm tra về sự tồn tại của nó và nó là một mô hình code, tức có thể thực hiện kỹ thuật roundtrip trên code Java. Ví dụ: Mô hình phân tích được kiểm tra cho việc áp dụng các UML profile và kiểm tra mô hình thiết kế để đảm bảo khả năng roundtrip. public boolean validate() throws Exception{ boolean valid = true; writeln(“Starting validation); String designModelFilename= getStringParameter(TransformationParamaters.P_FILE_PSM_MODEL; MdaModel designModel = openModel(“designModel”,designModelFilename); if(designModel == null){ valid = false; writeln(“The design model is a required parameter and must exist.”); }else{ if( !designModel.canRTE()){ valid = false; writeln(“The design model must be an XDE Code Model”); } } Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 97 String analysisModelFilename= getStringParameter(TransformationParamaters.P_FILE_PIM_MODEL; MdaModel analysisModel = openModel(“analysisModel”,ModelFilename); if(analysisModel == null){ valid = false; writeln(“The analysis model is a required parameter and must exist.”); }else{ if(!analysisModel.hasProfile(“MyCustomProfile”){ valid = false; writeln(“The profile “MyCustomProfile” must be” +”applied to analysis model!”); } } writeln(“Validation completed!”); return valid; } Phụ thuộc vào mức xác nhận mong muốn, một method verify() có thể rất phức tạp, ngang bằng với phương thức transform, và thường nó sử dụng các phương thức và class helper tương tự với code chuyển đổi thực sự. Trong ví dụ sau, đoạn code mẫu này dùng để nhận dạng các thành phần trong mô hình phân tích cần chuyển đổi. Ví dụ: method verify() public boolean verify() throws Exception { writeln("Verifying transformation ..."); boolean verified = true; String analysisModelFilename = getStringParameter(TransformationParameters.P_FILE_PIM_MODEL; String designModelFilename = getStringParameter(TransformationParameters.P_FILE_PSM_MODEL; MdaModel designModel = openModel("psm", designModelFilename); MdaModel analysisModel = openModel("pim", analysisModelFilename); if( pim != null && psm != null && stereotype.length()>0 ) { MdaClass[] classes = analysis.getMdaClasses(MdaOption.RECURSE); for(int i=0;i<classes.length;i++) { Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 98 MdaClass pimCls = classes[i]; MdaGeneralization ger=pimCls.getMDAGenaralizations(); if(ger.length()==0 && pimCls.isStereotyped(“MyCustomProfile”, PersistentObject)){ verifyPersistentObject(pimCls); } } } else { writeln("\tRequired parameters not available."); } writeln("Verification complete."); return verified; } Sự phát triển và kiểm tra một chuyển đổi MDA tiến hành như các project Eclipse plugin khác. Một chuyển đổi có thể được debug thông qua sử dụng Eclipse runtime workbench. 2.4.5.6. Về vấn đề triển khai chuyển đổi Hướng dẫn 11: Sử dụng kiến trúc Eclipse plugin để đơn giản hoá quá trình cài đặt và nâng cấp các chuyển đổi MDA. Khi một chuyển đổi được phát triển xong, cần phải triển khai và hướng dẫn sử dụng chuyển đổi đó. Cơ chế Eclipse Update Manager cung cấp một một cơ chế thuân tiện cho việc cài đặt các plugin vào trong Eclipse. Sử dụng các chức năng của Eclipse Plugin Development Environment (PDE), chuyển đổi có thể được đóng gói và đặt trên internet do đó dễ dàng tải (download) và cài đặt các chuyển đổi này và các plugin phụ thuộc khác. Khi chuyển đổi đã được cài đặt, một menu chuyển đổi có thể được tích cực (thấy được) ở bất kỳ khung làm việc nào (lập mô hình, code...). Nhà phát triển có thể tuỳ ý chạy ba phương thức (validate, transform và verify) đồng thời hoặc chạy chúng riêng rẽ. Kết quả sẽ xuất hiện trong mô hình đích và quá trình chuyển đổi sẽ được hiển thị trên cửa sổ log (log view). Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 99 3. Hiện thực 3.1. Pattern và Code Template 3.1.1. DateHelperLib -Bao gồm các phương thức xử lý ngày tháng như: so sánh hai ngày, định dạng ngày tháng… 3.1.2. FileHelperLib -Bao gồm các phương thức quản lý file như: copy file, xóa thư mục, lấy đuôi file… Người sử dụng có thể áp dụng hai hiện thực trên vào mô hình hệ thống và sinh code. Code được sinh ra chưa tự import các thư viện Java, người sử dụng sẽ tự động import các thư viện này thông qua chức năng hỗ trợ import của Rational XDE. (Click chuột phải vào editor window, chọn Organize Import hoặc click trái vào phần gợi ý sửa lỗi trong editor window). 3.2. Plugin 3.2.1. Plugin UserManagement 3.2.1.1. Chức năng Thực hiện đọc mô hình UML, sinh ra các phương thức dựa theo Hibernate framework để quản lý User ở tầng DAO (không hiện thực các method thuộc tầng Business và tầng Presentation), mỗi phương thức bao gồm câu lệnh HQL và các lệnh khởi tạo, đóng session, transaction. Các phương thức được sinh ra bao gồm: • save: Lưu một đối tượng User vào table tương ứng trong cơ sở dữ liệu • update: Cập nhật các thông tin của đối tượng User lên table trong cơ sở dữ liệu. • remove: Xóa một đối tượng (một hàng) khỏi table trong cơ sở dữ liệu. • validate: So trùng Username và Password • isExist: Kiểm tra sự tồn tại của một đối tượng User trong table. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 100 • getUser: Trả về một đối tượng User trong table. Hệ quản trị cơ sở dữ liệu quan hệ được sử dụng có thể là bất kỳ DBMS quan hệ nào: Oracle, SQL Server, PostGreSQL… 3.2.1.2. Hiện thực: • Platform đích: Hibernate, Java. • Công cụ sử dụng: Rational XDE for Java, MDA Toolkit. • Hiện thực plugin bằng ngôn ngữ Java dựa trên MDA transformation wizard do MDA toolkit cung cấp trên công cụ Rational XDE. • Bước 1: Dùng Rational XDE (có MDA Toolkit) tạo một profile UserProfile, bao gồm các stereotype sau: -Stereotype cho Class: > -Stereotype cho các thuộc tính (Atribute) > > Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 101 Hình 3-1: Mô tả một mô hình tạo các stereotype phục vụ cho plugin quản lý User Sau khi hoàn chỉnh mô hình trên, ta sử dụng MDA Profile Tool để đăng ký một profile mới với hệ thống, tên của profile này là UserManager. Từ đây, tất cả các mô hình được lập trên Rational XDE đều có thể áp dụng profile này. • Bước 2: Xây dựng plugin thực hiện chuyển đổi từ mô hình sang code: -Tạo một plugin project dựa trên MDA Transformation Wizard. -Đọc từ mô hình nguồn hệ thống, thực hiện các phương thức chính sau: 1. validate: kiểm tra tính hợp lệ các thông số Input. 2. transform: chỉ thực hiện khi validate thành công. Với bất kỳ class nào có áp dụng «UserManagement» kiểm tra xem các phương thức và các thuộc tính của nó có áp dụng các stereotype trong UserManager Profile hay không, nếu có sinh ra các phương thức quản lý User tương ứng như đã nêu ở phần chức năng. Hiện thực cụ thể: Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 102 • Tìm trong mô hình hệ thống (trong Class Diagram) các class có stereotype là «UserManagement». • Với mỗi class có stereotype là «UserManagement»: o Xác định tên table tương ứng với class này, khoá chính của table đó, file nguồn tương ứng sẽ được sinh code: Parameter param = new Parameter(".hbm"); String tableKeycolumn = param.getTableKeyName(hibernateDir, normalizeName(pimCls.getName().trim())); String className = param.getTableName(hibernateDir, normalizeName(pimCls.getName().trim())); String FilePathToWrite=param.getFiletoWriteMethod (hibernateDir,className); o Duyệt qua các thuộc tính trong class này: Tìm trong class hai thuộc tính có stereotype >, >. Phân tích file ánh xạ XML trong thư mục Hibernate để tìm ra các thông số cần thiết cho các phương thức được sinh ra. Sinh ra các phương thức save, update, remove, validate, isExist, getUser để hiện thực tầng DAO, tương tác với table tương ứng với class có stereotype > trong mô hình UML nói trên. o Nếu người sử dụng có chọn sinh ra class Java Hibernate Session Factory, ta sẽ sinh ra một class HibernateSessionFactory có các phương thức quản lý việc khởi tạo và kết thúc của Session 3. verify: kiểm tra tính thống nhất giữa model và code sinh ra. 3.2.1.3. Hướng dẫn sử dụng plugin: Công cụ sử dụng: • Rational XDE (+MDA Toolkit) • My Eclipse (+Hibernate Synchronizer) Transformation được đóng gói dưới dạng plugin do đó, ta có thể lấy plugin này cho vào thư mục plugins của công cụ RationalXDE. 3.2.1.3.1. Yêu cầu -Người sử dụng phải áp dụng UserManager profile vào model hệ thống Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 103 -Người sử dụng dùng XDE lấy model hệ thống đã vẽ để sinh ra file script (chứa các câu lệnh SQL) để tạo table theo một DBMS nhất định. Sau đó, dùng file script này và DBMS đã chọn đó để tạo database. -Dùng một MyEclipse (hoặc một IDE bất kỳ) có hỗ trợ Hibernate Synchronizer để ánh xạ các table thành các đối tượng Java, một table tương ứng với ba thành phần sau: • File XML ánh xạ giữa table và class • Java Abstract Class • Java Class thừa kế từ abstract class trên. Các method sẽ được ghi vào class này Ba thành phần này sẽ được chứa trong cùng một thư mục Hibernate dùng tương tác với cơ sở dữ liệu bên dưới. 3.2.1.3.2. Triệu gọi Transform Các thông số Input: • PIM Model: Tên file của mô hình UML hệ thống. Mô hình này phải áp dụng profile UserManager • Code (PSM) Model: Mô hình code cho project. Đây là mô hình trong đó các class được sinh ra. • Prefix: Prefix trong tên của các table. • Hibernate Directory: Thư mục chứa các class Java do Hibernate Synchronizer sinh ra. • CreateSessionFactory: Check box cho phép người sử dụng chọn sinh ra Class HibernateSessionFactory hay không. • Session Factory Package: Nếu người sử dụng đánh dấu vào Check box “Create SessionFactory”, người sử dụng phải xác định đường dẫn packge đích cho file HibernateSession Factory. Các thông số này có thể được thiết lập trên Eclipse Preferences chuẩn (Windows|Preferences). Ở Preferences Dialog này, tập các thông số có thể được điền trước do đó người phát triển không cần phải nhập các thông số này mỗi khi transformation được triệu gọi. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 104 Hình 3-2: Eclipse Preferences Hình 3-3: Transformation Dialog. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 105 • Quá trình transform bao gồm ba bước, tương ứng với ba checkbox trong Transformation Dialog. o validate: kiểm tra tính hợp lệ các thông số Input o transform: chỉ thực hiện khi validate thành công. Với bất kỳ class nào có apply > kiểm tra xem các method và các attribute của nó có áp dụng các stereotype trong UserManager Profile hay không, nếu có các method quản lý User tương ứng như đã nói ở phần chức năng sẽ được sinh ra. o verify: kiểm tra tính thống nhất giữa model và code sinh ra. • Người sử dụng có thể đánh dấu một trong ba check box để yêu cầu thực hiện từng chức năng tương ứng hoặc đánh dấu cả ba check box để yêu cầu thực hiện cả ba chức năng (validate, transform, verify). o Cho phép áp dụng plugin nhiều lần nếu có chỉnh sửa trên mô hình nguồn. Các phương thức đã sinh ra của mô hình cũ sẽ được thay thế bằng các phương thức tương ứng với mô hình mới đã chỉnh sửa. • Sau khi đã đánh dấu vào các checkbox, nhấn nút OK để thực hiện quá trình sinh code. • Các thông điệp của quá trình sinh code sẽ xuất hiện trên log window của XDE. Do đó, người sử dụng có thể dễ dàng theo dõi và kiểm soát quá trình sinh code Kết quả: -Các method được sinh ra trong file Java Class đã giới thiệu ở trên 3.2.2. Plugin Search 3.2.2.1. Chức năng Hỗ trợ người sử dụng tạo phương thức có chức năng tìm kiếm trong file DAO (là file chứa các chức năng thêm vào ngoài các chức năng cơ bản là load, update, retrieve, delete, thực hiện trên đối tượng mang dữ liệu – transient data, cụ thể trong Hibernate là các file class ánh xạ từ cơ sở dữ liệu lên). • Input: o Mô hình UX của ứng dụng có áp dụng profile SearchProfile. Mô hình này chứa các class có stereotype là > và các attribute có stereotype là >. o Thư mục chứa file ánh xạ có extension là hbm của Hibernate. • Output: Các phương thức có chức năng tìm kiếm trong các file DAO tương ứng. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 106 3.2.2.2. Hiện thực • Platform đích: Hibernate, Java. • Công cụ sử dụng: Rational XDE for Java, MDA Toolkit. • Hiện thực plugin bằng ngôn ngữ Java dựa trên MDA transformation wizard do MDA toolkit cung cấp trên công cụ Rational XDE. Quy trình phát triển • Bước 1: Tạo một plugin-in project sử dụng wizard MDAToolkit Transformation Wizard. • Bước 2: Định nghĩa các danh sách các thông số transform: public static final String P_FILE_SEARCH_MODEL = "searchModelTransformationSearch"; public static final String P_HIBERNATE_DIRECTORY = "HibernateDirectory"; • Bước 3: Định nghĩa các giá trị mặc định cho các thông số transform: setDefault(P_FILE_SEARCH_MODEL,""); setDefault(P_HIBERNATE_DIRECTORY,""); • Bước 4: Định nghĩa các controls GUI cho các thông số transform: addField(new FileFieldEditor(P_FILE_SEARCH_MODEL, "&Search Model file:", parent)); addField(new DirectoryFieldEditor(P_HIBERNATE_DIRECTORY,"Hibernate directory", parent)); • Bước 5: Định nghĩa logic chuyển đổi: được hiện thực trong hàm transform. Sau khi lấy các thông số nhập (đã được validate hoặc chưa được validate, tùy vào người sử dụng có check vào check box Validate hay không, do đó ta vẫn cần thực hiện bước validate trong hàm này), ta sẽ phân tích: o Bước 5.1: phân tích mô hình UX để lấy ra các class có stereotype là Search và các attribute có stereotype là Search Attribute. Kết quả được chứa trong ArrayList với mỗi phần tử trong ArrayList có kiểu là <MdaClass, MdaAttribute[]> (mỗi class Search có một hoặc nhiều attribute Search) o Bước 5.2: phân tích các file ánh xạ hbm để lấy ra các tên class (mỗi class tương ứng với một table trong cơ sở dữ liệu), tên id và tên property thuộc Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 107 class đó. Kết quả được chứa trong ArrayList với mỗi phần tử trong ArrayList có kiểu là . o Bước 5.3: tạo một dialog mới sử dụng các kết quả vừa phân tích được, cho phép người dùng ánh xạ giữa attribute Search và id hoặc property trong class ánh xạ từ CSDL. o Bước 5.4: sau khi người dùng tạo ra các cặp (attributeSearch, id|property), tìm đến các file DAO tương ứng cho các class ánh xạ, tạo các hàm Search trong file này, có dạng : Search (session, SearchParamater) có kiểu trả về là ArrayList Template của nội dung: ArrayList arrRet = null; String hSQL = ""; hSQL = …. arrRet = (ArrayList) (find(hSQL, session)); return arrRet; • Bước 6: Định nghĩa logic validate các thông số do user truyền vào. 3.2.2.3. Hướng dẫn sử dụng • Bước 1: Chuyển vào perspective Modeling, mở mô hình UX của ứng dụng. Vào properties->AppliedProfiles, chọn profile SearchProfile để thêm các stereotype cần thiết cho chuyển đổi Search này. • Bước 2: Trong mô hình UX, chọn các class cần thêm chức năng search. Thêm vào stereotype > cho các class này bằng cách: click chuột vào class -> trong phần properties-> Stereotype, thêm vào “Search”. Thêm vào stereotype > cho attribute bằng cách: click chuột vào attribute->trong phần properties-> Stereotype, thêm vào stereotype >. • Bước 3: Vào menu Transform Æ TransformationSearch (nếu chưa kích hoạt thì vào menu Window -> Customize Perspective. Trong mục Available Items chọn Other, rồi check vào box TransfomationSearchMenus. Nhấn OK.). • Bước 4: Trong TransformationSearch dialog. Nhập Search Model file: nhập đường dẫn đến mô hình UX của ứng dụng. Nhập Hibernate directory: nhập đường dẫn đến thư mục chứa các file hbm của Hibernate. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 108 Hình 3-4: TransformationSearch dialog. • Bước 5: Chọn các action cần được thực hiện (validate: kiểm chứng thông số nhập, transformation: thực hiện transform). • Bước 6: Nhấn OK. Plugin sẽ phân tích mô hình và các file hbm để trích xuất thông tin cho dialog tiếp theo gồm các class (có stereotype là Search) cùng các thuộc tính (có stereotype là SearchAttribute), các class tương ứng với các table cùng với các id, property tương ứng với các column trong table đó. • Bước 7: Trong dialog SelectInfo dialog. Dùng combo ComboSearchAttribute (chứa class Search) và list ListSearchAttribute (chứa attribute Search của class đó) chọn attribute Search trong mô hình UX. Dùng combo ComboTable (chứa thông tin table) và list ListColumn (chứa thông tin column) chọn column muốn ánh xạ với attribute Search. Nhấn Select. Thông tin sẽ lập tức được hiển thị trong list SelectedItems nhằm giúp người dùng dễ dàng theo dõi. Click chuột vào dòng thông tin này, nhấn Remove sẽ loại bỏ được thông tin này. Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 109 Hình 3-5: SelectInfo dialog • Bước 8: Sau khi chọn xong, nhấn button Transform để plugin tạo ra các phương thức trong file DAO. 3.3. Ứng dụng web: WebLog Hiện thực ứng dụng Web sử dụng các công nghệ hỗ trợ ứng dụng Web đã nghiên cứu là UX (phần mô hình), JavaServer Faces, Hibernate (phần code) và các hướng tiếp cận hỗ trợ MDA (code template, transformation plugin): Ứng dụng Web này hiện thực các chức năng sau: • Login vào hệ thống, logout khỏi hện thống, đăng ký làm thành viên. Xem các thông tin (profile) và hiệu chỉnh một số thông tin của mình. • Các chức năng của admin như: xem xét, cập nhật, thêm mới, xóa user của hệ thống… Mô hình của ứng dụng Web được vẽ dựa trên ngôn ngữ UML và mô hình UX như sau: Nghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web 110 Hình 3-6: mô hình UX cho ứng dụng WebLog

Các file đính kèm theo tài liệu này:

  • pdfNghiên cứu và áp dụng công nghệ MDA, các framework hỗ trợ ứng dụng Web.pdf