Spring ra đời với mục đích làm đơn giản hóa, thay thếcác thành phần phức tạp và không quá cần
thiết trong J2EE, mà cụthể đó là EJB - "EJB thì có giá trịcủa nó, nhưng không phải lúc nào cũng
cần thiết và phù hợp cho tất cảcác ứng dụng".
Trong khi EJB thì cứng và cốgắng làm mọi thứ, một vài công việc tốt nhưng một sốthì không.
Spring chỉsửdụng Java Bean và thông qua một sốkỹthuật đặc biệt đểcung cấp nhiều chức năng
nhưEJB, bằng cách tích hợp với một sốkỹthuật open source khác.
Theo kiến trúc đa tầng của J2EE, Spring đảm nhận công việc ởtầng Business. Đểsửdụng Spring
theo J2EE cần kết hợp với các framework ởcác tầng liên quan là: tầng Presentation (Struts,
JSF,.), và tầng Persistence (Hibernate, JDBC,.). Thực tếSpring cũng hỗtrợcho các tầng
Presentation và Persistence, nhưng khảnăng không bằng các framework khác nhưStruts, JSF,
Hibernate,.
66 trang |
Chia sẻ: tlsuongmuoi | Lượt xem: 4094 | Lượt tải: 4
Bạn đang xem trước 20 trang tài liệu Một số vấn đề về công nghệ Java, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
TP (Request/Response, POST/GET Method)
• Servlet Configuration: Khởi tạo một số thông tin cấu hình cần thiết cho Servlet, cho ứng
dụng web
• Servlet Context: Khởi tạo một số tham số cho Servlet, cho ứng dụng web
• Thư viện hỗ trợ: javax.servlet,*; javax.servlet.http.*;
4.1.3. JSP
a. Đặc điểm
JSP ra đời nhằm cải tiến hạn chế của Servlet trong vấn đề thiết kế giao diện của ứng dụng. Bản
thân JSP là các trang HTML có nhúng mã Java để thực hiện các thao tác nghiệp vụ, kết nối
CSDL,... Khác với trang web truyền thống được WebServer gửi trực tiếp cho Client, các trang JSP
phải được thi hành thông qua Engine (JSP Container), ở đó các mã Java được tách ra, xử lý, kết
quả chuyển thành HTML trước khi trả về cho Client.
Thực tế mọi trang JSP đều được dịch sang Servlet và được thực thi trong WebServer, đây chính là
mối quan hệ mật thiết giữa Servlet và JSP như đã đề cập ở trên.
Các đặc điểm nổi bật của JSP:
• Mang đầy đủ những ưu điểm của ngôn ngữ Java
• Mang đầy đủ những ưu điểm của Servlet
Java overview
Trang 30/66
• Giúp cho quá trình phát triển, triển khai, bảo trì ứng dụng Web được dễ dàng hơn
• Đơn giản quá trình phát triển với các thẻ, thư viện: taglib, bean,...
b. Các vấn đề liên quan tới JSP
• WebServer hỗ trợ JSP (Tomcat)
• Vòng đời JSP: Init, Service, Destroy
• Giao thức HTTP (Request/Response, POST/GET Method)
• Các thẻ JSP
• Sử dụng taglib trong JSP >> độc lập design giao diện
• Các đối tượng "ngầm" trong JSP
4.1.4. Quan hệ Servlet, JSP
a. Sự khác nhau
• Phong cách viết mã: Pure Java Nhúng mã Java.
• Servlet phải dịch sang class, JSP được WebServer đảm nhận.
• JSP chỉ là một phiên bản đơn giản của Servlet, được compile ra Servlet
• JSP mềm dẻo hơn Servlet
b. Kết hợp Servlet, JSP
Client gửi yêu cầu tới WebServer, Servlet tiếp nhận, xử lý yêu cầu trả lại kết quả vào trong bean.
JSP truy xuất bean, gửi kết quả (HTML) tới Client.
4.2. JavaScript, CSS, Ajax
4.2.1. JavaScript
Hãng Netscape đã đưa ra ngôn ngữ script có tên là LiveScript để thực hiện chức năng đáp ứng
yêu cầu từ phía người dùng. Sau đó ngôn ngữ này được đổi tên thành JavaScript để tận dụng tính
đại chúng của ngôn ngữ lập trình Java. Mặc dù có những điểm tương đồng giữa Java và
JavaScript, nhưng chúng vẫn là hai ngôn ngữ riêng biệt.
JavaScript là ngôn ngữ dưới dạng script có thể gắn với các file HTML. Nó không được biên dịch
mà được trình duyệt diễn dịch. Không giống Java phải chuyển thành các mã dễ biên dịch, trình
duyệt đọc JavaScript dưới dạng mã nguồn.
Tuy không phải là ngôn ngữ hướng đối tượng do không hỗ trợ các lớp, không có tính kế thừa
nhưng JavaScript cũng được viết dựa trên các đối tượng. Và giống như Java, JavaScript độc lập
với hệ nền, nó có thể chạy trên bất cứ OS nào có trình duyệt hỗ trợ nó.
Hiện nay JavaScript được dùng chủ yếu nhúng trong các file HTML nhằm:
Java overview
Trang 31/66
• Kiểm tra dữ liệu ở phía Client. Việc kiểm tra dùng JavaScript như vậy sẽ nhanh chóng, tăng
tốc độ ứng dụng nhưng cần chú ý đến khả năng hỗ trợ JavaScript của trình duyệt
• Nâng cao tính mỹ thuật của trang web nhờ các hiệu ứng do JS tạo ra
Các vấn đề liên quan:
• Mô hình đối tượng khi sử dụng JavaScript (DOM, JDOM,...)
• Xử lý sự kiện của các đối tượng form
• Validate dữ liệu
• Popup windows
• Các hàm chuẩn: alert(), confirms(), prompts()
4.2.2. CSS
CSS (Cascading Style Sheet) hiện có thể coi là các chuẩn định kiểu cho các trang web. Về căn bản
đây là một tập khai báo về thuốc tính của các đối tượng trên một trang web. Hầu như tất cả các đối
tượng trên trang web đều có thể khai báo thuộc tính, từ các label, text đến các button, table. Thuộc
tính có thể là font, size, color,...
Việc dùng CSS sẽ giúp cải thiện tốc độ tải trang web đáng kể. Trình duyệt sẽ chỉ tải file CSS về
máy client một lần, những lần sau các trang web sử dụng file CSS này sẽ lấy ngay tại client. Việc
tập trung toàn bộ định nghĩa thuộc tính vào file CSS giúp cho đoạn mã HTML trở nên ngắn gọn, rõ
ràng đồng thời giúp giảm kích thước của trang web.
CSS có thể khai báo ngay trong file HTML nhưng thông thường CSS được khai báo trong một hay
nhiều file (.CSS) thành các class. Các đối tượng trong trang web muốn sử dụng class nào thì khai
báo trong thuộc tính class. Điều này tăng tính mềm dẻo khi dùng file CSS, ta có thể thay đổi màu
sắc, giao diện của những trang web một cách nhanh chóng thông qua việc chỉnh sửa những thuộc
tính trong file CSS.
Khai báo CSS:
Sử dụng CSS:
Java overview
Trang 32/66
Các vấn đề liên quan:
• Các thuộc tính của đối tượng Form (tham khảo tại W3C)
4.2.3. Ajax
a. Khái niệm về Ajax
Ajax là thuật ngữ công nghệ được nhắc tới nhiều trong một vài năm gần đây xung quanh các vấn
đề liên quan tới thế hệ Web2.0, chính xác là từ tháng 2 năm 2005 sau bài viết nổi tiếng của Jesse
James Garrett trên trang Adaptive Path. Nhưng thực sự Ajax không phải là một công nghệ, nó là
sự kết hợp của nhiều công nghệ với mỗi thế mạnh riêng của mình để tạo nên sức mạnh chung của
Ajax.
Đúng như tên viết tắt của mình, AJAX - " Asynchronous JavaScript and XML ", cũng có tài liệu cho
rằng "Asynchronous JavaScript+CSS+DOM+XMLHttpRequest" là sự kết hợp của các công nghệ
sau:
• Thể hiện web theo tiêu chuẩn XHTML và CSS;
• Nâng cao tính năng động và phản hồi bằng DOM (Document Object Model );
• Trao đổi và xử lý dữ liệu bằng XML và XSLT;
• Truy cập dữ liệu theo kiểu bất đồng bộ (asynchronous) bằng XMLHttpRequest;
• Và tất cả các kỹ thuật trên được liên kết lại với nhau bằng JavaScript .
Tất cả tạo thành một bộ công cụ cho phép tăng tốc độ ứng dụng web bằng cách chia nhỏ dữ liệu
trên trang web thành nhiều phần và load lại phần thông tin cần thay đổi, thay vì tải đi tải lại toàn bộ
trang web.
"Mọi thao tác của người sử dụng sẽ gửi lệnh JavaScript tới bộ xử lý AJAX, thay vì tạo ra một yêu
cầu HTTP (HTTP request) và truy vấn tới máy chủ", Jesse James Garrett đã ghi trong bài viết đầu
tiên định nghĩa về thuật ngữ này. "Nếu cần gì từ server, như tải về bổ sung mã giao diện hay nhận
dữ liệu mới, AJAX sẽ truyền yêu cầu tới máy chủ một cách không đồng bộ, thông thường sử dụng
XML, mà không làm gián đoạn sự tương tác của người dùng với ứng dụng web".
b. Mô hình hoạt động của Ajax
Với mô hình ứng dụng Web cổ điển, khi người dùng có một cần thay đổi dữ liệu trên trang Web,
yêu cầu thay đổi được gửi về server dưới dạng HTTP request (hay còn gọi postback), server sẽ xử
lý yêu cầu này và gửi trả lại trang HTML khác thay thế trang cũ. Qui trình này được mô tả là nhấp-
chờ và tải lại (click-wait-and-refresh)
Java overview
Trang 33/66
Với mô hình ứng dụng Web sử dụng Ajax, thay vì phải tải cả trang web thì với ứng dụng chỉ cần tải
về phần của trang Web được thay đổi nội dung. Điều này giúp cho ứng dụng web phản hồi nhanh
hơn. Ngoài ra, điểm đặc biệt quan trọng trong công nghệ AJAX nằm ở chữ A (Asynchronous) – bất
đồng bộ – tức là client cứ gửi yêu cầu tới server và quay lại với công việc của mình mà không cần
chờ trả lời. Khi nào server xử lý xong yêu cầu, nó sẽ báo hiệu để thể hiện những thay đổi cần thiết.
c. Nhược điểm của Ajax
Mặc dù Ajax có những đặc điểm vượt trội mang tính cách mạng cho các ứng dụng web, nhưng nó
cũng có một số nhược điểm sau:
• Phím "Back" (được đánh giá rất cao trong thao tác của người sử dụng web) của trình duyệt
bị mất tác dụng, người dùng không thể lấy lại dữ liệu của trang trước đó bằng cách đơn
giản, thông thường như trước đây vẫn dùng (đã có hướng giải quyết).
• Không thể lưu lại địa chỉ web vào thư mục Favorite (Bookmark) để xem lại về sau.
• Do áp dụng lớp trung gian để giao dịch, các ứng dụng AJAX không có một địa chỉ cố định
cho từng nội dung.
• Vấn đề bảo mật khi ứng dụng có dùng Ajax
Java overview
Trang 34/66
4.3. AWT, Swing
AWT và Swing là hai components GUI dùng cho các ứng dụng Java Desktop được Sun phát triển
trong bộ thư viện JFC (Phần 3.1.2). Phần này chủ yêu đi sâu vào các nội dung của Swing, bộ thư
viện GUI Java mạnh nhất hiện nay.
4.3.1. AWT
AWT (Abstract Window Toolkit) là bộ thư viện hỗ trợ giao diện đồ họa GUI đầu tiên của Sun. Hiện
tại AWT chỉ phù hợp cho các ứng dụng GUI đơn giản, hoặc các ứng dụng Applet.
Đặc điểm của AWT:
• Tập hợp rất nhiều thành phần GUI
• Mô hình bắt sự kiện mạnh
• Quản lý Layout, giúp cho các thành phần của ứng dụng độc lập với kích cỡ, độ phân giải
• Cung cấp các lớp truyền dữ liệu với Clipboard
• package: java.awt
Hệ thống phân cấp các thành phần trong AWT
Quản lý Layout
Xử lý sự kiện
Deploy ứng dụng
4.3.2. Swing
a. Đặc điểm
Swing ra đời sau AWT, có các đặc điểm sau:
• Mang tất cả các đặc điểm của AWT
• Mã thuần Java với các components AWT (Button, Toolbar,...)
• Bổ sung một tập các components bậc cao (ListView, TreeView, Tab,...)
• Hỗ trợ Look and Feel độc lập với OS
• package: javax.swing
b. Các Swing components
Các components trong Swing được chia thành:
• Windows: Window, Frame, Dialog,...
• Container: Các components đặc biệt có thể giữ (chứa) và quản lý các components khác
• Components thông dụng: Button, TextField, CheckBox,...
• Các components bậc cao: TreeView, ListView, DateTimePicker,...
Mỗi components là một đối tượng GUI, được tổ chức theo cấu trúc phân cấp như sau:
Java overview
Trang 35/66
c. Quản lý Layout
Quản lý Layout là việc đảm nhận quản lý thông tin về vị trí, kích thước các thành phần của ứng
dụng (trong khu vực Container). Với việc sử dụng Layout, kính thước, vị trí của các thành phần GUI
không phụ thuộc vào độ phân giải của màn hình bởi vì Layout quản lý, bố trí các components trên
Form theo một sự ràng buộc không hoàn toàn phụ thuốc vào tọa độ.
Java overview
Trang 36/66
Swing hỗ trợ các kiểu Layout sau:
• Flow Layout
• Border Layout
• Card Layout
• Grid Layout
• GridBag Layout
• Định nghĩa Layout của riêng mình
d. Xử lý sự kiện
Quản lý việc giao tiếp giữa các thành phần GUI trong ứng dụng, giao tiếp giữa người sử dụng với
các thành phần của một Form, ví dụ:
• KeyEvent: Sự kiện nhấn phím
• MouseEvent: Sự kiến nhấn chuột
• WindowEvent: Sự kiện liên quan tới Close, Open, Zoom một cửa sổ WIndow,..
• ...
Mọi sự kiện đều được kế thừa từ lớp EventObject.
e. Deploy ứng dụng
Đóng gói, triển khai ứng dụng Desktop (Phần 2.4).
4.3.3. AWT vs Swing
Components AWT Swing
Pros
- Tốc độ
- Hỗ trợ applet nhúng trên Browser
- Look and Feel của OS
- Tính thẩm mỹ cao hơn AWT, nhiều
components hơn AWT
- Look and Feel độc lập OS
Cons
- Tính cơ động không cao do một số
components phụ thuộc platform
- Không hỗ trợ một số thuộc tính như
icons, tooltip
- Một số Browser không hỗ trợ
- Tốc độ chậm hơn AWT
4.4. Mô hình MVC
Khi xây dựng ứng dụng phần mềm thì người phát triển thường tiếp cận theo cách là xây dựng ứng
dụng theo một mô hình nào đó, và mô hình này được xây dựng trước, mô hình này giúp người
phát triển không phải lo lắng về cấu trúc chương trình vì mô hình đã được dựng sẳn, họ chỉ phải
thực hiện các module nghiệp vụ. MVC là mô hình nổi tiếng cho các ứng dụng xây dựng trên nền
Java, từ các ứng dụng Web thông thường tới các ứng dụng J2EE, hay Desktop. Vai trò và ưu điểm
của MVC sẽ dễ thấy hơn nếu chúng ta xem xét tới các mô hình dành cho ứng dụng web trên
Servlet, JSP.
Java overview
Trang 37/66
4.4.1. Mô hình ứng dụng Web với Servlet, JSP
Khi xây dựng ứng dụng web bằng Servlet, JSP thì người phát triển thường dựa trên 2 mô hình sau,
tạm gọi là mô hình 1 và mô hình 2:
Hai mô hình có một số điểm khác biệt. Sự khác biệt rõ ràng nhất đó là sự khác biệt về thành phần
xử lý request.
Với mô hình 1 thì trang JSP điều khiển mọi quá trình xử lý request và đồng thời cũng là nơi hiển thị
phía client giá trị trã về của server.
Trong mô hình 1 ở trên không xuất hiện servlet trong quá trình xử lý. Request của client được gửi
trực tiếp tới trang JSP, trang JSP này có thể giao tiếp với các JavaBean hoặc một vài dịch vụ khác,
và cuối cùng nó chọn trang JSP tiếp theo cho client. Trang tiếp theo để hiển thị giá trị trã về của
server.
Trong mô hình 2, request từ phía client đầu tiên sẽ được chặn lại tại servlet, và bộ phận này người
ta gọi là servlet điều khiển. Servlet sẽ thực hiện một số xử lý ban đầu của request và cũng xác định
trang hiển thị tiếp theo. Hình sau:
Trong mô hình 2, client không bao giờ gửi trực tiếp request tới một trang JSP. Servlet điều khiển sẽ
thực hiện như là bộ phận điều khiển giao thông. Điều này cho phép servlet thực hiện xử lý theo
kiểu “front - end” – giống như là kiểm chứng và cho phép. Ta có thể hiểu, servlet như là bộ kiểm tra
request sau đó tuỳ theo kết quả mà quyết định bước xử lý tiếp theo của request. Khi quá trình xử lý
request tại servlet hoàn thành, servlet sẽ chuyển request trực tiếp tới trang JSP phù hợp. Ví dụ,
trong một ứng dụng web đơn giản, trang JSP sẽ hiển thị kết quả của trã về của servlet, kết quả đó
là các tham số trong request.
Java overview
Trang 38/66
4.4.2. Mô hình MVC
Với mô hình 2 trong các ứng dụng web ta thấy sự phân chia các bộ phận trong kiến trúc rõ ràng
hơn, đó là ba thành phần: logic nghiệp vụ, phần hiển thị, và bộ phần xử lý request. Sự phân chia
này được gọi là mô hình Model – View – Controller (MVC). Các ứng dụng (không chỉ là ứng dụng
web) xây dựng trên mô hình MVC có ưu điểm là rất dễ bảo trì và có thể mở rộng với các ứng dụng
phức tạp.
MVC là kỹ thuật được sử dụng rộng rãi trong lập trình chuyên nghiệp, đặc biệt là trong kỹ thuật làm
web, tạo cho website có khả năng linh động hơn. Thực tế có rất nhiều lập trình viên phát triển ứng
dụng của mình theo mô hình MVC dù đó là bất kỳ ngôn ngữ nào.
a. Model
Là một đối tượng hoặc tập hợp các đối tượng biểu diễn cho phần dữ liệu của chương trình, ví dụ
các dữ liệu được lưu trong cơ sở dữ liệu (CSDL) hay từ các hệ thống ứng dụng khác (như mail...).
Java overview
Trang 39/66
b. View
Là phần giao diện với người dùng, bao gồm việc hiện dữ liệu ra màn hình, cung cấp các menu, nút
bấm, hộp đối thoại, chọn lựa..., để người dùng có thể thêm, xóa, sửa, tìm kiếm và làm các thao tác
khác đối với dữ liệu trong hệ thống.
View trong mô hình MVC của ứng dụng web bao gồm HTML và các trang JSP. Các trang HTML
được dùng với mục đích tạo ra trang tĩnh, trong khi JSP có thể tạo ra trang với nội dung tĩnh hay
động.
c. Controller
Là phần điều khiển toàn bộ logic về hoạt động của giao diện, tương tác với thao tác của người
dùng (từ chuột, bàn phím và các thiết bị ngoại vi khác) và cập nhật, thao tác trên dữ liệu theo đầu
vào nhận được và điều khiển việc chọn phần “View” thích hợp để chuyển dữ liệu tới người dùng.
Trong ứng dụng web, Controller thường được thiết kế bằng Servlet, thực hiện các nhiệm sau:
• Chặn các request từ phía client.
• Chuyển các request tới các bộ phận dịch vụ để thực hiện.
• Hoặc là gọi các toán tử nghiệp vụ hoặc là uỷ thác tới một handler khác.
• Hổ trợ lựa chọn view tiếp theo cho client.
• Trã về view cho client.
4.5. Struts
4.5.1. Struts và MVC
Struts là một Framework OpenSource nổi tiếng của dự án Apache cho các ứng dụng J2EE. Được
phát triển bởi một nhóm do Craige R.McClanahan đứng đầu (Craige R.McClanahan là chuyên gia
nghiên cứu về Servlet, JSP và tham gia viết Tomcat), bản thân Struts là sự mở rộng của các
Java overview
Trang 40/66
Servlet API theo mô hình MVC. Thực tế hiện nay Struts vẫn là framework nổi tiếng nhất cho các
ứng dụng theo mô hình MVC.
Mục đích của Struts là phân tách rõ ràng các phần Model, View, Controller trong mô hình MVC.
Ứng dụng viết trên Struts dễ dàng bảo trì, mở rộng. Struts framework liên tục được cập nhật, mở
rộng cung cấp nhiều package, thư viện hỗ trợ cho người phát triển: Taglib, đa ngôn ngữ, validate
data, tempate cho ứng dụng mẫu,...
• Client Browser: Web Container tiếp nhận HTTP Request từ Client và trả về HTTP Response
• Controller: Các nhiệm vụ của thành phần Controller trong Struts bao gồm nhận đầu vào từ
client, gọi toán tử nghiệp vụ, và tìm thành phần view để trã về cho phía client. Trong Struts
framework servlet trở thành điểm trung tâm cho ứng dụng web. Servlet điều khiển sẽ ánh xạ
giữa action của user với các hàm nghiệp vụ và hổ trợ lựa chọn view trã về dựa trên thông
tin của request đã được xử lý. struts-config.xml là file cấu hình cho Controller của ứng dụng
xây dựng trên Struts
• Business Logic: Cập nhật trạng thái của Model và đảm nhận việc điều khiển, thực thi dưới
các Form trong ứng dụng
• Model: Model là các đối tượng biểu thị thông tin về các yêu cầu từ người dùng, và lưu giữ
các kết quả của các quá trình xử lý.
• View: Đối tượng View trong Struts thường là các trang JSP. Struts cung cấp một loạt các
thư viện taglib, hỗ trợ người phát triển trong việc thiết kế các trang JSP. Sự hỗ trợ của
Struts với JSP cho phép các đối tượng form trên các trang JSP được quản lý: Lấy dữ liệu,
Validate dữ liệu, Quản lý lỗi,... Các thư viện taglib thường dùng: struts-html, struts-form,
struts-bean, struts-logic, struts-template.
4.5.2. Đặc điểm của Struts
• OpenSource, cộng đồng đông đảo
• Áp dụng mô hình MVC
• Struts là framework cho ứng dụng web, không phải ứng dụng J2EE: (Triển khai theo dạng
file .WAR cho các Web Server)
• Áp dụng Struts khá dễ dàng, đơn giản: Download Struts framework (hiện là version 2.0.6 -
March 22, 2007), cấu hình ứng dụng với các thư viện (Nhiều IDE hỗ trợ)
• Bộ thư viện thẻ taglib phong phú cho JSP. Hỗ trợ validate dữ liệu, thông báo lỗi,...
Java overview
Trang 41/66
• Thuận lợi cho công tác bảo trì, nâng cấp
• Struts chỉ hướng vào tầng Controller, có quan điểm là chỉ hướng vào tầng View (Bản thân
chỉ là sự mở rộng của Servlet & JSP)
• Quan điểm về bộ thư viện taglib của Struts: phải load toàn bộ >> tốn bộ nhớ, ứng dụng
chạy chậm,...
• Struts JSF
• Dự án Struts đã đóng băng (hay đã hoàn thiện ở mức chín muồi)
4.5.3. Cấu hình ứng dụng Struts
Ví dụ về tổ chức của một ứng dụng dựa trên Struts:
Bên cạnh file cấu hình web.xml cho ứng dụng web thông thường, ứng dụng Struts còn có struts-
config.xml là file cấu hình để khởi tạo các tài nguyên cần thiết, bao gồm thông số kết nối CSDL các
ActionForms để lấy các yêu cầu của người dùng, ActionMappings để chỉ đến các Actions phía trình
phục vụ Server, và các ActionForward để chọn các trang hiển thị. Ngoài ra còn có các file mô tả thư
viện taglib của ứng dụng (các file .TLD).
Dưới đây là một dạng đơn giản của struts-config.xml:
• : Thông số kết nối CSDL
• : Khai báo các form của ứng dụng
Java overview
Trang 42/66
• : Các trang jsp hiển thị
• : Khai báo các Action
• Một số thẻ khác
Java overview
Trang 43/66
4.6. EJB
4.6.1. EJB trong kiến trúc J2EE
EJB (Enterprise JavaBean) là business component chạy bên trong EJB container, là một thành
phần trong kiến trúc. EJB container cung cấp các dịch vụ quản lý transaction, bảo mật, quản lý
trạng thái, quay vòng tài nguyên,... EJB container hỗ trợ những API sau: J2SE, JMS, JNDI, JTA,
JavaMail, JAF, RIM-IIOP và JDBC.
Các lợi ích mà EJB mang lại:
• Transaction Management
• Security support
• Persistence Management (CMP & BMP)
• Distributed System
4.6.2. Khi nào sử dụng EJB
Mặc dù EJB mạnh, có nhiều giá trị, nhưng vì là một công nghệ phức tạp, áp dụng khá khó khăn,
nên sử dụng EJB trong những trường hợp sau:
• Dùng cho các ứng dụng lớn, tài nguyên & dữ liệu phân tán
• Yêu cầu dễ dàng đáp ứng được sự mở rộng, nâng cấp của hệ thống (Scalable)
• Các giao dịch yêu cầu sự đảm bảo cao về tính toàn vẹn dữ liệu
• Số lượng Client lớn
Java overview
Trang 44/66
4.6.3. Cài đặt EJB
Mỗi EJB bắt buộc phải có những interface và class sau:
• Home Interface: home interface extend javax.ejb.EJBHome. Nó đóng vai trò như một
Factory pattern để khởi tạo các instance của EJB
• Remote Interface: remote interface extend javax.ejb.EJBObject. Remote interface chứa các
business method, được gọi từ client. Nó đóng vai trò như 1 proxy của EJB.
• Bean Class: chứa phần cài đặt của các method khai báo trong remote interface. Bean class
extend javax.ejb.SessionBean hoặc javax.ejb.EntityBean hoặc
javax.ejb.MessageDrivenBean.
Quy ước đặt tên Bean:
Java overview
Trang 45/66
4.6.4. Phân loại EJB
Tùy vào mục đích sử dụng, EJB được chia thành 3 loại như sau:
Java overview
Trang 46/66
a. Entity Bean
Bean này dùng để mô tả một thực thể trong hệ thống, thiết kế chuyên dụng để phục vụ cho việc
persistence và sharing dữ liệu. Mỗi Entity Bean tương ứng với một dòng trong bảng của CSDL.
- CMP: Container-Managed Persistence
- BMP: Bean-Managed Persistence
Khi nào dùng Entity Bean?
• Cần thể hiện thực thể nghiệp vụ, không phải hàm, thủ tục
• Trạng thái của Bean cần được duy trì
b. Session Bean
Phục vụ cho các yêu cầu xử lý nghiệp vụ và luồng công việc trong ứng dụng J2EE thông qua các
phương thức của mình. Session Bean không có tính Persistent, dữ liệu của nó không được lưu vào
CSDL.
Khi nào sử dụng Session Bean?
• Tại một thời điểm, chỉ có một Client truy cập tới thể hiện của Bean
• Trạng thái của Bean chỉ tồn tại trong một thời gian ngắn, không cần phải duy trì
• Bean được thực thi như Web Services
Session Bean được chia làm 2 loại là Stateless và Statefule
Java overview
Trang 47/66
- Stateless Session Bean
Không lưu giữ trạng thái giữa các phương thức xử lý cho các Clients. Sau mỗi phương thức được
gọi, EJB Container có thể chọn việc hủy bỏ hoặc tạo mới Stateless Session Bean.
Khi nào dùng Stateless Session Bean?
• Trạng thái của Bean không lưu dữ liệu cho một Client cụ thể
• Cần có phương thức chung cho nhiều Client
- Stateful Session Bean
Là Bean được thiết kế để thực hiện các xử lý nghiệp vụ yêu cầu phải qua nhiều phương thức,
nhiều giao dịch, do đó yêu cầu Statefule Session Bean phải lưu giữ trạng thái của từng Client khi
nó xử lý.
Khi nào dùng Stateful Session Bean?
• Trạng thái của Bean thể hiện sự tương tác giữa Bean và một Client cụ thể
• Cần thiết phải ghi nhớ thông tin về Client giữa các phương thức thực hiện
Java overview
Trang 48/66
• Dùng Bean để quản lý luồng xử lý nghiệp vụ giữa các thành phần Bean khác trong ứng
dụng
c. Message-Driven Bean
Là một Stateless Session Bean đặc biệt. Được sử dụng trong trường hợp các nghiệp vụ của ứng
dụng đòi hỏi phải có thời gian thực thi lâu khi Client không thể chờ để hiển thị kết quả. Điều đặc
biệt là Message-Driven Bean được thực thi thông qua việc gửi các thông điệp tới JMS (Java
Message Service). Bên cạnh đó, Message-Driven Bean là loại asynchronous service trong khi
Entity và Session là loại synchronous service.
Riêng Message-Driven Bean không đòi hỏi có Interface.
Khi nào dùng Message-Driven Bean?
• Khi cần truyền nhận thông điệp một cách bất đồng bộ
4.7. Spring
Spring ra đời với mục đích làm đơn giản hóa, thay thế các thành phần phức tạp và không quá cần
thiết trong J2EE, mà cụ thể đó là EJB - "EJB thì có giá trị của nó, nhưng không phải lúc nào cũng
cần thiết và phù hợp cho tất cả các ứng dụng".
Trong khi EJB thì cứng và cố gắng làm mọi thứ, một vài công việc tốt nhưng một số thì không.
Spring chỉ sử dụng Java Bean và thông qua một số kỹ thuật đặc biệt để cung cấp nhiều chức năng
như EJB, bằng cách tích hợp với một số kỹ thuật open source khác.
Theo kiến trúc đa tầng của J2EE, Spring đảm nhận công việc ở tầng Business. Để sử dụng Spring
theo J2EE cần kết hợp với các framework ở các tầng liên quan là: tầng Presentation (Struts,
JSF,...), và tầng Persistence (Hibernate, JDBC,...). Thực tế Spring cũng hỗ trợ cho các tầng
Presentation và Persistence, nhưng khả năng không bằng các framework khác như Struts, JSF,
Hibernate,...
Java overview
Trang 49/66
4.7.1. Đặc điểm của Spring
• Nguyên lý chính yếu của Spring đó là sử dụng kỹ thuật IoC (Inversion of Control) hay còn
gọi là kỹ thuật Dependency Injection. Đây là kỹ thuật làm mềm dẻo hóa mối quan hệ giữa
các lớp phụ thuộc lẫn nhau (Mong muốn "Loose coupling" thay cho "Strong coupling"). (Cái
này rất khó diễn đạt bằng tiếng Việt)
• Spring hỗ trợ lập trình hướng khía cạnh AOP.
• Ngoài việc cung cấp một framework mạnh, Spring còn được thiết kế để hỗ trợ người phát
triển dễ dàng tích hợp các framework ở các tầng khác trong ứng dụng J2EE: Web
framework, Persistent framework,... (Spring cung cấp ~ 1000 lớp/interface cho mục đích kết
nối với các framework khác)
• Bản thân Spring cung cấp nhiều giao diện có sẵn, giúp cho dễ dàng mở rộng và chỉnh sửa
ứng dụng.
• Với Spring công đoạn Test được thực hiện dễ dàng hơn (Không cần start EJB Container khi
Test như các ứng dụng EJB)
• Spring dựa trên các đối tượng JavaBean với các phương thức setter, getter. Tuy nhiên
Spring không khởi tạo các đối tượng như cách truyền thống (Obj obj = new Obj()) mà sử
dụng phương thức khởi tạo bằng các FactoryContainer dựng sẵn, thuộc tính các đối tượng
được config trong các file XML (bean.xml).
Các bước thực hiện cho một chức năng trong Spring:
1. Khai báo interface định nghĩa các chức năng.
2. Một implementation chứa các thuộc tính, các phương thức settter và getter.
3. Một file XML gọi là file cấu hình Spring.
4. Chương trình client sử dụng chức năng trên.
Download information: www.springframework.org
Phiên bản dependency (full)
1. Source Code
2. Library (Test, Integration,...)
3. Document
4. Samples
4.7.2. Các thành phần của Spring
Spring cung cấp nền tảng gồm 7 modules (trong các file thư viện JAR) như sau. Tất nhiên, người
phát triển có thể mềm dẻo lựa chọn sử dụng bao nhiêu module, và sử dụng những module nào cho
phù hợp với ứng dụng của mình.
Java overview
Trang 50/66
a. Spring Core
Cung cấp chức năng cơ bản của Spring. Thành phần chính của nó là Bean Factory, một cài đặt
của Factory pattern. BeanFactory áp dụng IoC hay Dependency Injection để đặc tả sự phụ thuộc từ
code của ứng dụng.
b. Spring Context
Spring Context là một file cấu hình để cung cấp thông tin ngữ cảnh của Spring. Spring context cung
cấp các service như JNDI access, EJB integration, e-mail, internalization (i18N), validation, và
scheduling functionality, truyền sự kiện, resource-loading,...
c. Spring DAO
Quản lý kết nối đến database, điều khiển exception và thông báo lỗi database. Giúp cho đơn giản
điều khiển lỗi và giảm khối lượng code mà chúng ta cần viết như mở và đóng kết nối. Module này
cũng cung cấp các dịch vụ quản lý giao dịch cho các đối tượng trong ứng dụng Spring.
d. Spring AOP
Spring AOP module tích hợp chức năng lập trình hướng khía cạnh (Aspect Oriented Programming)
vào Spring framework thông qua cấu hình của nó. Spring AOP module cung cấp các dịch vụ quản
lý giao dịch cho các đối tượng trong bất kỳ ứng dụng nào sử dụng Spring. Với Spring AOP chúng
ta có thể tích hợp declarative transaction management vào trong ứng dụng mà không cần dựa vào
EJB component. Spring AOP module cũng đưa lập trình metadata vào trong Spring.
e. Spring ORM
Spring có thể tích hợp với một vài ORM framework để cung cấp Object Relation Tool bao gồm:
JDO, Hibernate, OJB và iBatis SQL Maps.
f. Spring Web
Khởi tạo context cho các ứng dụng web. Spring cũng hỗ trợ tích hợp với Struts, JSF và Webwork.
Web module cũng làm giảm bớt các công việc điều khiển nhiều request và gắn các tham số của
request vào các đối tượng domain.
Java overview
Trang 51/66
g. Spring MVC
Cài đặt đầy đủ đặc tính của MVC pattern để xây dựng các ứng dụng Web. Spring MVC framework
hỗ trợ một số kỹ thuật view bao gồm: JSP, Velocity, Tiles,... File cấu hình cho phép lựa chọn cái
nào trong số các kỹ thuật trên được sử dụng, trong đó JSP là giao diện mặc định.
4.8. Hibernate
4.8.1. Giới thiệu về Hibernate
Hibernate là giải pháp ORM (Object/Relational mapping) OpenSource cho các ứng dụng Java,
cung cấp một framework cho việc mapping giữa mô hình hướng đối tượng và các CSDL quan hệ
truyền thống.
• Hibernate tuân thủ theo kiến trúc J2EE
• Việc quy trì kết nối dữ liệu được làm mờ với người phát triển. Hibernate đảm nhận các công
việc của Presistence Layer trong mô hình đa lớp
• Sử dụng các tài liệu XML để cấu hình kết nối dữ liệu và mapping giữa các lớp đối tượng
Java và các bảng trong CSDL
• Sử dụng ngôn ngữ truy vấn dữ liệu hướng đối tượng mạnh, cú pháp rất giống với ngôn ngữ
chuẩn SQL
• Hạn chế việc lặp lại các câu lệnh SQL
• Thao tác với các lớp và đối tượng, thay vì query, resultset,... Việc phát triển "Hướng đối
tượng hơn"
Java overview
Trang 52/66
4.8.2. Kiến trúc Hibernate
a. Hibernate Session
Được hình thành từ SessionFactory, Session thể hiện nội dung được duy trì của Hibernate. Do đó
Session được sử dụng để query, cũng như các thao tác insert, update, delete trên dữ liệu.
b. Hibernate Persistent Object
Là các đối tượng lưu giữ trạng thái, và các hàm nghiệp vụ. Các đối tượng này thường là JavaBean
hoặc POJO (Plain Old Java Obiect). Các đối tượng Persistence được sử dụng cùng với Session,
khi Session đóng, chúng được giải phóng và sẵn sàng phục vụ cho tầng ứng dụng.
c. Transaction & Connection
(Option)
d. Connector
Ngoài JDBC, Hibernate hỗ trợ một số Connector trong một số trường hợp kết nối đặc biệt khác, ví
dụ: JTA trong trường hợp kết nối tới nhiều CSDL,...
Java overview
Trang 53/66
4.8.3. Phát triển ứng dụng với Hibernate
• Mỗi bảng trong CSDL quan hệ tương ứng với một lớp đối tượng của ứng dụng, do đó cần
có một Bean cho mỗi bảng trong CSDL
• Để Hibernate biết một object được mapping như thế nào với table trong CSDL, phải cung
cấp tập tin đặc tả gọi là mapping file giữa property của object với field trong table. Theo quy
ước của Hibernate, các mapping file này có đuôi là .hbm.xml và phải hợp lệ với DTD
(Document Type Definition) mà Hibernate đã đưa ra. Trong các mapping file này.
• Cuối cùng cần có 1 tập tin để Hibernate bắt đầu: hibernate.cfg.xml. Có thể nói tập tin này
được load lên đầu tiên khi “khởi động” Hibernate.
a. Persistent Object
- PÔJO file với các thuộc tính (tương ứng các field trong CSDL)
- Các phương thức get/set.
b. Configuration
- hibernate.xml
- hibernate.cfg.xml
- Person.hbm.xml
c. HQL - Hibernate Query Language
- Ngôn ngữ truy vấn hướng đối tượng
- Cú pháp gần với SQL
- Creating Object
- Updating Object
- Deleting Object
- Selecting Object
Java overview
Trang 54/66
4.9. Web Services
4.9.1. Lịch sử hình thành Web Services
Mong muốn về sự giao tiếp giữa các đối tượng từ xa, trong ứng dụng phân tán đã dẫn đến sự hình
thành một số công nghệ mang tính "phân tán" như COM, COM+, CORBA, Java RMI,... Tuy nhiên
đây là các công nghệ độc quyền của một hãng nào đó, phụ thuộc vào hệ nền, vào ngôn ngữ xây
dựng, và không thể giao tiếp với nhau do giao thức của chúng khác nhau, hoặc chi phí thực hiện
cao, triển khai phức tạp (CORBA).
Mặt khác, các công nghệ ở trên đều được xây dựng mang tính hướng kết nối (connection -
oriented) không phục vụ hiệu quả cho các ứng dụng được xây dựng nhiều trên mạng Internet.
Đó là các nguyên nhân dẫn tới sự ra đời của Web Services - các dịch vụ Web cho phép các ứng
dụng, các hệ thống có thể giao tiếp với nhau. Web Services được hình thành với những mong
muốn, đồng thời cũng là đặc điểm như sau:
• Giao thức thống nhất trên cơ sở sử dụng định dạng XML
• Độc lập với các hệ nền
• Thực hiện tin cậy qua mạng Internet, phù hợp và tương thích với các giao thức phổ biến
trên Internet hiện nay như HTTP, SMTP, FTP,...
• Hỗ trợ cho nhiều ngôn ngữ C, Java, COBOL,...
• Hộ trợ cho cơ sở hạ tầng của các ứng dụng phân tán
• Xây dựng, triển khai ứng dụng nhanh chóng, đơn giản, linh động
MicroSoft chính là đơn vị đầu tiên hướng tới Web Services trong định hướng công nghệ của mình
khi đưa SOAP vào W3C nhằm phổ biến rộng rãi và biến SOAP thành một chuẩn trong các giao
thức Web Services.
4.9.2. Kiến trúc Web Services
Dưới đây là ví dụ đơn giản về kịch bản yêu cầu dịch vụ A của Client:
Java overview
Trang 55/66
1. Tiến hành tìm dịch vụ Web của hệ thống
2. Lấy mô tả về dịch vụ và cách thức để sử dụng dịch vụ A
3. Truy cập tới dịch vụ A thông qua giao thức SOAP
4. Lấy về kết quả của dịch vụ A thông qua giao thức SOAP
Để đáp ứng được các yêu cầu của mình, kiến trúc của Web Services bao gồm các phần như sau:
1. Tầng vận chuyển với những công nghệ chuẩn là HTTP, SMTP và JMS
Java overview
Trang 56/66
2. Tầng giao thức tương tác dịch vụ (Service Communication Protocol) với công nghệ chuẩn là
SOAP. SOAP là giao thức nằm giữa tầng vận chuyển và tầng mô tả thông tin về dịch vụ,
SOAP cho phép người dùng triệu gọi một service từ xa thông qua một message XML.
3. Tầng mô tả dịch vụ (Service Description) với công nghệ chuẩn là WSDL và XML. WSDL là
một ngôn ngữ mô tả giao tiếp và thực thi dựa trên XML. Web service sử dụng ngôn ngữ
WSDL để truyền các tham số và các loại dữ liệu cho các thao tác, các chức năng mà web
service cung cấp.
4. Tầng dịch vụ ( Service): cung cấp các chức năng của service.
5. Tầng đăng ký dịch vụ (Service Registry) với công nghệ chuẩn là UDDI. UDDI dùng cho cả
người dùng và SOAP server nó cho phép đăng ký dịch vụ để người dùng có thể gọi thực
hiện service từ xa qua mạng, hay nói cách khác một service cần phải được đăng ký để cho
phép các client có thể gọi thực hiện.
6. Bên cạnh đó để cho các service có tính an toàn, toàn vẹn và bảo mật thông tin trong kiến
trúc web service chúng ta có thêm các tầng Policy, Security, Transaction, Management giúp
tăng cường tính bảo mật, an toàn và toàn vẹn thông tin khi sử dụng service.
4.9.3. Các thành phần Web Services
a. XML - Extensible Markup Language
XML là một ngôn ngữ mô tả văn bản với cấu trúc do người sử dụng định nghĩa. Về hình thức XML
có ký pháp tựa như HTML nhưng không tuân theo một đặc tả quy ước như HTML. Người sử dụng
hay các chương trình có thể quy ước định dạng các tag XML để giao tiếp với nhau.Thông tin cần
truyền tải được chứa trong các tag XML, ngoài ra không chứa bất cứ thông tin nào khác về cách
sử dụng hay hiển thị những thông tin ấy.
XML đặc biệt hiệu quả khi được sử dụng như một chuẩn nhằm quy định định dạng và cả dữ liệu
giao tiếp giữa các hệ thống.
Do Web Service là sự kết hợp của nhiều thành phần khác nhau, do đó Web Services sử dụng các
tính năng và đặc trưng của các thành phần này để giao tiếp với nhau. Vì vậy XML là một công cụ
chính yếu để giải quyết vấn đề này. Từ kết qủa này, các ứng dụng tích hợp vĩ mô tăng cường sử
dụng XML. Nhờ có khả năng tổng hợp này mà XML đã trở thành kiến trúc nền tảng cho việc xây
dựng Web Service.
b. WSDL - Web Services Description Language
WSDL định nghĩa cách mô tả web service theo cú pháp tổng quát XML, bao gồm các thông tin
• Tên ̣service.
• Giao thức và kiểu mã hóa sẽ đư-ợc sử dụng khi gọi các hàm của web service.
• Loại thông tin: những thao tác, những tham số, và những kiểu dữ liệu gồm có giao diện của
web service, cộng với tên cho giao diện này.
Một WSDL hợp lệ gồm có hai phần :
• Phần giao diện mô tả giao diện và giao thức kết nối.
• Phần thi hành mô tả thông tin để truy xuất service.
Java overview
Trang 57/66
Cả 2 phần trên sẽ được lưu trong 2 tập tin XML, bao gồm:
c. Tập tin giao diện service (cho phần Giao diện)
Mô tả một số loại thông tin chính:
• types: Kiểu dữ liệu của thông điệp
• message: Mô tả thông điệp được trao đổi giữa Client và Server
• portType: Kiểu cổng (mỗi cổng hỗ trợ các kiểu thao tác khác nhau): One-way, Request-
Response, Solicit-Response, Notification.
• binding: Định nghĩa các cách Web Services kết hợp với nhau
d. Tập tin thi hành service (cho phần Thi hành)
Mô tả một số loại thông tin chính:
• service: Thực hiện những khai báo trong tập tin giao diện, thủ tục & phương thức gọi
Services
• port: Cổng đầu cuối định nghĩa tập hợp các Web Services và địa chỉ mạng
e. UDDI - Universal Description , Discovery and Intergration
Để có thể sữ dụng các dịch vụ, trước tiên client phải tìm dịch vụ, ghi nhận thông tin về cách sử
dụng dịch vụ và biết được đối tượng cung cấp dịch vụ. UDDI định nghĩa một số thành phần cho
biết trước các thông tin này để cho phép các client truy tìm và nhận lại những thông tin yêu cầu sử
dụng web services.
Cấu trúc UDDI gồm các thành phần:
• Trang trắng - White pages: chứa thông tin liên hệ và các định dạng chính yếu của web
services, chẳng hạn tên giao dịch, địa chỉ,… Những thông tin này cho phép các đối tượng
khác xác định được service.
• Trang vàng - Yellow pages: chứa thông tin mô tả web services theo những chủng loại khác
nhau. Những thông tin này cho phép các đối tượng thấy web services theo từng chủng loại
của nó.
• Trang xanh - Green pages: chứa thông tin kỹ thuật mô tả các hành vi và các chức
năng của web services. Các đối tượng dựa vào đặc điểm của web services để tìm kiếm.
• Loại dịch vụ - tMode: chứa các thông tin về loại dịch vụ sử dụng.
Java overview
Trang 58/66
f. SOAP
Client có thể truy xuất dịch vụ khi tìm thấy thông qua một giao thức là SOAP - Simple Object
Access Protocol. Đây là một giao thức giao tiếp có cấu trúc như XML và mã hóa thành định dạng
chung cho các ứng dụng trao đổi với nhau. Ý tưởng bắt đầu từ Microsoft và phần mềm Userland,
trải qua nhiều lần thay đổi, hiện tại là phiên bản SOAP 1.2 với nhiều ưu điểm vuợt trội hơn bản
SOAP 1.1. SOAP được xem như là cấu trúc xương sống của các ứng dụng phân tán xây dựng từ
nhiều ngôn ngữ, hệ điều hành khác nhau.
SOAP có những đặc trưng sau:
• SOAP được thiết kế đơn giản và dễ mở rộng.
• Tất cả các message SOAP đều được mã hóa sử dụng XML.
• SOAP sử dùng giao thức truyền dữ liệu riêng.
• Không có garbage collection phân tán, và cũng không có cơ chế tham chiếu.Vì thế SOAP
client không giữ bất kỳ một tham chiếu đầy đủ nào về các đối tượng ở xa.
• SOAP không bị ràng buộc bởi bất kỳ ngôn ngữ lập trình nào hoặc công nghệ nào.
Vì những đặc trưng này, nó không quan tâm đến công nghệ gì được sử dụng để thực hiện miễn là
người dùng sử dụng các message theo định dạng XML. Tương tự, service có thể được thực hiện
trong bất kỳ ngôn ngữ nào, miễn là nó có thể xử lý được những message theo định dạng XML.
Cấu trúc một message theo dạng SOAP được mô tả như hình dưới đây:
• Phần tử gốc - envelop: phần từ bao trùm nội dung message, khai báo văn bản XML như là
một thông điệp SOAP.
• Phần tử đầu trang - header: chứa các thông tin tiêu đề cho trang, phần tử này không bắt
buộc khai báo trong văn bản. Những đầu mục còn có thể mang những dữ liệu chứng thực,
những chữ ký số hóa, và thông tin mã hóa, hoặc những cài đặt cho giao tác.
Java overview
Trang 59/66
• Phần tử khai báo nội dung chính trong thông điệp - body, chứa các thông tin yêu cầu và
phản hồi.
SOAP hỗ trợ hai kiểu truyền thông khác nhau:
• Remote procedure call (RPC): cho phép gọi hàm hoặc thủ tục qua mạng. Kiểu này được
khai thác bởi nhiều web service và có nhiều trợ giúp.
• Document: được biết như kiểu hướng message: kiểu này cung cấp một lớp thấp của sự
trừu tượng hóa, và yêu cầu người lập trình nhiều hơn khi làm việc.
4.9.4. Web Services trong công nghệ Java
Web Services được khởi đầu từ MicroSoft. Nhưng công nghệ liên quan tới Java thực sự đưa Web
Services phát triển mạnh trong thể giới của mình, không chỉ là Sun Microsystems, công ty tạo ra
Java, triển khai các công nghệ, mà còn có nhiều nhà cung cấp khác như BEA, IBM,...
Với Java, Web Services tận dụng khả năng giải quyết vấn đề của các ứng dụng lớn trên các hệ
điều hành khác nhau cho chúng giao tiếp với nhau.
Để tạo một web service chúng ta cần xây dựng các tầng cần thiết trong kiến trúc web service hay
nói cách khác là xây dựng và thiết lập các thành phần trong các tầng đó, cụ thể là các thành phần
SOAP, WSDL, UDDI, XML, trong đó :
• SOAP là giao thức nằm giữa tầng vận chuyển và tầng mô tả thông tin về dịch vụ, SOAP
cho phép người dùng triệu gọi một service từ xa thông qua một message XML.
• WSDL là một ngôn ngữ mô tả giao tiếp và thực thi dựa trên XML. Web service sử dụng
ngôn ngữ WSDL để truyền các tham số và các loại dữ liệu cho các thao tác, các chức năng
mà web service cung cấp.
• UDDI dùng cho cả người dùng và ̣ SOAP server, nó cho phép đăng ký dịch vụ để người
dùng có thể gọi thực thi các hàm , các chức năng của web service hay nói cách khác một
service cần phải được đăng ký để cho phép các client có thể gọi thực hiện
• Bên cạnh đó chúng ta cũng phải quan tâm đến việc làm sao để cho các service có tính an
toàn, toàn vẹn và bảo mật thông tin trong web services nhất là các service liên quan đến
giao dịch thương mại và tài chính.Chúng ta sẽ tìm hiểu nội dung này trong các phần tiếp
theo.
4.10. Portal
4.10.1. Sự hình thành Portal
Xuất phát từ nhu cầu chia sẻ thông tin trong cộng đồng là một động lực quan trọng cho sự hình
thành và phát triển của mạng Internet ngày nay. Những thông tin trình diễn trên các website và
cùng với khả năng liên kết giữa chúng, thông qua các links, đã thực sự tạo ra các kênh liên lạc lý
tưởng mà qua đó cộng đồng các nhà khoa học, các nhà nghiên cứu, các doanh nghiệp, các nhóm
người có cùng mục đích có thể chia sẻ thông tin, cộng tác với nhau trong một mục đích chung.
Tuy nhiên cùng với thời gian, sự gia tăng về số lượng các website trên Internet, sự mở rộng quy
mô các website điều hành trong các doanh nghiệp đã đặt ra một số bất cập sau:
Java overview
Trang 60/66
• Vấn đề quá tải thông tin, phải xử lý, lục tìm nhiều mới có được thông tin chính xác mà mình
cần
• Về khía cạnh kỹ thuật, các thông tin thường là độc lập, khó phân loại, dẫn đến tình trạng
khó chia sẻ
• Khó khăn trong việc quản lý, bảo trì website của các doanh nghiệp
Đối với các doanh nghiệp, yêu cầu quan trọng là các website phải cung cấp công cụ hỗ trợ làm việc,
hỗ trợ hoạt động nghiệp vụ của mình. Đó cũng chính là lý do dẫn tới sự hình thành cổng giao dịch
thông tin PORTAL.
4.10.2. Định nghĩa & đặc điểm của Portal
Từ Portal (cổng) vốn là một thuật ngữ kiến trúc, chỉ lối vào một tòa nhà lớn. Trong lĩnh vực CNTT,
Portal cũng có ý nghĩa tương tự. Có thể coi đó là cổng vào một kho thông tin lớn, đa dạng. Qua
Portal, những đối tượng người dùng khác nhau có thể truy cập đến nhiều loại thông tin khác nhau
nhưng theo một cách thức thống nhất.
Định nghĩa chung về Portal: Portal là một cổng thông tin cung cấp tập hợp nhiều dịch vụ cho người
dùng như tìm kiếm thông tin, hỗ trợ hoạt động nghiệp vụ, email, forum,... Đối với người dùng có thể
Portal chỉ là một website thông thường qua trình duyệt nhưng nó là một "siêu website", một điểm
đích quy tụ hầu hết các thông tin, dịch vụ mà người dùng cần.
Ở góc độ khách hàng hay đối tác kinh doanh thì portal chính là kênh thông tin nơi doanh nghiệp
tiếp xúc, trao đổi và thực hiện giao dịch với đối tác, khách hàng của mình. Khi một doanh nghiệp
nào đó có portal thì tất cả mọi giao dịch đều được thực hiện trên một giao diện duy nhất nhưng
thông tin được thể hiện theo ý thích đến tận cá nhân người sử dụng. Và portal cũng làm cho quá
Java overview
Trang 61/66
trình trao đổi thông tin giữa các nhân viên trong một doanh nghiệp với khách hàng hay đối tác được
nhanh chóng, thuận tiện và ít tốn kém.
Một vài đặc điểm quan trọng của Portal:
a. Cá nhân hóa giao diện người dùng
Đây là thuộc tính này là quan trọng nhất. Một portal phải cung cấp cho người sử dụng một giao
diện nhất quán và giao diện này phải do chính người sử dụng lựa chọn. Tính cá nhân hóa thể hiện
trên ở chỗ:
• Người sử dụng được quyền sắp xếp, tổ chức lại cách thức hiển thị thông tin trên portal theo
ý muốn của mình.
• Nội dung thông tin và dịch vụ: Người sử dụng được quyền lựa chọn để chỉ hiển thị những
thông tin và dịch vụ mà họ thực sự quan tâm.
b. Tổ chức thông tin theo một CMS
• Thông tin được quản lý bởi portal đa dạng (text, media,...) phải được phân loại và sắp xếp
các theo các chủ đề, phục vụ cho việc tìm kiếm, tránh tình trạng quá tải thông tin.
• Hỗ trợ tính năng tìm kiếm mạnh, theo nhiều tiêu chí.
• Nguồn thông tin đa dạng
• Hỗ trợ nhiều môi trường hiển thị tin: PC, Mobile, PDA,…
• Bảo mật thông tin
c. Hỗ trợ mô hình làm việc cộng tác
• Cung cấp các công cụ phục vụ cho hoạt động nghiệp vụ của người dùng: email, forum,
conference, task management,...
• Tích hợp các phần mềm hỗ trợ nghiệp vụ (workflow)
d. Hệ quản trị mạnh
• Quản trị Portal: Layout, Look & Feel, Kênh thông tin,…
• Quản trị người dùng: Roles, Groups,…
e. Cơ chế Single Sign On
• Người dùng chỉ cần đăng nhập một lần là có thể sử dụng mọi dịch vụ theo Role của mình
4.10.3. Các loại Portal
a. Phân loại theo khách hàng
• Vertical portal
Là các Portal có nội dung thông tin cũng như các dịch vụ của nó được thiết kế để phục vụ cho một
lĩnh vực xác định, cho một chuyên ngành xác định. Virtiacal portal thường được sử dụng để cung
cấp môi trường làm việc cho các cộng đồng hoặc các nhóm làm việc có chung một mục đích xác
định. Các portal của cộng đồng các nhà khoa học, các cộng đồng tôn giáo là những ví dụ điển hình
cho loại portal này
• Horizontal portal
Java overview
Trang 62/66
Thuật ngữ này được sử dụng để chỉ những portal mà nội dung thông tin cũng các dịch vụ của nó
bao trùm nhiều chủ đề, nhiều lĩnh vực, do vậy nó mang tính diện rộng, phục vụ cho nhiều loại
khách hàng khác nhau. Ví dụ Yahoo,...
b. Phân loại theo mục đích sử dụng
• Information portal
Xây dựng hệ thống cung cấp thông tin trên cơ sở thu gom số liệu từ nhiều nguồn khác nhau. Các
nguồn dữ liệu này nằm rải rác trên mạng toàn cầu Internet, từ các CSDL của các mạng nội bộ
Intranet, và thậm chí cả từ các portal khác.
• Community portal
Xây dựng các cộng đồng ảo để giúp đỡ lẫn nhau và để hợp tác với nhau trong cùng một mục đích
xác định. Community portal mang lại cơ hội cộng tác cho các cá nhân, tổ chức doanh nghiệp mà
ranh giới địa lý không có ý nghĩa ở đây.
• Corporate portal (or Enterprise portal)
Corporate portal thường được dùng bởi các nhân viên trong một cơ quan hay tổ chức sử dụng để
chia sẻ thông tin với nhau, cộng tác với nhau để cùng giải quyết một công việc, qua đó nâng cao
năng suất lao động và hiệu quả giải quyết công việc của mình.
• Commercial portal
Cung cấp “chợ điện tử” (e-mall) trong thị trường thương mại điện tử. Có rất nhiều mô hình của
commercial portal, như B2B portal thực hiện các giao dịch điện tử giã các doanh nghiệp, B2C thực
hiện mua/bán hàng hóa giữa khách hàng và doanh nghiệp, Tourism portal để phục vụ ngành công
nghiệp du lịch, và v.v..
• Goverment portal
Cung cấp các “cổng hành chính công điện tử” để chính quyền (Trung ương và địa phương) thực
hiện các chức năng của mình đối với dân chúng thông qua việc cung cấp thông tin và các dịch vụ
hành chính công.
c. Theo quan điểm về mã nguồn của người phát triển
• Portal thương mại: MS SharePoint, BEA WebLogic, OracleAS, IBM WebSphere Portal,...
• OpenSource: DotNetNuke, uPortal, Liferay,...
4.10.4. Portal với công nghệ Java
a. Portlet và Chuẩn JSR 168
Hầu hết các Portal Framework đều cung cấp một chuẩn các giao diện ứng dụng lập trình (API) có
tính mở, nhờ đó người phát triển hệ thống có thể sử dụng để gắn các ứng dụng và dịch vụ vào
khung của Portal. Các API này được biết với tên là Portlet, là một công cụ cho phép người phát
triển đăng ký các thành phần khác nhau với một khung Portal, bằng cách đó có thể tùy biến và tạo
ra Portal của riêng mình.
Bố trí các thành phần trên giao diện của một Portlet:
Java overview
Trang 63/66
Trong các Portal Framework xây dựng trên nền tảng Java, Portlet là sự mở rộng của Servlet. Tất
nhiên, lược đồ xử lý của Portlet phức tạp hơn Servlet, ngoài Request, Response còn có các yêu
cầu Action, Render. Portlet có thể sử dụng JSPs và servlet để cài đặt những tính năng của nó. Vì 1
ứng dụng portlet là 1 mở rộng của ứng dụng web, nên nó có thể bao gồm những thành phần ứng
dụng web khác trên một nền tảng vững chắc của các chuẩn Internet như: HTTP, HTML, XML,
SSL,… Thêm vào đó, ứng dụng portlet còn bao gồm 1 file mô tả triển khai portlet.xml
Portal có Porlet Container để quản lý và thực thi các Portlet:
• Cung cấp môi trường thực thi cho portlet.
• Xác định và phân phối yêu cầu khai thác thông tin từ portal đến đúng portlet có khả năng
giải quyết.
• Quản lý thời gian sống của các portlet cài đặt trong hệ thống (khởi động và loại bỏ các
portal không cần thiết để giải phóng bộ nhớ cho hệ thống).
• Gửi kết quả xử lý thông tin của portlet cho portal để chuyển giao cho người sử dụng.
Java Specification Request 168 - JSR 168 là chuẩn để viết Portlet cho các Portal xây dựng trên
nền tảng công nghệ Java (JSR 168 còn được gọi là Portlet API). Với chuẩn này, bất kỳ ai cũng có
thể phát triển các Portlet bằng cách tuân theo và đăng ký là một thành phần của Portal, do đó ứng
dụng có thể chạy tương thích trên Portal Framework mà mình sử dụng.
Java overview
Trang 64/66
b. Đặc điểm Portal dựa trên công nghệ Java
Ngoài việc cung cấp framework mạnh cho người phát triển customize, thêm mới các portlet nghiệp
vụ của mình, các Portal framework trên công nghệ Java nói riêng và Portal framework nói chung
đều được tích hợp một số Portlets thông dụng như: Mail, Forum, Calendar, Library,...
Dựa trên công nghệ mã nguồn mở, cộng đồng phát triển đông đảo, liên tục phát triển, tự do chỉnh
sửa mà nguồn theo yêu cầu nghiệp vụ của mình.
Áp dụng hầu hết các công nghệ, framework mạnh, nổi tiếng của Java hiện nay như:
• Xây dựng theo kiến trúc J2EE
• Chuẩn Portlet JSR-168
• Hibernate
• Spring, EJB
• Struts, Tiles, JSF
• Web Services
• WSRP - Web Services for Remote Portal, Hỗ trợ giao tiếp với J2ME
• AJAX, RSS
c. Kiến trúc tổng thể
Ví dụ về kiến trúc của Liferay Portal:
Java overview
Trang 65/66
5. Tài liệu tham khảo
Các file đính kèm theo tài liệu này:
- Một số vấn đề về công nghệ Java.pdf