1. Trang chủ
  2. » Kỹ Thuật - Công Nghệ

JSP Technology

93 418 0
Tài liệu đã được kiểm tra trùng lặp

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 93
Dung lượng 776,58 KB

Nội dung

JSP Technology

Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 1 P P h h a a à à n n I I : : J J S S P P T T E E C C H H N N O O L L O O G G Y Y Chương I: CĂN BẢN VỀ JSP JavaServer Pages (JSP) là một kỹ thuật server-side do đó chúng ta không thể thực hiện bất kỳ hành động nào ở client. JSP cho phép chúng ta tách thành phần động của trang ra khỏi thành phần tónh HTML. Rất đơn giản, chúng ta chỉ cần viết một tài liệu HTML bình thường rồi sau đó bao quanh mã của thành phần động trong các tag đặc biệt, hầu hết các tag bắt đầu với <% và kết thúc với %>. Ví dụ, đây là một phần của trang JSP, có kết quả trả về là “Thanks for reading jsp book.” với URL là http://www.jsp.com/thank.jsp?title=jsp Thanks for reading <i><%=request.getParameter(“title”)%><i>book. Kỹ thuật JSP là một thành phần trong đại gia đình Java; nó sử dùng ngôn ngữ kòch bản dựa vào ngôn ngữ lập trình Java, và các trang JSP được biên dòch thành servlets. Từ đó chúng ta cũng nhận biết được, JSP thì không phụ thuộc bất kỳ nền (platform) nào. Nó đáp ứng được khuynh hướng của Sun MicroSystem là “write one, run anywhere”. Các trang JSP có thể gọi các thành phần JavaBeans, Enterprise JavaBeans (EJB) hoặc custom tags để thực hiện các xử lý trên server. Và như thế, kỹ thuật JSP là thành phần chủ chốt trong kiến trúc khả chuyển của Java cho những ứng dụng dựa vào Web. Như đã biết, JSPs sẽ biên dòch thành servlets nhưng JSP không thể thay thế servlet vì các lý do sau: - Một số tác vụ được giải quyết rất tốt bằng servlet. Ví dụ, các ứng dụng xuất ra dữ liệu nhò phân hoặc chỉ xác đònh nơi gởi trở lại cho người dùng (bằng cách dùng response.sendRedirect) được dùng servlet thì tốt nhất. - Một số tác vụ khác lại được giải quyết rất tốt bằng JSP như các tình huống mà cấu trúc nền tảng của trang HTML là cố đònh nhưng các giá trò trong nó lại thay đổi. - Còn các tác vụ còn lại cần sự kết hợp cả servlet và JSP. Ví dụ, trong yêu cầu gốc được trả lời bằng một servlet mà thực hiện mọi công việc, lưu trữ các kết quả trong các Beans và điều phối yêu cầu này đến một trong những trang JSP có thể hiển thò nó. THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 2 Cả ba đònh hướng này đều có chổ đứng của nó. Chẳng có đònh hướng nào hổ trợ đầy đủ cho mọi ứng dụng . Trước khi đi vào chi tiết công nghệ JSP, chúng tôi có một vài so sánh các công nghệ được sử dụng trong ứng dụng với các công nghệ khác. I. Một số so sánh các công nghệ được sử dụng với công nghệ khác? 1. MySQL Server. MySQL là hệ quản trò cơ sở dữ liệu quan hệ. Cơ sở dữ liệu là một tập dữ liệu có cấu trúc và được lưu trữ trong các bảng riêng biệt, mỗi bảng được lưu trong ba files với tên cơ sở dữ liệu là tên thư mục chứa các files đó. SQL được viết tắt từ Structured Query Language, là ngôn ngữ chuẩn phổ biến nhất để truy cập cơ sở dữ liệu. Sau đây là một số ưu và nhược điểm của MySQL với các hệ quản trò cơ sở dữ liệu khác: a) Ưu diểm. - Chạy được trên rất nhiều nền khác nhau như Unix, Windows, MacOS, …. - MySQL là hệ quản trò nhanh, nhỏ gọn. Các script files có thể chạy trên một số hệ quản trò khác như MS SQL Server, Oracle. - Theo một số web site thống kê, việc thực hiện các lệnh insert, update, delete nhanh nhất trong các hệ quản trò. - Miễn phí và mã nguồn mở (open source code). b) Khuyết điểm. - Chưa hổ trợ một số chuẩn ANSI SQL92 như không cho các câu select lồng nhau, select into table, khoá ngoại, triggers, stored procedures,… - Không có môi trường đồ hoạ. 2. So sánh JSP với các công nghệ khác. a) JSP với ASP. ASP là công nghệ tương đương từ Microsoft. JSP có ba lợi thế so với ASP. THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 3 SGML HTML XML CDF SMIL CML MML - Phần động được viết bằng Java, chứ không phải bằng các ngôn ngữ script như VBScript, JavaScript. Vì thế nó mạnh mẽ hơn tốt hơn đối với các ứng dụng phức tạp cần các thành phần sử dụng lại. - JSP chạy được trên nhiều hệ điều hành và web servers khác nhau ngay cả với IIS của Microsoft (cần có plugins từ Webphere, JRun, .) - Hổ trợ sự mở rộng tag với custom tag. b) JSP với PHP. Lợi điểm của JSP với PHP cũng như với ASP. JSP được viết bằng Java mà chúng ta đã biết với các API mở rộng cho mạng, truy cập cơ sở dữ liệu, các đối tượng phân tán, … trong khi với PHP đòi hỏi chúng ta phải học cả một ngôn ngữ mới. 3. Tầm quan trọng của XML cùng với XSLT. a) XML. XML là tập con của SGML, nó kết hợp tính linh động và sức mạnh của SGML cùng với một số tính năng hữu ích của HTML. Vì XML là tập con của SGML nên nó cũng tương thích với các hệ thống dựa vào SGML đã có. XML là lực đẩy cho các nghi thức trên internet và các phần mềm để dễ dàng xử lý và truyền dữ liệu. Ở trên đã nói XML là tập con của SGML và HTML là một sự cài đặt của SGML, mô hình sau đây diễn tả mối quan hệ giữa các ngôn ngữ và các siêu ngôn ngữ: Metalanguages Languages Implementation subset Implementation THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 4 CDF : Channel Difinition Format – cho phép các tác giả của các Web sites cho phép các người đăng ký biết khi nào Web site này thay đổi, CDF đã được giới thiệu trong IE4 vì vậy nó chỉ làm việc với IE của Microsoft. SMIL : Synchronized Multimedia Integration Language – được sử dụng để đồng bộ hóa các dòng dữ liệu đa truyền thông được truyền qua internet. CML : Chemical Markup Language – mô tả các công thức hóa học. MML: Mathematical Markup language- mô tả các phương trình, biểu thức toán học. Tính tự mô tả dữ liệu của XML : các tags mô tả các vấn đề, các đối tượng gần gủi với thế giới thực. Chúng ta sẽ thấy rõ hơn với hai ví dụ sau, đây là ví dụ minh họa nên nó còn thiếu nhiều thuộc tính trong thế giới thực : - XML có mối quan hệ chặt chẽ với JSP, đặt tả JSP hổ trợ cú pháp XML, chúng ta có thể trộn lẫn mã chúng với nhau dễ dàng như JSP với HTML như thế chúng ta có thể dùng JSP tự động phát sinh trang XML. - Hiện nay có rất nhiều sản phẩm quản trò cơ sở dữ liệu mà mỗi sản phẩm đều có các đặc tính riêng nó, do đó khi các cơ sở dữ liệu khác nhau cần chuyển đổi dữ liệu với nhau lại không tương thích. Vì vậy người làm công việc này cần phải biết nhiều sản phẩm quản trò cơ sở dữ liệu khác nhau. Do đó XML là một đònh dạng chuẩn mà các hệ quản trò cần hổ trợ. Hiện nay có nhiều hệ quản trò lớn hổ trợ XML như MS SQL Server, Oracle, … Ví dụ với XML tags <student> <name> <first>Giang</first> <middle>Le</middle> <last>Dinh</last> </name> <numberid>0750</numberid> <age>22</age> </student> Ví dụ với HTML tags <table> <tr> <td>Giang</td> <td>Le</td> <td>Dinh</td> </tr> <tr> <td>Number id : </td> <td>0750</td> </tr> <tr> <td>Age :</td> <td>22</td> </tr> </table> THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 5 b) XSLT. Extensible Stylesheet Language Transformation (XSLT) là một ngôn ngữ được tách ra từ ngôn ngữ XSL, “XSLT là một ngôn ngữ dùng để chuyển đổi các XML document thành các XML document khác”. Nó được viết bằng XML, điều này có nghóa rằng sự chuyển đổi trong XSLT được trình bày như một well-formed XML document. XSLT đóng vai trò quan trọng trong hướng phát triển “phát sinh ngôn ngữ markup hướng người dùng”. II. JSP scripting elements. Các scripting elements trong JSP cho phép chúng ta chèn mã vào servlet mà sẽ được phát sinh từ trang JSP. Có ba dạng sau: - Biểu thức có dạng <%= expressions %>, được đònh giá trò và chèn vào luồng xuất của servlet. - Scriptlet có dạng <% code %>, được chèn vào phương thức _jspService của servlet (được gọi là service). - Khai báo có dạng <%! code %>, được chèn vào thân của lớp servlet, như là các field của lớp thông thường. Template text Trong nhiều trường hợp, phần lớn các trang JSP chỉ bao gồm HTML tónh, được biết như là template text. Có hai ngoại lệ phụ cho quy tắc “template text được chuyển thẳng sang HTML tónh”. Đầu tiên, nếu chúng ta muốn có <% trong luồng xuất thì chúng ta cần phải đặt <\% trong template text. Thứ hai, nếu chúng ta muốn có chú thích trong JSP mà không có trong tài liệu kết quả, dùng: <%-- JSP comments --%> Chú thích HTML có dạng: <!-- HTML comments --> thì được chuyển qua tài liệu HTML thông thường. Cú pháp XML Trong JSP có rất nhiều element có cú pháp XML như jsp:useBean, jsp:include, jsp:setProperty, . Tuy nhiên scripting elements lại có hai dạng cú pháp sau: THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 6 JSP Syntax XML Syntax <% = Expressions %> <jsp:expression> Java code </jsp:expression> <% Scriptlets %> <jsp:scriptlet> Java code </jsp:scriptlet> <%! Declarations %> <jsp:declaration> Java code </jsp:declaration> 1. Các biến được đònh nghóa sẵn trong JSP Để đơn giản hoá mã trong các biểu thức hay scriptlets trong JSP, người ta cung cấp cho chúng ta chín đối tượng đã được đònh nghóa trước, có người còn gọi là các đối tượng ngầm đònh. Do các khai báo trong JSP nằm ngoài phương thức _jspService (được gọi bởi service) nên các đối tượng này không cho phép các khai báo truy cập vào. request Biến này có kiểu là javax.servlet.http.HttpServletRequest, có phạm vi trong một yêu cầu (request). Nó cho phép chúng ta truy cập vào các tham số của request như loại request (GET, POST, …) và các incoming HTTP header (cookies). response Có kiểu là javax.servlet.http.HttpServletResponse, có phạm vi toàn trang (page). Chú ý rằng vì luồng xuất thì thường làm vật đệm cho nên việc gán mã tình trạng của HTTP và response header thì hợp lý trong JSP, mặc dù điều này thì không được phép trong servlet một khi đã có luồng xuất nào được gởi đến client. out Có kiểu javax.servlet.jsp.JspWriter và phạm vi trong một trang (page). Dùng để gởi các thông xuất đến client. Đối tượng out được dùng thường xuyên trong scriptlets, các biểu thức tự động được đưa vào luồng xuất nên hiếm khi cần tham chiếu đến đối tượng này. THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 7 session Có phạm vi trong một phiên truyền (session) và kiểu tương ứng là javax.servlet.http.HttpSession. Gọi về các phiên truyền được tạo tự động vì thế biến này vẫn còn kết nối ngay cả chẳng có một tham chiếu incoming session nào. Một ngoại lệ là nếu chúng ta sử dụng thuộc tính session của page directive để tắc các phiên truyền, mà lại cố tham chiếu đến biến session thì sẽ gây ra các lỗi vào lúc trang JSP được dòch thành servlet. application Biến này có kiểu là javax.servlet.ServletContext, có phạm vi trong toàn ứng dụng (application). ServletContext lấy từ một đối tượng cấu hình servlet là getServletConfig().getContext(). Các trang JSP có thể lưu trữ dữ liệu persistent trong đối tượng ServletContext tốt hơn là trong các biến thể hiện. ServletContext có các phương thức setAttribute và setAttribute mà cho phép chúng ta lưu trữ dữ liệu config Biến này có phạm vi trang (page) và có kiểu tương ứng là javax.servlet.ServletConfig. pageContext Biến này có kiểu là javax.servlet.jsp.PageContext và có phạm vi là trang (page). pageContext cho phép một điểm truy cập duy nhất tới nhiều thuộc tính của trang và cung cấp một nơi thuận tiện để lưu trữ dữ liệu dùng chung. Biến pageContext lưu trữ giá trò của javax.servlet.jsp.PageContext cùng với trang hiện hành. Có thể xem chi tiết trong chương II về JavaBeans. page Biến này đồng nghóa với this và điều này thì không hữu ích trong ngôn ngữ lập trình Java, có kiểu là java.lang.Object và có phạm vi trang (page). exception Trong một trang lỗi, chúng ta có thể truy cập vào đối tượng exception. Biến này có kiểu là java.lang.Throwable và phạm vò là trang (page). THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 8 2. Biểu thức trong JSP Biểu thức trong JSP được dùng để chèn các giá trò trực tiếp vào luồng xuất. Nó có dạng sau: <%= Java expressions %> Biểu thức này được đònh trò, được chuyển thành chuổi, và được chèn vào trong trang. Sự đònh trò diễn ra ở thời gian runtime (khi trang được yêu cầu) và do đó có đầy đủ quyền truy cập các thông tin của yêu cầu này. Ví dụ sau đây mô tả ngày/giờ mà trang được yêu cầu: Current time: <%= new java.util.Date() %> Trong Java mỗi câu lệnh đều có dấu ‘;’ kết thúc dòng. Tại sao biểu thức trong JSP lại không có dấu ‘;’? Vì biểu thức này được đưa vào luồng xuất chẳng hạn như PrintWriter. Với ví dụ trên có thể chuyển vào servlet như sau: PrintWriter out = response.getWriter(); out.println(“Current time:” + new java.util.Date()); a) Biểu thức như là giá trò trong elements khác. Biểu thức có thể được sử dụng trong các thuộc tính của các elements khác. Giá trò từ các biểu thức này sẽ được tính vào thời gian yêu cầu (request time). Các elements cho phép sử dụng biểu thức trong các thuộc tính của chúng là: Tên Element Tên thuộc tính jsp:setProperty name và value jsp:include page jsp:forward page jsp:param value b) Ví dụ expression.jsp. Đây là một ví dụ hoàn chỉnh đầu tiên của JSP. Nó chỉ hiển thò thời gian hiện thời, tên máy, khi file này được truy cập. Code 1: expression.jsp <?xml version="1.0" encoding="ISO-8859-1" ?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 9 "DTD/xhtml1-strict.dtd"> <!-- Example of JSP Expressions. --> <html> <head> <title>JSP Expressions</title> <meta name="author" content="Giang" /> <meta name="keywords" content= "JSP,expressions,JavaServer,Pages,servlets" /> <meta name="description" content= Code 1: expression.jsp (tiếp theo) "A quick example of JSP expressions." /> <link rel="stylesheet" href="JSP-Styles.css" type="text/css" /> </head> <body> <h2>JSP Expressions</h2> <ul> <li> Current time: <%= new java.util.Date() %> </li> <li> Your hostname:<%=request.getRemoteHost()%> </li> <li>Your session ID: <%= session.getId() %></li> <li>The <code>testParam</code> form parameter: <%= request.getParameter("testParam") %> </li> </ul> </body> </html> 3. JSP scriptlets Scriptlets là những đoạn mã có chứa bất kỳ mã Java nào nằm giữa “<%” và “%>”. Nếu chúng ta muốn thực hiện thứ gì đó phức tạp hơn là chỉ chèn vào một biểu thức đơn giản thì JSP scriptlets cho phép chúng ta thêm bất kỳ đoạn mã Java nào vào trang JSP. Các scriptlets này được đưa vào phương thức _jspService (mà được gọi bởi service) của servlet. Có cú pháp: <% Java Code %> THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Gvhd: Ts.Nguyễn Thúc Hải Svth: Đinh Lê Giang Trang 10 Code 2: scriptlet.jsp <?xml version="1.0" encoding="ISO-8859-1" ?> <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 S trict// EN " " DTD /xhtml1-strict.dtd"> <!-- Example of JSP Scriptlets. --> <html> Code 2: scriptlet.jsp (tiếp theo) <head> <title>JSP Scriptlets</title> </head> <% String bgColor = request.getParameter("bgColor"); boolean hasExplicitColor; if (bgColor != null) { hasExplicitColor = true; } else { hasExplicitColor = false; bgColor = "WHITE"; } %> <body bgcolor="<%= bgColor %>"> <h2 align="center">Color Testing</h2> <% if (hasExplicitColor) { out.println("You supplied an explicit background color of " + bgColor + "."); } else { out.println("Using default background color of WHITE. " + "Supply the bgColor request attribute to try " + "a standard color, an RRGGBB value, or to see " + "if your browser supports X11 color names."); } %> </body> </html> THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN [...]... import vào bất kỳ thứ gì và chúng có cú pháp XML Có chín actions chuẩn: jsp: include, jsp: useBean, jsp: setProperty, jsp: getProperty, jsp: plugin, jsp: forward, jsp: fallback, jsp: params, jsp: param sẽ được giới thiệu trong mục này 1 Action chèn vào files ở thời gian request Với include directive cho phép chúng ta thêm vào các tài liệu chứa mã JSP vào nhiều trang khác nhau nhưng lại có vấn đề là đòi hỏi chúng... thể download Plug-In b) jsp: param và jsp: params action jsp: param được dùng trong các actions khác như: jsp: include, jsp: forward, jsp: plugin Action này dùng để cung cấp cặp tên và giá trò (name/value) cho các actions trên Cụ thể với jsp: plugin, thì action này sẽ đònh rõ tên và giá trò mà được truy cập từ trong applet bởi getParameter Tất cả jsp: param actions đều phải nằm trong jsp: params action Ví dụ:... VALUE=“VALUE2”> trong JSP sử dụng như sau: Svth: Đinh Lê Giang 21 Trang THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Hải Gvhd: Ts.Nguyễn Thúc < /jsp: params> < /jsp: plugin> c) jsp: fallback action jsp: fallback cung cấp văn bản... trong JSP Chúng ta có thể sử dụng các actions sau để sử dụng lại các component (Beans) trong JSP: jsp: useBean, jsp: setProperty, jsp: getProperty Các action này được trình bày trong chương II Svth: Đinh Lê Giang 23 Trang THƯ VIỆN ĐIỆN TỬ TRỰC TUYẾN Đồ án tốt nghiệp Hải Chương II : Gvhd: Ts.Nguyễn Thúc JSP JAVABEANS I Khái niệm và các quy ước của Bean 1 Khái niệm Mô hình thành phần (component) trong JSP. .. TUYẾN Đồ án tốt nghiệp Hải Gvhd: Ts.Nguyễn Thúc II .JSP sử dụng Beans 1 Các JSP element dùng cho Bean a) jsp: useBean element Cho phép chúng ta tải một Bean với tên và phạm vi xác đònh vào trang JSP Cú pháp: < /jsp: useBean> Nếu không có body, tức là không có tag nào trong thân của jsp: useBean thì có cú pháp là empty tag TypeSpec... sử dụng jsp: forward action Ví dụ: Code 14: Sử dụng jspforward 0.5) { dest = “page1 .jsp ; } else { dest = “page2 .jsp ; } %> Action này cho phép điều phối một request hiện hành vào lúc runtime đến một tài nguyên tónh, trang JSP hay lớp... Chẳng hạn, đây là một trang JSP mà in ra số lần truy cập vào trang Code 3: declaration .jsp JSP Declarations > JSP Declarations JSP Declarations < /jsp: plugin> 3 Actions dùng để forward và sử dụng Components a) Chuyển các request từ các trang JSP Tình huống chuyển... các directives cũng có hai dạng cú pháp: JSP Syntax XML Syntax : attr_list sẽ được mô tả phần sau trong chương này : directive này được trình bày trong chương III Tag Libraries < /jsp: root> 1 The page directive page directive... What's New at JspNews.com Here is a summary of our four most recent news stories:

Ngày đăng: 27/04/2013, 20:48

Xem thêm

HÌNH ẢNH LIÊN QUAN

Bảng sau mô tả tính sẳn dùng của biến kịch bản và các phương thức để xác lập và xác lập lại giá trị của biến - JSP Technology
Bảng sau mô tả tính sẳn dùng của biến kịch bản và các phương thức để xác lập và xác lập lại giá trị của biến (Trang 47)
Bảng sau mô tả tính sẳn dùng của biến kịch bản và các phương  thức để xác lập và xác lập lại giá trị của biến - JSP Technology
Bảng sau mô tả tính sẳn dùng của biến kịch bản và các phương thức để xác lập và xác lập lại giá trị của biến (Trang 47)
Hiển thị bảng thống kê - JSP Technology
i ển thị bảng thống kê (Trang 68)
- Xoá các mẩu tin trong các bảng phát sinh - JSP Technology
o á các mẩu tin trong các bảng phát sinh (Trang 69)
b) Bảng mô tả chi tiết. - JSP Technology
b Bảng mô tả chi tiết (Trang 71)
d) Bảng tầm ảnh hưởng. - JSP Technology
d Bảng tầm ảnh hưởng (Trang 77)
Sơ đồ cấu trúc chương trình. - JSP Technology
Sơ đồ c ấu trúc chương trình (Trang 78)
Mô hình hoạt động của The Web Work. The Web Work hoạt động dựa trên mô hình ba lớp (3 layer) - JSP Technology
h ình hoạt động của The Web Work. The Web Work hoạt động dựa trên mô hình ba lớp (3 layer) (Trang 84)
Trong mô hình kiến trúc hai, đó là sự kết hợp cả hai kỷ thuật xử lý web động là Servlet và JSP - JSP Technology
rong mô hình kiến trúc hai, đó là sự kết hợp cả hai kỷ thuật xử lý web động là Servlet và JSP (Trang 85)
Kiến trúc mô hình hai - JSP Technology
i ến trúc mô hình hai (Trang 86)
w