Chủ Nhật, 8 tháng 1, 2017

EJB - 3. Architecting assignment using JPA, EJB & JSF

I. SQL Server: Tạo Query with Current Connection bằng cách sử dụng phím tắt Ctrl + N rồi gõ lệnh như sau:
II. EJB Module:
Bước 1: Tạo project.



Bước 2: Kích chuột phải tên project mà đã được tạo rồi chọn New/Entity Classes from Database.





Student.java

Bước 3: Kích chuột phải tên project mà đã được tạo rồi chọn New/Session Beans for Entity Classes.


AbstractFacade.java

StudentFacade.java

StudentFacadeLocal.java

Bước 4: Kích chuột phải tên project mà đã được tạo rồi chọn Clean and Build và Deploy.
Chú ý: Nếu Deploy không thành công thì kích chuột phải GlassFish Server nằm trong Servers thuộc dạng Services rồi chọn View Domain Admin Console để tạo JDBC Connection Pool và JDBC Resources.

III. Web Application:
Bước 1: Tạo project.




Bước 2: Kích chuột phải Libraries nằm trong tên project mà đã được tạo rồi chọn Add Project.

Bước 3: Kích chuột phải tên project mà đã được tạo rồi chọn New/JSF Faces Configuration.

Bước 4:  Kích chuột phải tên project mà đã được tạo rồi chọn New/JSF Managed Bean.

 faces-config.xml

 StudentBean.java

Bước 5: Chỉnh sửa file trong thư mục Web Pages rồi chạy bằng cách sử dụng phím tắt Shift + F6.
 index.xhtml

Output

Chủ Nhật, 1 tháng 1, 2017

EJB - 4. JMS

Java Message Service là một Java API cho phép các ứng dụng để tạo, gửi, nhận và đọc tin nhắn. JMS API xác định một tập hợp các giao diện và ngữ nghĩa có liên quan mà cho phép các chương trình viết bằng ngôn ngữ lập trình Java để truyền đạt với việc triển khai tin nhắn khác. JMS API cho phép truyền thông không chỉ lỏng lẻo mà còn thể hiện 2 thành phần như sau:
  • Asynchronous (không đồng bộ): Một nhà cung cấp JMS có thể phân phối các thông điệp tới một client khi chúng xảy ra. Một client không có yêu cầu thông điệp để nhận được chúng.
  • Reliable: JMS API có thể đảm bảo rằng một tin nhắn được chuyển một lần. Cấp thấp hơn của độ tin cậy là có sẵn cho các ứng dụng có khả năng bỏ lỡ các thông điệp hoặc để nhận tin nhắn trùng lặp.

I. Ứng dụng JMS:
JMS Client: Đây là các chương trình ngôn ngữ Java mà gửi và nhận tin nhắn.
Non-JMS Client: Đây là những client mà thường sử dụng Native client API của hệ thống sao thay vì JMS.
Message: Mỗi ứng dụng xác định một tập hợp các thông điệp được sử dụng để trao đổi thông tin giữa các client của nó.
JMS Provider: Đây là một hệ thống tin nhắn (MOM) mà thực hiện JMS API ngoài các chức năng quản trị và kiểm soát khác theo yêu cầu của một sản phẩm thông điệp có đầy đủ tính năng.
Administered Objects: Đối tượng quản lý là JMS được cấu hình sẵn các đối tượng được tạo ra bởi một quản trị viên cho việc sử dụng của client.

II. JMS Administered Objects:
ConnectionFactory: Đây là đối tượng một client sử dụng để tạo ra một kết nối với một nhà cung cấp.
Destination: Đây là đối tượng một client sử dụng để xác định đích đến của thông điệp mà nó được gửi và nguồn gốc của thông điệp mà nó nhận được.
Đối tượng quản lý được đặt trong JNDI namespace bởi một quản trị viên.

III. JMS Messaging Models:
1. Point-to-point (PTP):
Một nhà sản xuất tạo ra và gửi một tin nhắn mà sẽ được nhận chỉ bởi người tiêu dùng duy nhất. Đích đến tin nhắn được gọi là "Queue".
Đặc tính bao gồm 3 thành phần:
  • Mỗi tin nhắn chỉ có một người tiêu dùng.
  • Một người gửi và người nhận của một thông điệp không có sự phụ thuộc thời gian. Người nhận có thể lấy các thông điệp hay không và nó đang chạy khi client gửi tin nhắn.
  • Người nhận công nhận việc xử lý thành công của một thông điệp.
2. Publish/Subscrible:
Bất cứ số lượng client nào có thể đăng ký điểm đến tin nhắn và khi một khách hàng gửi một thông điệp tới điểm đến, tin nhắn đó được nhận bởi tất cả các client đã đăng ký vào điểm đến đó.
Nhà sản xuất thông điệp được gọi là nhà xuất bản và người tiêu dùng được gọi là các thuê bao. Ngoài các điểm đến tin nhắn được gọi là "Topic".
Đặc tính bao gồm 2 thành phần:
  • Mỗi thông điệp có thể có nhiều người tiêu dùng.
  • Các nhà xuất bản và thuê bao có sự phụ thuộc thời gian. Client mà đăng ký tới một chủ đề có thể tiêu thụ chỉ những thông điệp được công bố sau khi client đã tạo ra một thuê bao, thuê bao phải tiếp tục hoạt động để cho nó tiêu thụ thông điệp này.

Integrating Session Beans, Entites, Message-Driven Beans and Web Services


I. Entity Bean:
- Một đối tượng của dữ liệu bền vững được duy trì trong một lưu trữ dữ liệu lâu dài như một cơ sở dữ liệu. Một khóa chính xác định mỗi thể hiện của nó.
 - Đại diện cho dữ liệu một cách rõ ràng hoặc sưu tập dữ liệu, chẳng hạn như một hàng trong một cơ sở dữ liệu quan hệ. phương pháp đậu thực thể cung cấp các thủ tục cho hành động trên dữ liệu đại diện của hạt cà phê. Một entity bean là dai dẳng và tồn tại miễn là dữ liệu của nó vẫn còn trong cơ sở dữ liệu.
 - Entity bean có thể được tạo ra trong hai cách: Bằng hành động trực tiếp của Client, trong đó phương thức create() được gọi là giao diện home của bean, hoặc bởi một số hành động khác mà thêm dữ liệu vào cơ sở dữ liệu. Trong thực tế, trong một môi trường với dữ liệu kế thừa, các đối tượng entity có thể tồn tại trước EJB được triển khai.
 - Thực hiện một trong hai. Trong trường hợp bean-managed persistence, người thực hiện của entity bean dự trữ và lấy các thông tin được quản lý bởi bean thông qua gọi trực tiếp cơ sở dữ liệu. Bean có thể sử dụng một trong hai Java Database Connectivity (JDBC) hoặc SQL-Java (SQLJ) cho phương thức này. Tuy nhiên, phương thức này khó khăn hơn. Trong trường hợp container-managed persistence, các nhà cung cấp trình chứa có thể thực hiện truy cập vào cơ sở dữ liệu sử dụng các API một cách chuẩn. Nó có thể cung cấp công cụ cho biến cá thể bản đồ của entity bean để gọi đến một cơ sở dữ liệu nằm bên dưới. Cách tiếp cận này làm cho nó dễ dàng hơn để sử dụng entity bean với cơ sở dữ liệu khác nhau.

II. Session bean:
 - Session bean bao bọc business logic có thể được viện dẫn lập trình bởi một client thông qua local, remote hoặc dịch vụ web. Để truy cập vào một ứng dụng được triển khai trên các máy chủ, client gọi phương thức session bean. Session bean thực hiện công trình cho client của mình, che chắn nó bằng cách thực thi các business task bên trong máy chủ.
 - Có 2 loại session bean:
  • Stateful: Các trạng thái của một đối tượng bao gồm các giá trị của các biến cá thể của nó. Các biến này đại diện cho trạng thái của một client/bean session duy nhất. Bởi vì các client tương tác ("đàm phán") với bean của nó, trạng thái này thường được gọi là trạng thái đàm thoại. Như tên gọi của nó cho thấy, một session bean là tương tự như một phiên tương tác. Một session bean không được tiết lộ, nó có thể chỉ có một client, trong cùng một cách mà một phiên tương tác có thể chỉ có một người sử dụng. Khi client chấm dứt, sesion bean của nó cũng có thể chấm dứt và không còn liên kết nữa. Các trạng thái được duy trì trong suốt thời gian của client/bean session. Nếu client loại bỏ bean, session sẽ chấm dứt và trạng thái này sẽ biến mất.
  • Stateless: Một stateless session bean không duy trì một trạng thái đàm thoại với client. Khi một client gọi các phương thức của một session bean phi trạng thái, biến cá thể của bean có thể chứa một trạng thái cụ thể tới client kia nhưng chỉ trong thời gian của sự cầu khẩn. Khi phương pháp này được hoàn thành, trạng thái client cụ thể không nên được giữ lại. Client có thể, tuy nhiên, thay đổi trạng thái của các biến cá thể trong session bean phi trạng thái gộp chung, và trạng thái này được giữ qua các dẫn chứng tiếp theo của session bean phi trạng thái gộp chung. Bởi vì chúng có thể hỗ trợ nhiều client, session bean phi trạng thái có thể cung cấp khả năng mở rộng tốt hơn cho các ứng dụng mà đòi hỏi phải có một số lượng lớn của client. Thông thường, một ứng dụng đòi hỏi ít phi trạng thái hơn trạng thái để hỗ trợ cùng một số client. Một session bean phi trạng thái có thể thực hiện một dịch vụ web, nhưng session bean trạng thái không thể thực hiện.

III. Message-Driven bean:
 - Nó là một bean doanh nghiệp mà cho phép các ứng dụng Java EE để xử lý các thông điệp không đồng bộ. Đây là loại đậu thường đóng vai trò như một JMS. Các thông điệp có thể được gửi bởi bất cứ thành phần Java EE hoặc bởi một ứng dụng JMS hay hệ thống mà không sử dụng công nghệ Java EE. Message-driven beans có thể xử lý JMS hay các loại thông điệp khác.
 - Session bean cho phép bạn gửi thông điệp JMS và nhận chúng nhưng không đồng bộ. Để tránh gõ lên các nguồn tài nguyên máy chủ, không sử dụng ngăn chặn đồng bộ nhận trong một thành phần ở phía máy chủ. Nói chung, các thông điệp JMS không nên được gửi hoặc nhận được đồng bộ. Để nhận tin nhắn không đồng bộ, nên sử dụng message-driven bean.


IV. Web Service:
 - Bất cứ phần mềm nào có sẵn trên internet và sử dụng một hệ thống thông điệp XML một cách tiêu chuẩn. XML được sử dụng để mã hóa tất cả các thông tin liên lạc với dịch vụ web.
 - Dịch vụ Web có thể được mô tả, công bố, đặt hoặc viện dẫn qua mạng để tạo ra sản phẩm, quy trình, và chuỗi cung ứng và được xây dựng dựa trên các chuẩn mở như TCP/IP, HTTP, Java, HTML, XML. Các ứng dụng này có thể nằm trong cục bộ hoặc dựa trên web.
 - Hệ thống trao đổi thông tin dựa trên XML sử dụng Internet để trực tiếp tương tác ứng dụng với ứng dụng. Những hệ thống này có thể bao gồm các chương trình, đối tượng, thông điệp, hoặc tài liệu.
Tập hợp các giao thức mở và các tiêu chuẩn được sử dụng để trao đổi dữ liệu giữa các ứng dụng hoặc hệ thống. Phần mềm ứng dụng viết bằng ngôn ngữ lập trình khác nhau và chạy trên nền tảng khác nhau có thể sử dụng dịch vụ web để trao đổi dữ liệu qua mạng máy tính cũng như Internet theo một cách tương tự với quá trình liên lạc trên một máy tính duy nhất. Khả năng tương tác này là do việc sử dụng các tiêu chuẩn mở.
 - Nền tảng dịch vụ web cơ bản là XML và HTTP. Tất cả các dịch vụ web chuẩn trong việc sử dụng qua các thành phần sau: SOAP (Simple Object Access Protocol), UDDI (Universal Description, Discovery and Inegration), WSDL (Web Services Description Language).
 - Cho phép truyền thông giữa các ứng dụng khác nhau bằng cách sử dụng các tiêu chuẩn mở như HTML, XML, WSDL, và SOAP. Một dịch vụ web có sự hỗ trợ của: XML để gắn thẻ dữ liệu, SOAP để chuyển tải một thông điệp, WSDL để mô tả sự sẵn có của các dịch vụ đó.
 - Các bước để thực hiện hoạt động này như sau:
  • Các chương trình client kết hợp với thông tin đăng ký tài khoản vào một thông điệp SOAP.
  • Thông điệp SOAP này được gửi đến các dịch vụ web như thân thể của HTTP POST request.
  • Các dịch vụ web giải nén SOAP request và chuyển đổi nó thành một lệnh mà ứng dụng có thể hiểu được.
  • Các ứng dụng xử lý thông tin cần thiết và đáp ứng với một số tài khoản mới duy nhất cho khách hàng đó.
  • Tiếp theo, các dịch vụ web bao bì response vào một thông điệp SOAP, mà nó sẽ gửi lại cho các chương trình client để đáp ứng với yêu cầu HTTP của nó.
  • Các chương trình client giải nén thông điệp SOAP để có được những kết quả của quá trình đăng ký tài khoản.

Thứ Tư, 28 tháng 12, 2016

EJB - 2. Sử dụng Session Bean

I. Để tạo ra một ứng dụng EJB mới, thực hiện các bước sau đây trong NetBeans IDE:

1. Chọn File => New Project. Sau đó chọn danh mục Java EE và kiểu project là Enterprise Application. Nhấn Next.

2. Đặt tên project là EJBDemo. Nhấn Next.

3. GlassFish Server 4.1 được chọn làm máy chủ. Sau đó chọn phiên bản Java EE 7. Nhấn Finish.

4. Thành công trong việc tạo một ứng dụng này.

II. Để tạo một Session Bean mà được truy cập bằng cách sử dụng chế độ Local, thực hiện các bước sau đây trong NetBeans IDE:

1. Nhấp chuột phải vào EJBDemo-ejb và chọn New => Other. Chọn danh mục Enterprise JavaBeans và loại tập tin là Session Bean. Nhấn Next.

2. Chỉ định thông tin Session Bean như sau và sau đó nhấn Finish:

3. Thêm dòng code vào giao diện SayHelloSessionBeanLocal để khai báo phương thức sayHello.
SayHelloSessionBeanLocal.java là giao diện Local của Session Bean mà NetBeans tự động tạo ra.

4. Thực hiện phương pháp sayHello trong lớp SayHelloSessionBean.
Nhận thấy rằng lớp SayHelloSessionBean thực hiện giao diện Local là SayHelloSessionBeanLocal.

5. Nhấp chuột phải vào EJBDemo và chọn Deploy.

6. Deploy thành công.

III. Để tạo một Servlet, thực hiện các bước dưới đây trong NetBeans IDE.

1. Nhấp chuột phải vào EJBDemo-war và chọn New => Other. Sau đó chọn danh mục Web và loại tập tin là Servlet. Nhấn Next.

2. Chỉ định thông tin Servlet như sau và sau đó nhấn Finish:





3. Thực hiện thay đổi cho lớp SayHelloServlet.
Nhấn Alt + Insert rồi chọn Call Enterpise Bean. Sau đó nhấn OK.
Thành công trong việc tạo.

4. Thay đổi phương thức ProcessRequest của SayHelloServlet.

IV. Để tạo một JSP, thực hiện các bước dưới đây trong NetBeans IDE.

1.Trong index.html, sửa đổi trong thẻ title của trang và thêm một thẻ form trong thẻ body.

2. Nhấn chuột phải thư mục Web Pages trong EJBDemo-war. Chọn New => JSP rồi đặt tên file là sayhello. Sau đó nhấn Finish.

3. Trong sayhello.jsp, chúng ta sẽ thực hiện sửa đổi như sau.

V. Output:

1. Nhấp chuột phải vào EJBDemo và chọn Run.

2. Chạy thành công. Nhập tên trong textbox rồi nhấn Send.
 index.html

sayhello.jsp