Khóa luận Xây dựng hệ thống cung cấp dịch vụ nghe nhạc/xem video trực tuyến

MỞ ĐẦU Âm nhạc là một trong những lĩnh vực giải trí rất quan trọng. Theo số liệu từ Hiệp hội Công nghiệp Ghi âm Quốc tế (IFPI), doanh thu từ việc kinh doanh nhạc số hợp pháp trong sáu tháng đầu năm 2006 là 945 triệu USD, tăng 106% so với cùng kỳ năm trước. Trong vài năm trở lại đây, sự phát triển của CNTT nói chung và mạng Internet nói riêng, đã mang lại sức sống mới cho nhạc số. Ngày nay việc giải trí, nghe nhạc trực tuyến trên mạng Internet đã không còn là điều xa lạ đối với mỗi chúng ta. Hơn nữa, Internet đã mang lại những ưu thế đáng kể trong việc “phát hành”, “chia sẻ” . so với các phương tiện thông tin khác. Hiện nay ở Việt Nam cũng như trên thế giới đã có rất nhiều các website cho phép nghe nhạc, xem video trực tuyến. Trong khuôn khổ luận văn này, chúng tôi đề cập đến một hệ thống nghe nhạc, xem video clip trực tuyến được xây dựng trên nền Joomla. Về phía người sử dụng thì hệ thống này không khác gì so với một hệ thống website nghe nhạc thông thường. Nhưng với người phát triển, việc xây dựng hệ thống trên nền Joomla thuận tiện hơn rất nhiều so với việc xây dựng lại từ đầu 1 hệ thống nghe nhạc. Hệ thống cung cấp nhạc này sẽ bao gồm các chức năng cơ bản như quản lý nội dung về bài hát, ca sỹ, nhạc sỹ, album .vv và tím kiếm cơ bản. Ở phiên bản tiếp theo, chúng tôi dự định sẽ đưa thêm và hệ thống một chức năng mới, đó là tìm kiếm bài hát theo một giai điệu hoặc tiết tấu có sẵn. Giai điệu này có thể là một File dạng MIDI, hay một đoạn nhạc của bài hát, hoặc thậm chí là một đoạn tiếng huýt sáo do người sử dụng trực tiếp ghi lại thông qua Micro. Để phát triển tính năng này, chúng ta cần có một module xử lý các bài hát được tải lên và trích ra đoạn nhạc mẫu của bài hát đó. Sau đó lưu đoạn nhạc mẫu vào ngay cơ sở dữ liệu của bài hát đó. Một module để phân tích và so sánh các đoạn nhạc mẫu với đoạn nhạc cần tìm kiếm. Cuối cùng là một module xử lý đoạn nhạc yêu cầu tìm kiếm: đoạn nhạc này có thể là một File nhạc MIDI (từ các chương trình mô phỏng đàn Piano [14] ) một đoạn âm thanh do người dùng tự thu âm, hay là cả một bài hát. Chương 1. GIỚI THIỆU VỀ JOOMLA 1.1 Giới thiệu chung: 1.1.1 Hệ thống quản trị nội dung (CMS) CMS viết tắt của từ Content Management System (tạm dịch là Hệ thống quản trị nội dung), là một hệ thống phần mềm máy tính để thiết lập, tổ chức, tạo thuận tiện cho việc xây dựng các tài liệu hay các nội dung khác. Thông thường, CMS là một ứng dụng web sử dụng để quản lý các website và nội dung web. MỤC LỤC BẢNG CHÚ GIẢI THUẬT NGỮ 1 MỞ ĐẦU .2 Chương 1. GIỚI THIỆU VỀ JOOMLA 3 1.1 Giới thiệu chung: .3 1.1.1 Hệ thống quản trị nội dung (CMS) .3 1.1.2 Các ứng dụng chính của Joomla .3 1.2 Các thành phần chính của Joomla .6 1.2.1 Template .6 1.2.2 Components 8 1.2.3 Modules 8 1.2.4 Mambots .8 CHƯƠNG 2. GIỚI THIỆU PHP & MYSQL 9 2.1 PHP 9 2.1.1 Lịch sử phát triển của PHP .9 2.1.2 Cộng đồng sử dụng và phát triển PHP tại Việt Nam 12 2.1.3 Cấu trúc cơ bản của mã PHP 12 2.2 MySQL 14 2.2.1 Lịch sử phát triển 14 2.2.2 Một số từ khóa thông dụng trong SQL: 16 a. Lấy dữ liệu: 16 b. Sửa đổi dữ liệu : .16 c. Giao dịch dữ liệu: 17 CHƯƠNG 3. XÂY DỰNG HỆ THỐNG 18 3.1 Mô tả bài toán 18 3.2 Mô hình nghiệp vụ .18 3.2.1 Bảng phân tích xác định chức năng, tác nhân và hồ sơ 18 3.2.2 Biểu đồ ngữ cảnh hệ thống .19 3.2.3 Biểu đồ phân rã chức năng .20 3.2.4 Mô hình các chức năng cụ thể 20 3.2.5 Lập ma trận thực thể chức năng .21 3.3 Phân tích – Mô hình khái niệm logic 22 3.3.1 Biểu đồ luồng dữ liệu mức 0 22 3.3.2 Biểu đồ luồng dữ liệu mức 1 23 3.3.3 Mô hình khái niệm dữ liệu: mô hình E-R 24 a. Xây dựng được các thực thể 24 b. Xác định mối quan hệ và thuộc tính 24 c. Vẽ biểu đồ rút gọn .25 3.4 Thiết kế mô hình logic .26 3.4.1. Chuyển mô hình ER sang mô hình quan hệ 26 a. Biểu diễn các thực thể: 26 b. Biểu diễn các mối quan hệ .26 c. Chuẩn hóa: .26 d. Biểu đồ quan hệ của mô hình dữ liệu 27 3.4.2. Thiết kế cơ sở dữ liệu vật lý 27 3.4.2. Thiết kế cơ sở dữ liệu vật lý 28 a. Bảng: BÀI HÁT .28 b. Bảng: ALBUM 29 c. Bảng: CA SỸ .29 d. Bảng: NHẠC SỸ .30 e. Bảng: BÀI HÁT_ALBUM .30 f. Bảng: BÀI HÁT_CA SỸ .30 CHƯƠNG 4: ỨNG DỤNG THỰC TIỄN .31 4.1. Mô tả môi trường xây dựng và thử nghiệm ứng dụng .31 4.1.1 Mô tả môi trường xây dựng ứng dụng: 31 4.1.2 Các ứng dụng xây dựng thử nghiệm: .31 4.2 Giao diện của website 32 4.3. Đánh giá về hệ thống 41 4.3.1 Ưu điểm 41 4.3.2 Nhược điểm 41 4.4 Hướng phát triển trong tương lai .41 TÀI LIỆU THAM KHẢO .43

pdf49 trang | Chia sẻ: lvcdongnoi | Lượt xem: 3700 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Khóa luận Xây dựng hệ thống cung cấp dịch vụ nghe nhạc/xem video trực tuyến, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
......................................................................3 1.1.1 Hệ thống quản trị nội dung (CMS).................................................................3 1.1.2 Các ứng dụng chính của Joomla.....................................................................3 1.2 Các thành phần chính của Joomla .........................................................................6 1.2.1 Template .........................................................................................................6 1.2.2 Components ....................................................................................................8 1.2.3 Modules ..........................................................................................................8 1.2.4 Mambots .........................................................................................................8 CHƯƠNG 2. GIỚI THIỆU PHP & MYSQL..................................................................9 2.1 PHP........................................................................................................................9 2.1.1 Lịch sử phát triển của PHP.............................................................................9 2.1.2 Cộng đồng sử dụng và phát triển PHP tại Việt Nam....................................12 2.1.3 Cấu trúc cơ bản của mã PHP........................................................................12 2.2 MySQL ................................................................................................................14 2.2.1 Lịch sử phát triển..........................................................................................14 2.2.2 Một số từ khóa thông dụng trong SQL:........................................................16 a. Lấy dữ liệu:....................................................................................................16 b. Sửa đổi dữ liệu :.............................................................................................16 c. Giao dịch dữ liệu: ..........................................................................................17 CHƯƠNG 3. XÂY DỰNG HỆ THỐNG......................................................................18 3.1 Mô tả bài toán......................................................................................................18 3.2 Mô hình nghiệp vụ...............................................................................................18 3.2.1 Bảng phân tích xác định chức năng, tác nhân và hồ sơ................................18 3.2.2 Biểu đồ ngữ cảnh hệ thống...........................................................................19 3.2.3 Biểu đồ phân rã chức năng ...........................................................................20 3.2.4 Mô hình các chức năng cụ thể ......................................................................20 3.2.5 Lập ma trận thực thể chức năng ...................................................................21 3.3 Phân tích – Mô hình khái niệm logic ..................................................................22 3.3.1 Biểu đồ luồng dữ liệu mức 0 ........................................................................22 3.3.2 Biểu đồ luồng dữ liệu mức 1 ........................................................................23 3.3.3 Mô hình khái niệm dữ liệu: mô hình E-R ....................................................24 a. Xây dựng được các thực thể ..........................................................................24 b. Xác định mối quan hệ và thuộc tính..............................................................24 c. Vẽ biểu đồ rút gọn .........................................................................................25 3.4 Thiết kế mô hình logic.........................................................................................26 3.4.1. Chuyển mô hình ER sang mô hình quan hệ ................................................26 a. Biểu diễn các thực thể: ..................................................................................26 b. Biểu diễn các mối quan hệ.............................................................................26 c. Chuẩn hóa: .....................................................................................................26 d. Biểu đồ quan hệ của mô hình dữ liệu............................................................27 3.4.2. Thiết kế cơ sở dữ liệu vật lý ........................................................................27 3.4.2. Thiết kế cơ sở dữ liệu vật lý ........................................................................28 a. Bảng: BÀI HÁT.............................................................................................28 b. Bảng: ALBUM ..............................................................................................29 c. Bảng: CA SỸ .................................................................................................29 d. Bảng: NHẠC SỸ ...........................................................................................30 e. Bảng: BÀI HÁT_ALBUM ...........................................................................30 f. Bảng: BÀI HÁT_CA SỸ ...............................................................................30 CHƯƠNG 4: ỨNG DỤNG THỰC TIỄN.....................................................................31 4.1. Mô tả môi trường xây dựng và thử nghiệm ứng dụng .......................................31 4.1.1 Mô tả môi trường xây dựng ứng dụng: ........................................................31 4.1.2 Các ứng dụng xây dựng thử nghiệm: ...........................................................31 4.2 Giao diện của website..........................................................................................32 4.3. Đánh giá về hệ thống..........................................................................................41 4.3.1 Ưu điểm ........................................................................................................41 4.3.2 Nhược điểm ..................................................................................................41 4.4 Hướng phát triển trong tương lai.........................................................................41 TÀI LIỆU THAM KHẢO .............................................................................................43 BẢNG CHÚ GIẢI THUẬT NGỮ Chữ viết tắt / Ký hiệu Tên tiếng anh Giải nghĩa CSDL Cơ sở dữ liệu Website Trang web MySQL Hệ thống quản lý Cơ sở dữ liệu quan hệ, sử dụng Ngôn ngữ truy vấn có cấu trúc File Tập tin (dữ liệu được lưu trữ trên đĩa cứng) HTML Ngôn ngữ đánh dấu siêu văn bản PHP Ngôn ngữ lập trình web PHP Javascript Một dạng mã kịch bản Framework Môi trường làm việc CSS Cascading Style Sheets CMS Content Management System (Hệ quản trị nội dung) Template Khuôn mẫu (thường dùng cho một trang web) Components Thành phần của Joomla Modules Thành Phần của Joomla Mambots Thành Phần của Joomla Engine Một phương tiện, dụng cụ Chương 4: Ứng dụng thực tiễn MỞ ĐẦU Âm nhạc là một trong những lĩnh vực giải trí rất quan trọng. Theo số liệu từ Hiệp hội Công nghiệp Ghi âm Quốc tế (IFPI), doanh thu từ việc kinh doanh nhạc số hợp pháp trong sáu tháng đầu năm 2006 là 945 triệu USD, tăng 106% so với cùng kỳ năm trước. Trong vài năm trở lại đây, sự phát triển của CNTT nói chung và mạng Internet nói riêng, đã mang lại sức sống mới cho nhạc số. Ngày nay việc giải trí, nghe nhạc trực tuyến trên mạng Internet đã không còn là điều xa lạ đối với mỗi chúng ta. Hơn nữa, Internet đã mang lại những ưu thế đáng kể trong việc “phát hành”, “chia sẻ” ... so với các phương tiện thông tin khác. Hiện nay ở Việt Nam cũng như trên thế giới đã có rất nhiều các website cho phép nghe nhạc, xem video trực tuyến. Trong khuôn khổ luận văn này, chúng tôi đề cập đến một hệ thống nghe nhạc, xem video clip trực tuyến được xây dựng trên nền Joomla. Về phía người sử dụng thì hệ thống này không khác gì so với một hệ thống website nghe nhạc thông thường. Nhưng với người phát triển, việc xây dựng hệ thống trên nền Joomla thuận tiện hơn rất nhiều so với việc xây dựng lại từ đầu 1 hệ thống nghe nhạc. Hệ thống cung cấp nhạc này sẽ bao gồm các chức năng cơ bản như quản lý nội dung về bài hát, ca sỹ, nhạc sỹ, album...vv và tím kiếm cơ bản. Ở phiên bản tiếp theo, chúng tôi dự định sẽ đưa thêm và hệ thống một chức năng mới, đó là tìm kiếm bài hát theo một giai điệu hoặc tiết tấu có sẵn. Giai điệu này có thể là một File dạng MIDI, hay một đoạn nhạc của bài hát, hoặc thậm chí là một đoạn tiếng huýt sáo do người sử dụng trực tiếp ghi lại thông qua Micro. Để phát triển tính năng này, chúng ta cần có một module xử lý các bài hát được tải lên và trích ra đoạn nhạc mẫu của bài hát đó. Sau đó lưu đoạn nhạc mẫu vào ngay cơ sở dữ liệu của bài hát đó. Một module để phân tích và so sánh các đoạn nhạc mẫu với đoạn nhạc cần tìm kiếm. Cuối cùng là một module xử lý đoạn nhạc yêu cầu tìm kiếm: đoạn nhạc này có thể là một File nhạc MIDI (từ các chương trình mô phỏng đàn Piano [14] ) một đoạn âm thanh do người dùng tự thu âm, hay là cả một bài hát. Chương 1: Giới thiệu Joomla Chương 1. GIỚI THIỆU VỀ JOOMLA 1.1 Giới thiệu chung: 1.1.1 Hệ thống quản trị nội dung (CMS) CMS viết tắt của từ Content Management System (tạm dịch là Hệ thống quản trị nội dung), là một hệ thống phần mềm máy tính để thiết lập, tổ chức, tạo thuận tiện cho việc xây dựng các tài liệu hay các nội dung khác. Thông thường, CMS là một ứng dụng web sử dụng để quản lý các website và nội dung web. 1.1.2 Các ứng dụng chính của Joomla Joomla là một hệ thống quản trị nội dung CMS, trợ giúp rất tốt cho việc xây dựng một websites và những ứng dụng trực tuyến khác. Ở thời điểm hiện nay, Joomla là một trong những hệ thống quản trị nội dung CMS khá thành công. Với việc đạt được cột mốc 100 ngàn thành viên đăng ký tại diễn đàn Joomla trở thành CMS mã nguồn mở có số lượng thành viên rất đông đảo. Đồng thời việc trao đổi, giúp đỡ lẫn nhau giữa các thành viên trong cộng đồng trở nên thuận tiện và nhanh chóng hơn. Và hơn hết, Joomla là một giải pháp mã nguồn mở, nó miễn phí cho tất cả mọi người. Hệ thống Joomla có khả năng quản trị nội dung tương đối đa dạng, vì thế khi một người phát triển muốn xây dựng một ứng dụng bất kỳ, thì có thể dựa trên rất nhiều thứ có sẵn mà Joomla cung cấp. Không những cung cấp đầy đủ các công cụ quản lý nội dung, Joomla còn rất dễ dàng mở rộng thêm thông qua việc cài đặt các module, component, template .... Hiện nay Joomla được sử dụng trên toàn thế giới để cung cấp mọi thứ, từ đơn giản như các trang web cá nhân, tới những ứng dụng web phức tạp. Dưới đây là một vài ứng dụng mà Joomla thường được sử dụng để xây dựng: * Corporate websites or portals : Website của công ty hay cổng giao tiếp * Online commerce : Thương mại trực tuyến * Small business websites : Website kinh doanh nhỏ * Non-profit and organizational websites : Website các tổ chức phi lợi nhuận * Government applications : Các ứng dụng cho chính phủ Chương 1: Giới thiệu Joomla * School and church websites : Website trường học nhà thờ * Personal or family homepages : Website cá nhân, gia đình * Community-based portals : Cổng kết nổi cơ bản * Magazines and newspapers : Website các tạp chí và báo điện tử ... những ví dụ trên cho thấy khả năng của Joomla không hề có giới hạn. Gói Joomla cơ bản được thiết kế để dễ dàng cài đặt, thậm chí cho những người không phải là lập trình viên máy tính. Phần lớn người sử dụng không gặp phải trở ngại nào khi cài đặt và chạy hệ thống Joomla, và có rất nhiều sự hỗ trợ cho những người mới sử dụng. Joomla có một cộng đồng năng động, đang phát triển với trên 100,000 thành viên, họ là những người sử dụng thông thường hay các nhà lập trình chuyên nghiệp. Một hệ thống Joomla được cài đặt và chạy, nó thậm chí đơn giản cho những người dùng không phải là người phát triển ứng dụng web chuyên nghiệp, đều có thể thêm hay chỉnh sửa nội dung, cập nhật ảnh, và quản lý những dữ liệu phản hồi... Bất kỳ ai với những kỹ năng xử lý web cơ bản đều có thể dễ dàng học cách quản lý một site Joomla. Joomla làm công việc quản lý nội dung khá tốt, yếu tố này làm cho một site Joomla trở nên đơn giản hơn rất nhiều trong việc quản lý. Nhưng với nhiều người, sức mạnh thực sự của Joomla nằm trong Framework ứng dụng, nhờ nó mà hàng nghìn nhà phát triển chuyên nghiệp trên toàn thế giới có thể tạo ra những add-ons và extensions tương đối mạnh. Sau đây là một vài ví dụ trong hàng nghìn extension sẵn có dành cho Joomla: * Dynamic form builders : Xây dựng form động * Business or organizational directories : Các danh bạ tổ chức hoặc kinh doanh * Document management : Quản lý tài liệu * image and multimedia galleries : Triển lãm ảnh và đa phương tiện * E-commerce and shopping cart engines: Các máy bán hàng và thương mại điện tử Chương 1: Giới thiệu Joomla * Forums and chat software : Phần mềm chat và forum. * Calendars : Quản lý thời gian biểu * Blogging software : Phần mềm blog * Directory services : Dịch vụ danh bạ * Email newsletters : Thư dưới dạng tin tức mới * Data collection and reporting tools : Các công cụ báo cáo và tập hợp dữ liệu * Banner advertising systems : Các hệ thống banner quản cáo * Subscription services : Các dịch vụ thuê bao Và rất nhiều các extension khác nữa mà chúng ta có thể tìm thấy tại mục Joomla Extension tại địa chỉ Nhưng thông thường, tại các công ty lớn thì yêu cầu của họ xa hơn những gì được cung cấp miễn phí của Joomla, vì thế họ có thể mua những Extension hướng tới mục đích cụ thể của họ từ các nhà phát triển web chuyên nghiệp. Joomla mang đến một Framework ứng dụng với đầy đủ sức mạnh để có thể làm cho công việc tạo ra các add-on của những nhà phát triển trở nên đơn giản hơn. Những add-on phức tạp này sử dụng sức mạnh của Joomla, gần như không có giới hạn về mặt phương tiện. Sử dụng lõi framework, những nhà phát triển có thể dễ dàng xây dựng: * Integrated e-commerce systems : Hệ thống tích hợp thương mại điện tử * Inventory control systems : Hệ thống điều khiển thống kê * Data reporting tools : Các công cụ báo cáo dữ liệu * Custom product catalogs : Các catalog sản phẩm * Complex business directories : Các danh mục kinh doanh phức tạp * Reservation systems : Hệ thống dành riêng * Communication tools : Các công cụ kết nối * Application bridges : Các cầu nối ứng dụng … Chương 1: Giới thiệu Joomla Nếu công ty hay tổ chức thuê một nhà phát triển ứng dụng Joomla thứ ba có sử dụng Joomla Framework, thì họ đang xây dựng trên một platform mở, nó không rằng buộc họ với bất kỳ một nhà phát triển hay một quyền sở hữu nào. Tất cả những thông tin cần thiết về việc phát triển trên Joomla! Framework đều được công bố rộng rãi trên trang chủ của Joomla, hoặc trong diễn đàn chính thức của cộng đồng Joomla Và nếu như ai đó có bất kỳ ý tưởng nào để phát triển Joomla! Framework hay những sản phẩm đã hoàn thiện thì họ đều có thể phân phát tới cộng đồng Joomla thông qua mạng này. Điều cuối cùng cần nhắc lại là Joomla miễn phí, mở và sẵn sàng cho tất cả mọi người theo giấy phép bản quyền GPL (General Public License). Những người tạo ra Joomla không thể hứa rằng có thể đáp ứng được mọi yêu cầu trên toàn thế giới. Nhưng với đa số những ứng dụng web, phần mềm của họ là tương đối hoàn hảo cho công việc. Nhóm phát triển Joomla đang thêm những tính năng mới cho mỗi phiên bản phát hành về sau này. 1.2 Các thành phần chính của Joomla Công viêc cài đặt một bản Joomla khá đơn giản. Người sử dụng chỉ cần tải một bản Joomla từ trang chủ của Joonla về , giải nén ra, copy vào thư mục localhost và truy cập vào File index trên trình duyệt để bắt đầu quá trình cài đặt. Sau khi cài đặt xong và chạy thành công Joomla, điều đầu tiên bạn cần quan tâm, đó chính là thành phần giao diện phía người dùng của website – Templates. 1.2.1 Template Template và những File liên quan tới nó cung cấp một cái nhìn trực quan cho website của bạn theo kiểu “look and feel” và được duy trì tách biệt với nội dung website. Template được lưu trữ trong một cơ sở dữ liệu MySQL Một bản Joomla điểm hình đã được cài đặt sẽ bao gồm 2 Templates có sẵn, đó là: madeyourweb và rhuk_solaflare_ii. Các File Template được đặt trong thư mục Templates, trong thư mục gốc, và mỗi một Template thường bao gồm những File sau: Chương 1: Giới thiệu Joomla Tên File Chi tiết Index.php File này chứa những mã HTML, PHP và có thể cả JavaScript, sẽ cung cấp Framework cho phần phác hoạ website của bạn. Bằng việc kết hợp với File .css và các File ảnh, nó tạo nên tất cả những thiết kế và các yếu tố sắp đặt nội dung trên wesite của bạn. templateDetails.xml File này định nghĩa cách sử dụng template và chứa các tham chiếu tới tất cả các File được sử dụng, ví dụ index.PHP, .css File ...vvv template_thumbnail.png File ảnh này được sử dụng trong phần quản lý Template, nếu nó được bật, một hình nhỏ hiển thị File Template_thumbnail.png chính là giao diện của Template tương ứng. File ảnh này phải được đặt trong thư mục Template template_css.css Được đặt trong thư mục css, File CSS này chứa các đoạn mã để xử lý yếu tố trực quan của website, ví dụ: phông chữ, cỡ chữ, màu sắc ..vvv... Có thể có rất nhiều File CSS mà bạn muốn cung cấp tham chiếu HTML thích hợp trong File index.PHP. Ví dụ: <?php echo "<link rel=\"stylesheet\" href=\"$GLOBALS[mosConfig_live_site]/ Templates/$GLOBALS[cur_Template] /css/Template_css.css\" type=\"text/css\"/>" ; ?> Image Files Những File này được đặt trong thư mục ảnh và có thể có đuôi mở rộng là .gif, .jpg, hoặc .png. Chúng cung cấp những yếu tố đồ hoạ cho phần phác thảo website. Chương 1: Giới thiệu Joomla 1.2.2 Components Components là thành phần cốt lõi trong các chức năng chính Joomla! Và được hiển thị trong phần thân chính ở template của website. Phần lõi trong phần thân chính sẽ xuất hiện trong template như sau: . Điều này tuỳ thuộc vào mục đích khi thiết kế website, nhưng thường thì nó sẽ nằm ở phần chính giữa của trang web. Một hệ thống Joomla điển hình đi kèm với các Components được cung cấp sẵn như: Banners, Contacts, News Feeds, Polls, và Web Links . Các thành viên của cộng đồng Joomla đều có thể đưa ra những Components do chính họ viết lên trang [2] để các thành viên khác tham khảo và góp ý. Và cũng tại trang [2]có danh sách tải về những Component mở rộng. 1.2.3 Modules Module là một phần nhỏ trong content và nó sẽ được hiển thị ở bất cứ nơi nào mà template cho phép. Modules rất dễ dàng cài đặt trong phần Administrator Section (phía người quản trị), và nó mở rộng ra những khả năng mới của Joomla!. Modules của Joomla có thể bao gồm: Main Menu, Top menu, Template Chooser, Polls, Newsflash, Hit Counter... Các thành viên của cộng đồng Joomla liên tục tạo ra những Modules với những tính năng mới. Và những modules này được cung cấp hoàn toàn miễn phí trên trang [2]. Sau đây là một ví dụ đơn giản về mã lệnh để tải một Modules: <?php mosLoadModules ( 'user1' ); ?>. 1.2.4 Mambots Mambots là một hàm, có chức năng định hướng nhiệm vụ. Thông thường nó sẽ ngăn lại content và điều chỉnh nó trước khi cho hiển thị. Joomla cũng cung cấp một số Mambot trong các gói cài , ví dụ như {mospagebreak}, {mosimage} Chương 2: Giới thiệu PHP & MySQL CHƯƠNG 2. GIỚI THIỆU PHP & MYSQL 2.1 PHP 2.1.1 Lịch sử phát triển của PHP Năm 1995, Rasmus Lerdorf tạo ra PHP và được công bố với tên gọi ban đầu là PHP/FI. PHP/FI được xem như là một tập con đơn giản của các mã kịch bản Perl để theo dõi tình hình truy cập đến bản sơ yếu lý lịch của ông trên mạng. Ông đã đặt tên cho bộ mã kịch bản này là 'Personal Home Page Tools'. Khi cần đến các chức năng rộng hơn, Rasmus đã viết ra một bộ thực thi bằng C lớn hơn để có thể truy vấn tới các cơ sở dữ liệu và giúp cho người sử dụng phát triển các ứng dụng web đơn giản. Rasmus đã quyết định công bố mã nguồn của PHP/FI cho mọi người xem, sử dụng cũng như sửa các lỗi có trong nó đồng thời cải tiến mã nguồn. PHP/FI, là viết tắt từ "Personal Home Page/Forms Interpreter", bao gồm một số các chức năng cơ bản cho PHP như ta đã biết đến ngày nay. Nó có các biến kiểu như Perl, thông dịch tự động các biến của form và cú pháp HTML nhúng. Cú pháp này giống như của Perl, mặc dù hạn chế hơn nhiều, đơn giản và có phần thiếu nhất quán. Vào năm 1997, PHP/FI 2.0, lần viết lại thứ hai của phiên bản C, đã thu hút được hàng ngàn người sử dụng trên toàn thế giới với xấp xỉ 50.000 tên miền đã được ghi nhận là có cài đặt nó, chiếm khoảng 1% số tên miền có trên mạng Internet. Tuy đã có tới hàng nghìn người tham gia đóng góp vào việc tu chỉnh mã nguồn của dự án này thì vào thời đó nó vẫn chủ yếu chỉ là dự án của một người. Không lâu sau khi công bố PHP/FI, bản PHP 3.0 là phiên bản đầu tiên cho chúng ta thấy một hình ảnh gần gũi với các phiên bản PHP mà chúng ta được biết ngày nay. Nó đã được Andi Gutmans và Zeev Suraski tạo ra năm 1997 sau khi viết lại hoàn toàn bộ mã nguồn trước đó. Lý do chính mà họ đã tạo ra phiên bản này là do nhận họ thấy PHP/FI 2.0 hết sức yếu kém trong việc phát triển các ứng dụng thương mại điện tử mà họ đang xúc tiến trong một dự án của trường đại học. PHP 3.0 như là phiên bản thế hệ kế tiếp của PHP/FI 2.0, và chấm dứt phát triển PHP/FI 2.0. Một trong những sức mạnh lớn nhất của PHP 3.0 là các tính năng mở rộng mạnh mẽ của nó. Ngoài khả năng cung cấp cho người dùng cuối một cơ sở hạ tầng chặt chẽ dùng cho nhiều cơ sở dữ liệu, giao thức và API khác nhau, các tính năng mở rộng của Chương 2: Giới thiệu PHP & MySQL PHP 3.0 đã thu hút rất nhiều nhà phát triển tham gia và đề xuất các mô đun mở rộng mới. Hoàn toàn có thể kết luận được rằng đây chính là điểm mấu chốt dẫn đến thành công vang dội của PHP 3.0. Các tính năng khác được giới thiệu trong PHP 3.0 gồm có hỗ trợ cú pháp hướng đối tượng và nhiều cú pháp ngôn ngữ nhất quán khác. Ngôn ngữ hoàn toàn mới đã được công bố dưới một cái tên mới, xóa bỏ mối liên hệ với việc sử dụng vào mục đích cá nhân hạn hẹp mà cái tên PHP/FI 2.0 gợi nhắc. Nó đã được đặt tên ngắn gọn là 'PHP', một kiểu viết tắt hồi quy của "PHP: Hypertext Preprocessor". Vào cuối năm 1998, PHP đã phát triển được con số cài đặt lên tới hàng chục ngàn người sử dụng và hàng chục ngàn Web site báo cáo là đã cài nó. Vào thời kì đỉnh cao, PHP 3.0 đã được cài đặt cho xấp xỉ 10% số máy chủ Web có trên mạng Internet. PHP 3.0 đã chính thức được công bố vào tháng 6 năm 1998, sau thời gian 9 tháng được cộng đồng kiểm nghiệm. Vào mùa đông năm 1998, ngay sau khi PHP 3.0 chính thức được công bố, Andi Gutmans và Zeev Suraski đã bắt đầu bắt tay vào việc viết lại phần lõi của PHP. Mục đích thiết kế là nhằm cải tiến tốc độ xử lý các ứng dụng phức tạp, và cải tiến tính mô đun của cơ sở mã PHP. Những ứng dụng như vậy đã chạy được trên PHP 3.0 dựa trên các tính năng mới và sự hỗ trợ khá nhiều các cơ sở dữ liệu và API của bên thứ ba, nhưng PHP 3.0 đã không được thiết kế để xử lý các ứng dụng phức tạp như thế này một cách có hiệu quả. Một Engine mới, có tên 'Zend Engine' (ghép từ các chữ đầu trong tên của Zeev và Andi), đã đáp ứng được các nhu cầu thiết kế này một cách thành công, và lần đầu tiên được giới thiệu vào giữa năm 1999. PHP 4.0, dựa trên Engine này, và đi kèm với hàng loạt các tính năng mới bổ sung, đã chính thức được công bố vào tháng 5 năm 2000, gần 2 năm sau khi bản PHP 3.0 ra đời. Ngoài tốc độ xử lý được cải thiện rất nhiều, PHP 4.0 đem đến các tính năng chủ yếu khác gồm có sự hỗ trợ nhiều máy chủ Web hơn, hỗ trợ phiên làm việc HTTP, tạo bộ đệm thông tin đầu ra, nhiều cách xử lý thông tin người sử dụng nhập vào bảo mật hơn và cung cấp một vài các cấu trúc ngôn ngữ mới. Với PHP 4.0, số nhà phát triển dùng PHP đã lên đến hàng trăm nghìn và hàng triệu site đã công bố cài đặt PHP, chiếm khoảng 20% số tên miền trên mạng Internet. Chương 2: Giới thiệu PHP & MySQL Nhóm phát triển PHP cũng đã lên tới con số hàng nghìn người và nhiều nghìn người khác tham gia vào các dự án có liên quan đến PHP như PEAR, PECL và tài liệu kĩ thuật cho PHP. Mặc dù PHP 4.0 đã thành công hết sức to lớn, nhưng nhóm phát triển PHP đã nhanh chóng nhận ra những yếu kém của nó, đặc biệt với khả năng hỗ trợ lập trình hướng đối tượng (OOP), xử lý XML, không hỗ trợ giao thức máy khách mới của MySQL 4.1 và 5.0, hỗ trợ dịch vụ web yếu. Những điểm này chính là mục đích để Zeev và Andi viết Zend Engine 2.0, lõi của PHP 5.0. Ngày 29 tháng 6 năm 2003, PHP 5 Beta 1 đã chính thức được công bố. Đó cũng là phiên bản đầu tiên của Zend Engine 2.0. Phiên bản Beta 2 sau đó đã ra mắt vào tháng 10 năm 2003 với sự xuất hiện của hai tính năng rất được chờ đợi: “Iterators”, “Reflection” nhưng “Namespaces” một tính năng gây tranh cãi khác đã bị loại khỏi mã nguồn. Ngày 21 tháng 12 năm 2003: PHP 5 Beta 3 đã được công bố để kiểm tra với việc phân phối kèm với Tridy, bỏ hỗ trợ Windows 95, khả năng gọi các hàm PHP bên trong XSLT, sửa chữa nhiều lỗi và thêm khá nhiều hàm mới. PHP 5 bản chính thức đã ra mắt ngày 13 tháng 7 năm 2004 sau một chuỗi khá dài các bản kiểm tra thử bao gồm Beta 4, RC1, RC2, RC3. Mặc dù coi đây là phiên bản sản xuất đầu tiên nhưng PHP 5.0 vẫn còn một số lỗi trong đó đáng kể là lỗi xác thực HTTP. Ngày 14 tháng 7 năm 2005, PHP 5.1 Beta 3 được PHP Team công bố đánh dấu sự chín muồi mới của PHP với sự có mặt của PDO, một nỗ lực trong việc tạo ra một hệ thống API nhất quán trong việc truy cập cơ sở dữ liệu và thực hiện các câu truy vấn. Ngoài ra, trong PHP 5.1, các nhà phát triển PHP tiếp tục có những cải tiến trong nhân Zend Engine 2, nâng cấp mô đun PCRE lên bản PCRE 5.0 cùng những tính năng và cải tiến mới trong SOAP, streams và SPL Hiện nay phiên bản tiếp theo của PHP đang được phát triển, bản PHP 6 dùng thử có thể được tải tại [6]. Phiên bản PHP 6 được kỳ vọng sẽ lấp đầy những khiếm khuyết của PHP ở phiên bản hiện tại, ví dụ: hỗ trợ Namespace (hiện tại các nhà phát triển vẫn chưa công bố rõ ràng về vấn đề này); hỗ trợ Unicode; sử dụng PDO làm API chuẩn cho việc truy cập cơ sở dữ liệu, các API cũ sẽ bị đưa ra thành thư viện PECL... Chương 2: Giới thiệu PHP & MySQL 2.1.2 Cộng đồng sử dụng và phát triển PHP tại Việt Nam Đa số các doanh nghiệp ở Việt Nam hiện nay sử dụng PHP thay cho các công nghệ khác. Lý do tương đối đơn giản, đó là vì chi phí cho công nghệ PHP thấp hơn, rất phù hợp cho cách doanh nghiệp vừa và nhỏ, với những ứng dụng không đòi hỏi tính toán nhiều và độ phức tạp cao. Theo những thống kê mới nhất [7] , tại Thành phố Hà Nội, tỷ lệ sử dụng ASP.NET/PHP là 1/2,5 còn tỷ lệ này ở Thành phố Hồ Chí Minh là 1/2,3. Những nỗ lực đầu tiên để phổ biến PHP trong đó có dự án xây dựng “Chuẩn viết mã PHP tiếng Việt” đã được xúc tiến. Ngày 24 tháng 10 năm 2004, nhóm PHPVietnam đã đề xuất xây dựng PHPVietnam Mailing List đầu tiên trên Google Groups [8]. Tại đây cũng đã diễn ra những thảo luận để xây dựng diễn đàn cho cộng đồng PHP Việt Nam. Có thể nói, tính đến thời điểm hiện tại, người Việt chưa đóng góp được gì nhiều cho cộng đồng PHP trên thế giới. Đóng góp lớn nhất ghi nhận đến hiện nay là sự xuất hiện của PHP Designer 2007 do Michael Pham (quốc tịch Việt Nam và Đan Mạch) xây dựng [13]. Chủ yếu sự tham gia của cộng đồng PHP tại Việt Nam là thông qua việc dịch các tập tin ngôn ngữ và dựa trên những ứng dụng PHP sẵn có với chút sửa đổi để tạo nên các hệ thống thông tin thuần Việt như NukeViệt của nhóm NukeViệt. Cộng đồng PHP người Việt hiện nay cũng cho ra đời khá nhiều script miễn phí PHP để giúp phát triển PHP ở Việt Nam. Ngoài ra còn có một số người đã biên dịch các sách PHP ra tiếng Việt, tạo những điều kiện thuận lợi hơn cho những người mới tham gia vào cộng đồng PHP. 2.1.3 Cấu trúc cơ bản của mã PHP PHP là một ngôn ngữ lập trình kịch bản hay một loại mã lệnh chủ yếu được dùng để phát triển các ứng dụng viết cho máy chủ, mã nguồn mở, dùng cho mục đích tổng quát. Nó rất thích hợp vrới web và có thể dễ dàng nhúng vào trang HTML. Do được tối ưu hóa cho các ứng dụng web, tốc độ nhanh, nhỏ gọn, cú pháp giống C và Java, dễ học và thời gian xây dựng sản phẩm tương đối ngắn hơn so với các ngôn ngữ khác nên PHP đã nhanh chóng trở thành một ngôn ngữ lập trình web phổ biến nhất thế giới. Chương 2: Giới thiệu PHP & MySQL Đoạn mã sau minh họa cách viết PHP lồng vào các trang HTML : Mã mẫu <?php echo "Chào thế giới PHP!"; ?> Thẻ sẽ đánh đấu sự bắt đầu và sự kết thúc của phần mã PHP qua đó máy chủ biết để xử lý và dịch mã cho đúng. Đây là một điểm khá tiện lợi của PHP giúp cho việc viết mã PHP trở nên khá trực quan và dễ dàng trong việc xây dựng phần giao diện ứng dụng HTTP. PHP xử lý các biến rất linh động. Nó có thể nhận biết được kiểu của biến và làm cho cú pháp câu lệnh đơn giản hơn. Ai đã từng lập trình với C, Java sẽ cảm thấy rất dễ dàng khi sử dụng PHP. Tuy nhiên việc dễ dài này lại gây ra một vài trở ngại. Trong PHP tất cả các biến số được bắt đầu bằng dấu $. Dù cho biến của bạn là kiểu chuỗi, nguyên hay thập phân hoặc thậm chí là mảng thì chúng không có gì khác biệt nhau. PHP chỉ theo dõi dữ liệu chứa trong biết thay đổi như thế nào mà thôi. Nói chung khi làm việc với PHP chúng ta cần quan tâm đến 3 vị trí khác nhau của biến đó là : 1- Khai báo ngay trong mã lệnh PHP. 2- Chuyển tiếp từ một trang HTML. 3- Là biến sẵn có của hệ thống PHP. Chương 2: Giới thiệu PHP & MySQL 2.2 MySQL MySQL là một ngôn ngữ máy tính phổ biến để tạo, sửa, và lấy dữ liệu từ một hệ quản trị cơ sở dữ liệu quan hệ. Ngôn ngữ này phát triển vượt xa so với mục đích ban đầu là để phục vụ các hệ quản trị cơ sở dữ liệu đối tượng-quan hệ. Nó là một tiêu chuẩn ANSI/ISO. 2.2.1 Lịch sử phát triển Từ một bài báo tham dự hội thảo khoa học A Relational Model of Data for Large Share Data Banks (tạm dịch là "Mô hình quan hệ cho dữ liệu dùng trong ngân hàng dữ liệu chia sẻ có khối lượng lớn") của tiến sĩ Edgar F. Codd xuất bản tháng 6 năm 1970 trong tạp chí Communications of the ACM của Hiệp hội ACM, một mô hình đã được chấp nhận rộng rãi là mô hình tiêu chuẩn dùng cho hệ thống quản lý cơ sở dữ liệu quan hệ. Giữa những năm 1970, một nhóm các nhà phát triển tại trung tâm nghiên cứu của IBM tại San Jose phát triển hệ thống cơ sở dữ liệu "Hệ thống R" dựa trên mô hình của Codd. Structured English Query Language, viết tắt là "SEQUEL" (tạm dịch là "Ngôn ngữ truy vấn tiếng Anh có cấu trúc"), được thiết kế để quản lý và truy lục dữ liệu được lưu trữ trong “Hệ thống R”. Sau này, tên viết tắt SEQUEL được rút gọn thành SQL để tránh việc tranh chấp nhãn hiệu (từ SEQUEL đã được một công ty máy bay của UK là Hawker-Siddeley đăng ký). Mặc dù SQL bị ảnh hưởng bởi công trình của tiến sĩ Codd nhưng nó không do tiến sĩ Codd thiết kế ra. Ngôn ngữ SEQUEL được thiết kế bởi Donald D. Chamberlin và Raymond F. Boyce tại IBM, và khái niệm của họ được phổ biến để tăng sự chú ý về SQL. Phiên bản cơ sở dữ liệu quan hệ phi thương mại, không hỗ trợ SQL đầu tiên được phát triển năm 1974.(Ingres from U.C. Berkeley.) Năm 1978, việc thử nghiệm phương pháp được khởi đầu tại một cơ sở thử nghiệm của khách hàng. Cuộc thử nghiệm đã chứng minh được sự có ích và tính thực tiễn của hệ thống và đã chứng tỏ sự thành công của IBM. Dựa vào kết quả đó, IBM bắt đầu phát triển các sản phẩm thương mại bổ xung thêm SQL dựa trên nguyên mẫu Hệ thống R bao gồm System/38 (Hệ thống/38) (được công bố năm 1978 và được thương mại hóa tháng 8 năm 1979, SQL/DS (được giới thiệu vào năm 1981) và DB2 (năm 1983). Cùng thời điểm đó Relational Software, Inc. (bây giờ là Oracle Corporation) đã nhận thấy tiềm năng của những khái niệm được Chamberlin and Boyce đưa ra và đã phát triển phiên bản Hệ quản trị cơ sở dự liệu quan hệ riêng của họ cho Navy, CIA và Chương 2: Giới thiệu PHP & MySQL các tổ chức khác. Vào mùa hè năm 1979, Relational Software, Inc. giới thiệu Oracle V2 (Phiên bản 2), phiên bản thương mại đầu tiên hỗ trợ SQL cho máy tính VAX. Oracle thường xuyên được nhắc tới một cách không nghiêm túc vì đã tấn công thị trường của IBM trong 2 năm, nhưng việc táo bạo nhất trong quan hệ công chúng của họ là tấn công một phiên bản của IBM System/38 chỉ trong có vài tuần. Tương lai của Oracle đã được đảm bảo vì có sự quan tâm đáng kể của công chúng sau đó mới phát triển, trong khi đã có nhiều phiên bản của các nhà cung cấp khác. IBM đã quá chậm trong việc phát triển SQL và các sản phẩm quan hệ, có lẽ vì ban đầu nó không dùng được trong môi trường Unix và máy tính lớn (Mainframe), và họ sợ nó sẽ làm giảm lợi nhuận thu được từ việc bán các sản phẩm cơ sở dữ liệu IMS (những sản phẩm dựa trên mô hình cơ sở dữ liệu định hướng chứ không phải cơ sở dữ liệu quan hệ) của mình. Trong lúc đó, Oracle vẫn đang phát triển, IBM đang phát triển System/38, được mong đợi là hệ cơ sở dữ liệu quan hệ đầu tiên của họ. Với năng lực và thiết kế tiên tiến của nó, người ta cho rằng nó có thể sẽ thay thế cho hệ thống Unix và máy tính lớn. SQL được thừa nhận là tiêu chuẩn của [ANSI]] (American National Standards Institute) vào năm 1986 và ISO (International Organization for Standardization) năm 1987. ANSI đã công bố cách phát âm chính thức của SQL là "ess kyoo ell", nhưng rất nhiều các chuyên gia cơ sở dữ liệu nói tiếng Anh vẫn gọi nó là sequel. Một quan niệm sai khác cũng được phổ biến rộng rãi đó là "SQL" là chữ viết tắt của "Structured Query Language" (Ngôn ngữ truy vấn có cấu trúc). Thực tế không phải như vậy! Tiêu chuẩn SQL đã trải qua một số phiên bản: Năm Tên Tên khác Chú giải 1986 SQL-86 SQL-87 Được công bố đầu tiên bởi ANSI. Được phê chuẩn bởi ISO năm 1987. 1989 SQL-89 Thay đổi nhỏ. 1992 SQL-92 SQL2 Thay đổi lớn. 1999 SQL:1999 SQL3 2003 SQL:2003 Chương 2: Giới thiệu PHP & MySQL 2.2.2 Một số từ khóa thông dụng trong SQL: a. Lấy dữ liệu: Thao tác sử dụng nhiều nhất trong một cơ sở dữ liệu dựa trên giao dịch là thao tác lấy dữ liệu. • SELECT được sử dụng để lấy dữ liệu từ một hoặc nhiều bảng trong cơ sở dữ liệu, SELECT là lệnh thường dùng nhất của ngôn ngữ sửa đổi dữ liệu (tạm dịch) (tiếng Anh: Data Manipulation Language - DML). Trong việc tạo ra câu truy vấn SELECT, người sử dụng phải đưa ra mô tả cho những dữ liệu mình muốn lấy ra chứ không chỉ ra những hành động vật lý nào bắt buộc phải thực hiện để lấy ra kết quả đó. Hệ thống cơ sở dữ liệu, hay chính xác hơn là bộ tối ưu hóa câu truy vấn sẽ dịch từ câu truy vấn sang kế hoạch truy vấn tối ưu. o Những từ khóa liên quan tới SELECT bao gồm: ƒ FROM dùng để chỉ định dữ liệu sẽ được lấy ra từ những bảng nào, và các bảng đó quan hệ với nhau như thế nào. ƒ WHERE dùng để xác định những bản ghi nào sẽ được lấy ra, hoặc áp dụng với GROUP BY. ƒ GROUP BY dùng để kết hợp các bản ghi có những giá trị liên quan với nhau thành các phần tử của một tập hợp nhỏ hơn các bản ghi. ƒ HAVING dùng để xác định những bản ghi nào, là kết quả từ từ khóa GROUP BY, sẽ được lấy ra. ƒ ORDER BY dùng để xác định dữ liệu lấy ra sẽ được sắp xếp theo những cột nào. b. Sửa đổi dữ liệu : Ngôn ngữ sửa đổi dữ liệu (Data Manipulation Language - DML), là môt phần nhỏ của ngôn ngữ, có những thành phần tiêu chuẩn dùng để thêm, cập nhật và xóa dữ liệu delete data. • INSERT dùng để thêm dữ liệu vào một bảng đã tồn tại. • UPDATE dùng để thay đổi giá trị của một tập hợp các bản ghi trong một bảng. Chương 2: Giới thiệu PHP & MySQL • MERGE dùng để kết hợp dữ liệu của nhiều bảng. Nó được dùng như việc kết hợp giữa hai phần tử INSERT và UPDATE . • DELETE xóa những bản ghi tồn tại trong một bảng. • TRUNCATE Xóa toàn bộ dữ liệu trong một bảng (không phải là tiêu chuẩn, nhưng là một lệnh SQL phổ biến). c. Giao dịch dữ liệu: Giao dịch, nếu có, dùng để bao bọc các thao tác sửa đổi dữ liệu. • BEGIN WORK (hoặc START TRANSACTION, tùy theo các ngôn ngữ SQL khác nhau) được sử dụng để đánh dấu việc bắt đầu một giao dịch dữ liệu (giao dịch dữ liệu đó có kết thúc hoàn toàn hay không). • COMMIT dùng để lưu lại những thay đổi trong giao dịch. • ROLLBACK dùng để quay lại thời điểm sử dụng lệnh COMMIT cuối cùng. Chương 3: Xây dựng hệ thống CHƯƠNG 3. XÂY DỰNG HỆ THỐNG Mục tiêu của luận văn là xây dựng hệ thống cung cấp dịch vụ nghe nhạc / xem video trực tuyến. Hệ thống này sẽ được xây dựng trên nền hệ quản trị nội dung Joomla, một trong những hệ quản trị nội dung mã nguồn mở mạnh nhất hiện nay. Trong chương 3 này, chúng tôi sẽ trình bày các bước phân tích, thiết kế hệ thống từ bài toán được mô tả ở phần dưới đây. 3.1 Mô tả bài toán Hệ thống cung cấp dịch vụ nghe nhạc / xem video trực tuyến là một hệ thống cho phép mọi người nghe nhạc mà không cần phải đăng ký là thành viên. Người dùng có thể tìm kiếm các bài hát, các nhạc sỹ, album, ca sỹ. Nếu trong cơ sở dữ liệu có, nó sẽ trả về kết quả cho người dùng. Chức năng quản lý nội dung của hệ thống bao gồm: chỉnh sửa, thêm , xoá các bài hát , các album, tất cả những thao tác này chỉ có thể được thực hiện bởi người quản trị của hệ thống. Một bài hát mới khi được thêm vào phải được phân loại theo các thể loại nhạc: nhạc trẻ, nhạc cách mạng, nhạc không lời ... Bài hát mới có thể có hoặc không thuộc 1 album cụ thể nào cả. Nó cũng có thể có hoặc không có thông tin về Nhạc sỹ hoặc Ca sỹ thể hiện bài hát đó. Khi xoá một bài hát, cơ sở dữ liệu về bài hát đó sẽ được xoá, đồng thời File lưu bài hát đó trên máy chủ cũng sẽ được xoá ngay lập tức. Khi sửa một bài hát, nếu người quản trị tải lên một bài hát khác mà không xoá bài hát cũ, thì nội dung mới của bài hát coi như thành hai đoạn, mỗi đoạn là một File. 3.2 Mô hình nghiệp vụ 3.2.1 Bảng phân tích xác định chức năng, tác nhân và hồ sơ Động từ + bổ ngữ Danh từ Nhận xét Tìm kiếm Bài hát, nhạc sỹ, album, ca sỹ (tác nhân) Thêm, sửa, xoá Bài hát, nhạc sỹ, album, ca sỹ (tác nhân) Chương 3: Xây dựng hệ thống 3.2.2 Biểu đồ ngữ cảnh hệ thống 0 Hệ thống website nghe nhạc Người dùng Yêu cầu nghe Người quản lý Yêu cầu tìm kiếm Kết quả xử lý yêu cầu Sửa Xoá Thêm Kết quả tìm kiếm Bài hát Chương 3: Xây dựng hệ thống 3.2.3 Biểu đồ phân rã chức năng 3.2.4 Mô hình các chức năng cụ thể (1) Chơi nhạc: Chức năng này sẽ được kích hoạt khi người dùng nhấn và 1 bài hát nào đó. Một player sẽ hiển thị ra và trên đó có các chức năng cơ bản xử lý chơi nhạc, ví dụ như dừng, tạm dừng ... (2) Tìm kiếm: Đây là chức năng cung cấp cho người sử dụng, dùng để tìm kiếm một bài hát, một nhạc sỹ, ca sỹ hoặc album. Chức năng tìm kiếm sẽ tìm những bản ghi có 1 phần dữ liệu giống như chuỗi đã nhập vào (3.1) Thêm bài hát: Đây là chức năng của người quản trị mạng, khi thêm bài hát, bắt buộc phải có thể loại của bài hát, còn thông tin về nhạc sỹ, ca sỹ thể hiện và album không bắt buộc. Trước tiên bài hát sẽ được upload lên một thư mục nào đó trên host, nếu upload thành công thì mới tạo thông tin trong cơ sở dữ liệu. (3.2) Xoá bài hát: Đây là chức năng của người quản trị mạng để xoá 1 bài hát, Bao gồm cả viêc xoá file trên host và bản ghi về bài hát trên cơ sở dữ liệu. (3.3) Sửa bài hát: Đây là chức năng của người quản trị mạng dùng để sửa các thông tin liên quan đến bài hát trong cơ sở dữ liệu. Hệ thống website nghe nhạc 1.Chơi nhạc 2.Tìm Kiếm 3.Quản lý 3.1 Thêm bài hát 3.1 Xoá bài hát 3.1 Sửa bài hát Chương 3: Xây dựng hệ thống 3.2.5 Lập ma trận thực thể chức năng Các thực thể a. Danh sách bài hát b. Danh sách album c. Danh sách ca sỹ d. Danh sách nhạc sỹ Chức năng nghiệp vụ a b c d 1. Thêm mới bài hát U 2. Xoá bài hát R R R R 3. Sửa bài hát R R R R 4. Tìm kiếm bài hát R R R R 5. Chơi nhạc R Chương 3: Xây dựng hệ thống 3.3 Phân tích – Mô hình khái niệm logic 3.3.1 Biểu đồ luồng dữ liệu mức 0 1.0 Chơi Nhạc 2.0 Tìm Kiếm 3.0 Quản lý Người sử dụng Người quản lý DS bài hát a DS album b DS nhạc sỹ c DS ca sỹ d TT phản hồi Thêm Sửa Xoá Yêu cầu tìm kiếm Nghe bài hát TT phản hồi Chương 3: Xây dựng hệ thống 3.3.2 Biểu đồ luồng dữ liệu mức 1 3.1 Thêm bài hát 3.3 Sửa bài hát 3.2 Xoá bài hát Người quản lý DS bài hát a DS album b DS nhạc sỹ c DS ca sỹ d Chương 3: Xây dựng hệ thống 3.3.3 Mô hình khái niệm dữ liệu: mô hình E-R a. Xây dựng được các thực thể Dựa vào các bảng trên chúng ta có thể xây dựng được các thực thể sau: BÀI HÁT(Mã bài hát, tên bài hát, mã nhạc sỹ, mã ca sỹ, mã album, thể loại) ALBUM(Mã album, tên album) NHẠC SỸ(Mã nhạc sỹ, tên nhạc sỹ) CA SỸ(Mã ca sỹ, tên ca sỹ) b. Xác định mối quan hệ và thuộc tính Động từ “Thêm” của người quản trị Trả lời Câu hỏi Thực thể Thuộc tính Ai thêm Người quản lý Thêm cái gì Bài hát, album, nhạc sỹ, ca sỹ Động từ “Xoá” của người quản trị Trả lời Câu hỏi Thực thể Thuộc tính Ai xoá Người quản lý Xoá cái gì Bài hát, album, nhạc sỹ, ca sỹ Động từ “Sửa” của người quản trị Trả lời Câu hỏi Thực thể Thuộc tính Ai sửa Người quản lý Sửa cái gì Bài hát, album, nhạc sỹ, ca sỹ Chương 3: Xây dựng hệ thống c. Vẽ biểu đồ rút gọn Mã album BÀI HÁT NHẠC SỸ CA SỸ Thuộc Thuộc Thuộc Mã nhạc sỹ Mã BH Thể loại Mã ca sỹ Mã nhạc sỹ Tên nhạc sỹ Mã ca sỹ Tên ca sỹ Mã album Tên album ALBUM Chương 3: Xây dựng hệ thống 3.4 Thiết kế mô hình logic 3.4.1. Chuyển mô hình ER sang mô hình quan hệ a. Biểu diễn các thực thể: Î BÀI HÁT (Mã bài hát, Tên bài hát, Mã nhạc sỹ, Mã ca sỹ, Mã album, Thể loại) Î ALBUM (Mã album, Tên album) Î NHẠC SỸ (Mã nhạc sỹ, Tên nhạc sỹ) Î CA SỸ (Mã ca sỹ, Tên ca sỹ) b. Biểu diễn các mối quan hệ Î BÀI HÁT_CA SỸ ( Mã BH_CS, Mã bài hát, Mã ca sỹ ). Î BÀI HÁT_ALBUM ( Mã BH_AL, Mã bài hát, Mã album ). c. Chuẩn hóa: Tất cả là chuẩn 3 nên không cần chuẩn hóa. Bài hát Album Thuộc Nhạc sỹ Ca sỹ Thuộc Chương 3: Xây dựng hệ thống d. Biểu đồ quan hệ của mô hình dữ liệu BAI HAT Mã bài hát Tên bài hát Thể loại Mã BH_AL Mã BH_CS ALBUM Mã album Tên album BAI HAT_ ALBUM Mã BH_AB Mã bài hát Mã album BAI HAT_ CA SY Mã BH_CS Mã bài hát Mã ca sỹ CA SỸ Mã ca sỹ Tên ca sỹ Thông tin NHẠC SỸ Mã bài hát Tên bài hát Thể loại Mã BH_AL Chương 3: Xây dựng hệ thống 3.4.2. Thiết kế cơ sở dữ liệu vật lý Sử dụng hệ quản trị cơ sở dữ liệu MySQL, từ các quan hệ trên ta có: (Để phù hợp với hệ thống Joomla, em có thêm một số trường trong các bảng) a. Bảng: BÀI HÁT jos_song STT Tên trường Chú giải 1 Id Khoá chính 2 name Tên bài hát 3 url Địa chỉ lưu bài hát 4 id_author 5 id_songsinger 6 id_songalbum 7 id_type 8 id_content 9 Finger_print 10 Created 11 Created_by ai trong ban quản trị up bài hát này? 12 Hits Số người bình chọn cho ca khúc 13 Vote Điểm bình chọn tính trung bình cho ca khúc 14 Publish Cho phép được/không được nghe bài hát này 15 description Vài nét về bài hát Chương 3: Xây dựng hệ thống b. Bảng: ALBUM c. Bảng: CA SỸ jos_album STT Tên trường Chú giải 1 id Khoá chính 2 Name 3 Producer Hãng phát hành album đó 4 Info 1 số thông tin về album 5 Type Thể loại nhạc của album đó 6 Img ảnh của album 7 Created Ngày tạo 8 Created_by Người tạo ra bản ghi này? 9 Publish Cho phép hiển thị hoặc ko album này jos_singer STT Tên trường Chú giải 1 id Khoá chính 2 Name Tên ca sỹ 3 img ảnh của ca sỹ 4 is_band Đây có phải là một ban nhạc hay không ? 5 Created Ngày tạo 6 Created_by Người tạo ra bản ghi này? 7 description Thông tin liên đến ca sỹ Chương 3: Xây dựng hệ thống d. Bảng: NHẠC SỸ e. Bảng: BÀI HÁT_ALBUM f. Bảng: BÀI HÁT_CA SỸ jos_author STT Tên trường Chú giải 1 id Khoá chính 2 name Tên nhạc sỹ 3 Img ảnh của nhạc sỹ 4 Created Ngày tạo 5 Created_by Người tạo ra bản ghi này? 6 description Một số thông tin liên về nhạc sỹ Jos_songalbum STT Tên trường Chú giải 1 id Khoá chính 2 Id_song 3 Id_album Jos_songsinger STT Tên trường Chú giải 1 id Khoá chính 2 Id_song 3 Id_singer Chương 4: Ứng dụng thực tiễn CHƯƠNG 4: ỨNG DỤNG THỰC TIỄN 4.1. Mô tả môi trường xây dựng và thử nghiệm ứng dụng 4.1.1 Mô tả môi trường xây dựng ứng dụng: Cấu hình máy tính: - Hệ điều hành: Ubuntu 6.10 (Được cài đặt trên máy ảo VMWare Workstation 5.2) - Cấu hình mạng: Localhost (Tạo server ảo ngay trên máy) - Phiên bản Apache: Apache/2.0.55 (Ubuntu) - Phiên bản PHP: 5.1.6 - Phiên bản SQL: Client API version 5.0.24a - Phiên bản phpMyAdmin: 2.8.2 – Debian - 02 - Gói Joomla đã sử dụng: Joomla_1.0.11-Stable-Full_Package - Phiên bản các component, mambot, module đã tải về để sử dụng lại: bot_mgmedia-0.1.6b1 4.1.2 Các ứng dụng xây dựng thử nghiệm: Component đã viết: - Component quản lý Bài hát: com_song - Component quản lý Album: com_album - Component quản lý Nhạc sỹ: com_author - Component quản lý Ca sỹ: com_singer - Component quản lý Thẻ loại nhạc: com_musictype Mambots đã viết: - Mambot hiển thị bài hát: mam_song - Mambot hiển thị album: mam_album Thử nghiệm: - Thử nghiệm về tốc độ khi nghe trên mạng Internet : chưa có - Chức năng nhập bài hát: bình thường - Thử nghiệm nếu có nhiều người cùng truy cập: chưa có Chương 4: Ứng dụng thực tiễn 4.2 Giao diện của website . Hình 1: Giao diện chính của website phía người sử dụng Chương 4: Ứng dụng thực tiễn Component quản lý bài hát: Hình 2: Component quản lý các bài hát Chương 4: Ứng dụng thực tiễn Hình 3.Giao diện phần chỉnh sửa/thêm mới bài hát Chương 4: Ứng dụng thực tiễn Component quản lý Album Hình 4. Component quản lý Album Chương 4: Ứng dụng thực tiễn Hình 5. Giao diện phần chỉnh sửa Album Chương 4: Ứng dụng thực tiễn Component quản lý Nhạc sỹ: Hình 6. Component quản lý nhạc sỹ Chương 4: Ứng dụng thực tiễn Hình 7. Giao diện phần chỉnh sửa thông tin Nhạc sỹ Chương 4: Ứng dụng thực tiễn Component quản lý Nhạc sỹ: Hình 8. Component quản lý Ca sỹ Chương 4: Ứng dụng thực tiễn Hình 9. Giao diện phần chỉnh sửa Ca sỹ Chương 4: Ứng dụng thực tiễn 4.3. Đánh giá về hệ thống 4.3.1 Ưu điểm - Nội dung: được xây dựng thông qua các component cho nên chúng tương đối rõ ràng, dễ quản lý, thuận tiện cho việc bảo trì, thay thế - Giao diện : chúng ta có thể viết thêm cái gói giao diện mới (theo chuẩn của giao diện ban đầu) và cài đặt vào trong hệ thống. Công việc này tương đối đơn giản và không làm ảnh hưởng đến các thành phần khác của hệ thống. Việc thay đổi giao diện của website giờ đây đơn giản chỉ với một vài thao tác ngay trên phần website của người quản trị mà không cần phải can thiệp vào code của cả hệ thống. - Độ an toàn : Hệ quản trị nội dung Joomla thường xuyên có các bản nâng cấp, vá lỗi (định kỳ theo 2-4 tháng) hoàn toàn miễn phí. Do đó hệ thống của chúng tôi luôn được nâng cấp về tính an toàn mà người quản trị không cần phải tốn thời gian và công sức cho việc sửa code. Việc quản lý quyền hạn của các thư mục, các tệp trong hệ thống cũng được thực hiện ngay trên website của người quản trị, mà không cần phải thao tác bằng lệnh trực tiếp trên máy chủ. 4.3.2 Nhược điểm Nhược điểm thứ nhất đó là đối với những người muốn phát triển hệ thống thì cần phải có những kiến thức nhất định về hệ thống quản trị nội dung Joomla. Từ đó mới có thể xây dựng được các module, các component hoặc các mambot một cách hiệu quả. Thứ hai, hệ thống chưa có chức năng tìm kiếm theo giai điệu, theo tiết tấu. Đây là chức năng rất tốt đối với một website nghe nhạc trực tuyến. Thứ ba, hệ thống chưa có phần xử lý về tải của máy chủ và tải đường truyền khi số lượng người sử dụng truy cập lớn. 4.4 Hướng phát triển trong tương lai Như đã được đề cập ở các phần trên, hệ thống cung cấp nghe nhạc, xem phim trực tuyến xây dựng trên nền Joomla. Các thành phần như module, component đều có thể viết thêm và cài đặt vào hệ thống một cách dễ dàng. Vì thế, trong tương lai ứng dụng sẽ có thêm một chức năng rất quan trọng. đó là tìm kiếm bài hát theo một giai điệu có sẵn. Giai điệu này có thể là một File dạng Chương 4: Ứng dụng thực tiễn MIDI, hay một đoạn nhạc của bài hát, hoặc thậm chí là một đoạn tiếng huýt sáo do người sử dụng trực tiếp thu âm thông qua qua Micro. Để phát triển tính năng này, chúng ta cần có một module xử lý các bài hát được tải lên và trích ra đoạn nhạc mẫu của bài hát đó. Sau đó lưu đoạn nhạc mẫu vào ngay cơ sở dữ liệu của bài hát đó. Một module để phân tích và so sánh các đoạn nhạc mẫu với đoạn nhạc cần tìm kiếm. Cuối cùng là một module xử lý đoạn nhạc yêu cầu tìm kiếm: đoạn nhạc này có thể là một File nhạc MIDI (từ các chương trình mô phỏng đàn Piano [14] ) một đoạn âm thanh do người dùng tự thu âm, hay là cả một bài hát. TÀI LIỆU THAM KHẢO TÀI LIỆU THAM KHẢO [1]. chủ của Joomla) [2]. và (Trang web cung cấp các extensions cho Joomla) [3]. Steve White – Websdezined.com and Andy Wallace Joomla! User Manua Joomla! V1.0.11 21 October 2006 [4]. (Diễn đang cung cấp tài Liệu về PHP do Tống Phước Khải biên soạn) [5]. (Trang web từ điển bách khoa) [6]. (Trang web cung cấp thông tin về PHP) [7]. (Trang web so sánh giữa các ngôn ngữ phát triển website của Google) [8]. (Mail group của PHPVietNam) [9]. và (Trang chủ Joomla Việt Nam) [10]. (Trang chủ PHP) [11]. (Trang chủ MySQL) [12]. (Một số thông tin về giai điệu, tiết tấu, sử dụng cho việc tìm kiếm theo giai điệu và tiết tấu) [13]. hoặc (địa chỉ tải bản PHP Designer 2007 của Michael Pham ) [14]. (Trang web mô phỏng âm thanh)

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

  • pdf11Xây dựng hệ thống cung cấp dịch vụ nghe nhạc xem video trực tuyến .pdf
Luận văn liên quan