Đồ án Xây dựng từ điển Multimedia dùng công nghệ AJAX trên nền PHP

Trong thời đại ngày nay, chúng ta luôn hướng đến những gì đơn giản, gần gũi và tiện lợi trong mọi lĩnh vực. Công nghệthông tin cũng không nằm ngoài mục tiêu này. Có điều đây là lĩnh vực có tốc độthay đổi kinh ngạc, tính từng giây từng phút. Các công nghệliên tục thay đổi và cũng liên tục ra đời các công nghệmới thật phong phú, trợ giúp hữu ích cho các nhà quản trịvà người sửdụng. Ajax có thểnói là một công nghệkhá mới, đặc biệt là ởViệt Nam nhưng nó được sử dụng ngày càng phổbiến vì khảnăng tương tác cao, làm cho các ứng web gần với ứng dụng đểbàn hơn. Ajax (Asynchronous JavaScript + XML) được tạo ra bởi Jesss James Garrett của Adaptive Path. Một sốthành phần của Ajax đã được mô tảtrước đây là Dynamic HTML và việc kịch bản hóa từxa. Vềmặt công nghệ, Ajax đưa ra các biểu thức cho các tiềm năng chưa thực hiện được trong các công nghệtrình duyệt web trước đây. Google và một sốtổchức chính khác đã sửdụng Ajax đểxây dựng những gì có tính chất cộng đồng được mong đợi giống nhưnhững gì mà một ứng dụng web có thểthực hiện. Một sốlượng lớn các kỹthuật được sắp xếp đểlấp đầy những thiếu sót với sự phong phú hơn, thông minh hơn hoặc vềmặt cải tiến các client. Ajax cho phép thực hiện điều này tốt hơn, thông minh hơn mà chỉsửdụng các kỹthuật đã được cài đặt trên sốlượng lớn các máy tính hiện đại. Một đặc điểm nữa cho thấy Ajax ngày càng được ứng dụng rộng rãi là nó độc lập với hệ điều hành (không phụthuộc nền), xứlý dữliệu XML, sửdụng các JavaScript.

pdf80 trang | Chia sẻ: tuandn | Lượt xem: 2364 | Lượt tải: 3download
Bạn đang xem trước 20 trang tài liệu Đồ án Xây dựng từ điển Multimedia dùng công nghệ AJAX trên nền PHP, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
BỘ GIÁO DỤC VÀ ĐÀO TẠO TRƯỜNG ĐẠI HỌC KỸ THUẬT CÔNG NGHỆ ---------------o0o--------------- ĐỒ ÁN TỐT NGHIỆP Đề tài XÂY DỰNG TỪ ĐIỂN MULTIMEDIA DÙNG CÔNG NGHỆ AJAX TRÊN NỀN PHP SVTH : LÊ THANH NHÀN Lớp : 03DTHM MSSV : 103102139 GVHD : Thầy HOÀNG ĐỨC QUANG THÀNH PHỐ HỒ CHÍ MINH NĂM 2009 1 BỘ GIÁO DỤC & ĐÀO TẠO ĐẠI HỌC KỸ THUẬT CÔNG NGHỆ TP.HCM CỘNG HÒA XÃ HỘI CHỦ NGHĨA VIỆT NAM ĐỘC LẬP – TỰ DO – HẠNH PHÚC _____oOo_____ Khoa: Công nghệ thông tin Bộ môn: Mạng máy tính NHIỆM VỤ THỰC HIỆN LUẬN VĂN TỐT NGHIỆP CUỐI KHOÁ Họ và tên : Lê Thanh Nhàn MSSV : 103102139 Ngành : Mạng máy tính Lớp : 03DTHM 1. Đầu đề đồ án tốt nghiệp : Xây dựng từ điển multimedia dùng công nghệ Ajax trên nền PHP. 2. Nhiệm vụ : a. Dữ liệu ban đầu : ..................................................................................................................................................... ..................................................................................................................................................... ..................................................................................................................................................... ..................................................................................................................................................... ..................................................................................................................................................... ..................................................................................................................................................... b. Nội dung  Phần tìm hiểu công nghệ : ............................................................................................................................... ............................................................................................................................... ............................................................................................................................... ............................................................................................................................... ...............................................................................................................................  Phần phân tích, thiết kế & xây dụng ứng dụng minh họa : 2 ............................................................................................................................... ............................................................................................................................... ............................................................................................................................... ............................................................................................................................... ............................................................................................................................... 3. Ngày giao nhiệm vụ đồ án: 7/10/2008 4. Ngày hoàn thành nhiệm vụ: 3/1/2009 5. Họ tên giáo viên hướng dẫn: thầy Hoàng Đức Quang Nội dung và yêu cầu đồ án tốt nghiệp đã thông qua. TP.HCM, ngày …… tháng …… năm 2009 CHỦ NHIỆM KHOA (Ký và ghi rõ họ tên) GIÁO VIÊN HƯỚNG DẪN CHÍNH (Ký và ghi rõ họ tên) PHẦN DÀNH CHO BỘ MÔN Người duyệt (chấm sơ bộ) : ................................................. Đơn vị : .................................................................................. Ngày bảo vệ : ........................................................................ Điểm tổng quát : .................................................................. 3 NHẬN XÉT ĐÁNH GIÁ CỦA GIẢNG VIÊN HƯỚNG DẪN ĐỀ TÀI: ............................................................................................................................. ............................................................................................................................................ Sinh Viên: ........................................................... Chuyên ngành ................................. ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ Điểm bằng số: ..................................................... Điểm bằng chữ: .................................................. Tp. Hồ Chí Minh, ngày tháng năm NGƯỜI NHẬN XÉT (Ký tên và ghi rõ họ tên) 4 NHẬN XÉT ĐÁNH GIÁ CỦA GIẢNG VIÊN PHẢN BIỆN ĐỀ TÀI: ............................................................................................................................. ............................................................................................................................................ Sinh Viên: ........................................................... Chuyên ngành ................................. ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ Các câu hỏi (tối đa 3 câu): ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ ............................................................................................................................................ Điểm bằng số: ..................................................... Điểm bằng chữ: .................................................. Tp. Hồ Chí Minh, ngày tháng năm NGƯỜI NHẬN XÉT (Ký tên và ghi rõ họ tên) 5 LỜI CÁM ƠN Để hoàn thành được đồ án tốt nghiệp này, em đã được sự trợ giúp rất nhiều của thầy cô, bạn bè và gia đình. Đầu tiên, em xin gởi lời cảm ơn đến Thầy, Cô khoa Công Nghệ Thông Tin trường Đại học Kỹ Thuật Công Nghệ đã tận tình dạy dỗ, dìu dắt em trong suốt bốn năm đại học. Em xin cảm ơn Thầy Hoàng Đức Quang, người tận tình hướng dẫn, giúp đỡ, động viên em trong quá trình tìm hiểu và thực hiện đề tài “Xây dựng từ điển multimedia dùng công nghệ Ajax trên nền PHP”. Cuối cùng, con cảm ơn Ba, Mẹ và những người thân đã khích lệ, động viên con trong thời gian học tập, nghiên cứu để có được kết quả như ngày nay. Tháng 1 năm 2009 Sinh viên Lê Thanh Nhàn 6 LỜI NÓI ĐẦU Trong thời đại ngày nay, chúng ta luôn hướng đến những gì đơn giản, gần gũi và tiện lợi trong mọi lĩnh vực. Công nghệ thông tin cũng không nằm ngoài mục tiêu này. Có điều đây là lĩnh vực có tốc độ thay đổi kinh ngạc, tính từng giây từng phút. Các công nghệ liên tục thay đổi và cũng liên tục ra đời các công nghệ mới thật phong phú, trợ giúp hữu ích cho các nhà quản trị và người sử dụng. Ajax có thể nói là một công nghệ khá mới, đặc biệt là ở Việt Nam nhưng nó được sử dụng ngày càng phổ biến vì khả năng tương tác cao, làm cho các ứng web gần với ứng dụng để bàn hơn. Ajax (Asynchronous JavaScript + XML) được tạo ra bởi Jesss James Garrett của Adaptive Path. Một số thành phần của Ajax đã được mô tả trước đây là Dynamic HTML và việc kịch bản hóa từ xa. Về mặt công nghệ, Ajax đưa ra các biểu thức cho các tiềm năng chưa thực hiện được trong các công nghệ trình duyệt web trước đây. Google và một số tổ chức chính khác đã sử dụng Ajax để xây dựng những gì có tính chất cộng đồng được mong đợi giống như những gì mà một ứng dụng web có thể thực hiện. Một số lượng lớn các kỹ thuật được sắp xếp để lấp đầy những thiếu sót với sự phong phú hơn, thông minh hơn hoặc về mặt cải tiến các client. Ajax cho phép thực hiện điều này tốt hơn, thông minh hơn mà chỉ sử dụng các kỹ thuật đã được cài đặt trên số lượng lớn các máy tính hiện đại. Một đặc điểm nữa cho thấy Ajax ngày càng được ứng dụng rộng rãi là nó độc lập với hệ điều hành (không phụ thuộc nền), xứ lý dữ liệu XML, sử dụng các JavaScript. Tóm lại, đây là một công nghệ thể hiện tính đáp ứng nhanh cao, thích hợp cho việc xây dựng các ứng dụng đòi hỏi tính tức thời trên môi trường web. Từ điển media trực tuyến là một ứng dụng điển hình. Và cũng là mục tiêu chính đồ án tốt nghiệp của em. 7 MỤC LỤC Phần 1: TÌM HIỂU VẤN ĐỀ Chương 1: TỔNG QUAN……………………………………………………….1 1. Tiền đề xuất hiện công nghệ Ajax…………………………………………1 1.1. Nguyên nhân xuất hiện công nghệ Ajax……………………………...1 1.2. Công nghê web thể hệ thứ hai – Web 2.0…………………………….4 1.3. Các thế mạnh của Ajax……………………………………………….9 2. Nhiệm vụ đồ án…………………………….……………………..……...12 Chương 2: MÔ HÌNH MVC…………………….…………………………….14 1. Giới thiệu mô hình MVC………………………………………………...14 2. View trong ứng dụng Ajax……………………………………….……....15 3. Controller trong ứng dụng Ajax………………………………….……....17 4. Model trong ứng dụng Ajax……………………………………….……..19 5. Ví dụ về mô hình MVC trên nền PHP…………………………….……..22 6. Mô hình MVC cho ứng dụng từ điển……………….……….…….……..30 Chương 3: CÁC CÔNG NGHỆ TRONG AJAX………………….…….……32 1. Cascading Style Sheet……………………….…………….….………….32 2. JavaScript………………………………………………………..……….35 3. DOM……………………………………………………………..………39 4. Đối tượng XMLHttpRequest……………………………….….………...43 4.1. Giới thiệu…………………………………………………..………..43 4.2. Phương thức, thuộc tính………………………………….…………45 4.3. Sự tương tác……………………………………………….………..46 4.4. Get và Post…………………………………………….……………49 4.5. Gởi Request…………………………………………….…………..50 5. Streaming…………………………………………………....………….53 5.1. Giới thiệu……………………………………………...…………...53 5.2. Các phương thức streaming……………………….……………….54 8 Phần 2: THIẾT KẾ VÀ CÀI ĐẶT Chương 4: THIẾT KẾ………………………………………………………56 1. Sơ đồ ứng dụng……………………………………………….……….56 2. Cơ sở dữ liệu………………………………………………….……….56 3. Cài đặt server………………………………………………………….57 Chương 5: CÁC MODULE, LỚP CHÍNH CỦA ỨNG DỤNG…….…….60 1. Hệ thống tập tin………………………………………….……………60 2. Các module của ứng dụng………………………………….…………60 3. Các lớp đối tượng chính trong từng module…………….……………60 Phần 3: KẾT QUẢ, ĐÁNH GIÁ VÀ HƯỚNG PHÁT TRIỂN 1. Kết quả thử nghiệm…………………………………….……….…….61 2. Hoạt động của ứng dụng………………………………..…………….61 3. Kết luận………………………………………………….…….….…..69 4. Hướng phát triển……………………………………….……..………70 9 Phần 1: TÌM HIỂU VẤN ĐỀ CHƯƠNG 1: TỔNG QUAN 1. TIỀN ĐỀ XUẤT HIỆN CÔNG NGHỆ AJAX 1.1. NGUYÊN NHÂN XUẤT HIỆN CÔNG NGHỆ AJAX Trước khi tìm hiểu về Ajax, ta cần xem xét quá trình phát triển các công nghệ web, nguyên nhân và hoàn cảnh xuất hiện công nghệ Ajax. Lúc đầu, các trang web là tĩnh, người dùng gửi yêu cầu một tài nguyên nào đó, và server sẽ trả về tài nguyên đó. Các trang Web không có gì hơn là một văn bản được định dạng và phân tán. Đối với các trình duyệt thì các trang web tĩnh không phải là các vấn đề khó khăn, và trang web lúc đầu chỉ để thông tin về các sự kiện, địa chỉ, hay lịch làm việc qua Internet mà thôi, chưa có sự tương tác qua các trang web. Năm 1990, Tim Berners-Lee, tại CERN, đã sáng chế ra HTML (Hyper Text Markup Language), ngôn ngữ đánh dấu siêu văn bản. HTML rất đơn giản, dễ dùng, và nó trở thành một ngôn ngữ rất phổ biến, cơ bản. Tuy nhiên, không lâu sau, nhu cầu về các trang web động, có sự tương tác ngày một tăng, chính vì thế sự ra đời các công nghệ web động là một điều tất yếu. Dưới đây là một số công nghệ web động cơ bản: JAVASCRIPT Netscape đã tạo ra một ngôn ngữ kịch bản gọi là JavaScript. JavaScript được thiết kế để việc phát triển dễ dàng hơn cho các nhà thiết kế web và các lập trình viên không thành thạo Java. (Microsoft cũng có một ngôn ngữ kịch bản gọi là VBScript). JavaScript ngay lập tức trở thành một phương pháp hiệu quả để tạo ra các trang web động. Việc coi các trang như là một đối tượng đã làm nảy sinh một khái niệm mới gọi là Document Object Model (DOM). Lúc đầu, JavaScript và DOM có một sự kết hợp chặt chẽ nhưng sau đó chúng được phân tách. DOM hoàn toàn là cách biểu diễn hướng đối tượng của trang web và nó có thể được sửa đổi với các ngôn ngữ kịch bản bất kỳ như JavaScript hay VBScript. 10 Tổ chức World Wide Web Consortium (W3C) đã chuẩn hóa DOM, trong khi European Computer Manufacturers Association (ECMA) phê duyệt JavaScript dưới dạng đặc tả ECMAScript. JSP/SERVLET, ASP VÀ PHP Cùng với Java, Sun đồng thời đưa ra một công nghệ mới gọi là Servlet. Các đoạn mã Java sẽ không chạy phía client như Applet; chúng sẽ được chạy trên một ứng dụng phía server. Servlet cũng đồng thời phục vụ các CGI script. Servlet là một bước tiến lớn, nó đưa ra một thư viện hàm API trên Java và một thư viện hoàn chỉnh để thao tác trên giao thức HTTP. JavaServer Page (JSP) là một công nghệ lập trình web của Sun, cùng với nó là một công nghệ khác của Microsoft - Active Server Pages (ASP). JSP là công nghệ đòi hỏi một trình chủ hiểu được Java. Microsoft đã nghiên cứu các nhược điểm của Servlet và tạo ra ASP dễ dàng hơn để thiết kế các trang web động. Microsoft thêm các bộ công cụ rất mạnh và sự tích hợp rất hoàn hảo với các web server. JSP và ASP có những nét tương đương vì chúng đều được thiết kế để phân tách quá trình xử lí khỏi quá trình biểu diễn. Có sự khác biệt về kỹ thuật, song cả hai đều cho phép các nhà thiết kế web tập trung vào cách bố trí (layout), trong khi các nhà phát triển phần mềm thì tập trung vào các kỹ thuật lập trình logic. Tất nhiên Microsoft và Sun không độc quyền ở các giải pháp phía server. Còn có các công nghệ khác, trong đó phải kể đến là PHP (Hypertext Preprocessor) cho tới Cold Fusion. Các công nghệ này cung cấp các bộ công cụ rất mạnh cho các nhà phát triển. PHP là gì PHP (viết tắt của Hypertext Preprocessor) là ngôn ngữ lập trình được kết nối chặc chẽ với máy chủ. Nói một cách đơn giản không theo thuật ngữ khoa học thì là một quá trình xử lý PHP được thực hiện trên máy chủ (Windows hoặc Unix). Khi một trang web muốn dùng PHP thì phải đáp ứng được tất cả các quá trình xử lý thông tin trong trang web đó, sau đó đưa ra kết quả như ngôn ngữ HTML. Vì quá trình xử lý này diễn 11 ra trên máy chủ nên trang web được viết bằng PHP sẽ dễ nhìn hơn ở bất kỳ hệ điều hành nào. Cũng giống hầu hết các ngôn ngữ lập trình khác, PHP có thể nối trực tiếp với HTML. Mã PHP tách biệt với HTML bằng các thực thể đầu và cuối. Khi một tài liệu được đưa ra phân tích, quá trình xử lý PHP chỉ được thực hiện ở những điểm quan trọng, rồi sau đó đưa ra kết quả. Nhưng bên cạnh đó, PHP cũng có khả năng tách biệt mã hoàn tòan với HTML. Nói rộng ra, việc đưa ra sự kết hợp này rất chi là lý tưởng, bởi vì nó cho phép các nhà thiết kết có thể làm việc trên trang web đã được bố trí theo kế hoạch mà không bị cản trở bởi các mã. Vì sao nên dùng PHP Không còn xa lạ gì khi có rất nhiều sự lựa chọn các ngôn ngữ lập trình khác ngoài PHP như ASP, Perl…và một số loại khác. Trong mỗi ngôn ngữ lập trình này đều có cấu hình và chức năng khác nhau nhưng chúng vẫn có thể đưa ra một kết quả giống nhau. Tại sao PHP lại là ưu tiên hàng đầu của bạn? Rất đơn giản, đối với những người còn xa lạ với chương trình, đây là sự lôi cuốn mạnh mẽ nhất. Thậm chí là rất ít hoặc không có một chương trình nào có thể tạo ra tốc độ đáng kinh ngạc trong việc phát triển web như PHP. Bởi vì nó được thiết kế đặc biệt trong các ứng dụng web. PHP xây dựng được rất nhiều tính năng để đáp ứng những nhu cầu chung nhất. PHP là một mã nguồn thông tin mở. Bởi vì mã nguồn của PHP sẵn có nên cộng đồng các nhà phát triển web luôn có ý thức cải tiến nó, nâng cao để khắc phục các lỗi trong chương trình này. PHP rất ổn định và tương hợp. PHP vận hành khá ổn định trên các hệ điều hành gồm cả Unix, Windows. Đồng thời nó chạy trên các máy chủ như IIS và Apache rất tốt. 12 Xét một cách toàn diện thì PHP là một ngôn ngữ rất dễ học. Nếu ta đã biết qua các ngôn ngữ như C hay Pascal thì việc học PHP sẽ rất mau, bởi nó có những nét tương đồng nhau. FLASH Năm 1996, FutureWave đã đưa ra sản phẩm FutureSplash Animator. Sau đó FutureWave thuộc sở hữu của Macromedia, và công ty này đưa ra sản phẩm Flash. Flash cho phép các nhà thiết kế tạo các ứng dụng hoạt họa và linh động. Flash không đòi hỏi các kỹ năng lập trình cao cấp và rất dễ học. Cũng giống như nhiều giải pháp khác Flash yêu cầu phần mềm phía client. Chẳng hạn như gói Shockwave Player plug- in có thể được tích hợp trong một số hệ điều hành hay trình duyệt. DHTML Khi Microsoft và Netscape đưa ra các phiên bản trình duyệt của họ, thì các nhà phát triển web có một lựa chọn mới: Dynamic HTML (DHTML). DHTML không phải là một chuẩn của W3C, nó giống một bộ công cụ thương mại hơn. Trong thực tế nó là một tập hợp gồm HTML, Cascading Style Sheets (CSS), Jav