Mục tiêu của đề tài là xây dựng một phiên bản website trường ĐH Công nghệ
phiên bản tiếng Anh trên thiết bị di động. Phiên bản này là một bản rút gọn của
website, cho phép hiển thị tốt trên thiết bị di động vốn bị hạn chế bởi kích thước màn
hình. Bắt đầu từ việc nghiên cứu hệ thống website trường ĐH Công nghệ, vốn được
xây dựng trên hệ quản trị nội dung Drupal. Sau khi nghiên cứu các thành phần cơ bản,
các module quan trọng, hệ thống file giao diện của Drupal thì tiến hành thiết kế
template cho phiên bản trên thiết bị di động. Triển khai bằng cách cài đặt một trang
Drupal mới với dữ liệu được lấy từ phiên bản gốc và hiển thị lại theo template đã thiết
kế. Kết quả, đã xây dựng thành công phiên bản trên thiết bị di động cho website
trường ĐH Công nghệ với tên miền riêng. Tuy nhiên, hệ thống chưa có chức năng tự
nhận diện thiết bị truy cập để điều hướng sang tên miền đó.
64 trang |
Chia sẻ: nhungnt | Lượt xem: 2081 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Đề tài Website trường ĐH công nghệ phiên bản tiếng anh trên thiết bị di động, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ĐẠI HỌC QUỐC GIA HÀ NỘI
TRƯỜNG ĐẠI HỌC CÔNG NGHỆ
Nguyễn Thị Thanh Tâm
WEBSITE TRƯỜNG ĐH CÔNG NGHỆ PHIÊN BẢN
TIẾNG ANH TRÊN THIẾT BỊ DI ĐỘNG
KHOÁ LUẬN TỐT NGHIỆP ĐẠI HỌC HỆ CHÍNH QUY
Ngành: Công nghệ thông tin
HÀ NỘI - 2010
ĐẠI HỌC QUỐC GIA HÀ NỘI
TRƯỜNG ĐẠI HỌC CÔNG NGHỆ
Nguyễn Thị Thanh Tâm
WEBSITE TRƯỜNG ĐH CÔNG NGHỆ PHIÊN BẢN
TIẾNG ANH TRÊN THIẾT BỊ DI ĐỘNG
KHOÁ LUẬN TỐT NGHIỆP ĐẠI HỌC HỆ CHÍNH QUY
Ngành: Công nghệ thông tin
Cán bộ hướng dẫn: ThS.Phùng Chí Dũng
HÀ NỘI - 2010
TÓM TẮT NỘI DUNG
Mục tiêu của đề tài là xây dựng một phiên bản website trường ĐH Công nghệ
phiên bản tiếng Anh trên thiết bị di động. Phiên bản này là một bản rút gọn của
website, cho phép hiển thị tốt trên thiết bị di động vốn bị hạn chế bởi kích thước màn
hình. Bắt đầu từ việc nghiên cứu hệ thống website trường ĐH Công nghệ, vốn được
xây dựng trên hệ quản trị nội dung Drupal. Sau khi nghiên cứu các thành phần cơ bản,
các module quan trọng, hệ thống file giao diện của Drupal thì tiến hành thiết kế
template cho phiên bản trên thiết bị di động. Triển khai bằng cách cài đặt một trang
Drupal mới với dữ liệu được lấy từ phiên bản gốc và hiển thị lại theo template đã thiết
kế. Kết quả, đã xây dựng thành công phiên bản trên thiết bị di động cho website
trường ĐH Công nghệ với tên miền riêng. Tuy nhiên, hệ thống chưa có chức năng tự
nhận diện thiết bị truy cập để điều hướng sang tên miền đó.
MỤC LỤC
Chương 1. Tổng quan về Drupal ............................................................................ 2
1.1. Giới thiệu chung ............................................................................................. 2
1.1.1. Drupal là gì? ......................................................................................... 2
1.1.2. Lịch sử .................................................................................................. 2
1.1.3. Các tầng kỹ thuật .................................................................................. 3
1.1.4. Chức năng............................................................................................. 4
1.1.5. Nguyên tắc ............................................................................................ 7
1.2. Các khái niệm cơ bản...................................................................................... 7
1.2.1. Nhân ..................................................................................................... 7
1.2.2. Block .................................................................................................... 8
1.2.3. Hook ..................................................................................................... 9
1.2.4. Node ..................................................................................................... 9
1.2.5. Taxonomy........................................................................................... 12
1.2.6. Path .................................................................................................... 14
1.2.7. User .................................................................................................... 16
1.2.8. Hệ thống file ....................................................................................... 17
1.3. Hệ thống module .......................................................................................... 20
1.3.1. Các module hệ thống .......................................................................... 21
1.3.2. Các module đóng gói quan trọng......................................................... 22
1.4. Hệ thống giao diện ........................................................................................ 24
1.4.1. Tổng quan về phát triển giao diện ....................................................... 24
1.4.2. Regions ............................................................................................... 25
1.4.3. Hệ thống file trong giao diện............................................................... 26
1.4.4. Các file template ................................................................................. 27
1.4.5. Các file CSS ....................................................................................... 35
1.5. Kết luận ........................................................................................................ 36
Chương 2. Phiên bản website dùng Drupal trên thiết bị di động ........................... 37
2.1. Đặt vấn đề .................................................................................................... 37
2.2. Định hướng giải pháp ................................................................................... 37
2.2.1. Multisite ............................................................................................. 37
2.2.2. Thiết kế template ................................................................................ 38
2.2.3. Module Mobile Plugin ........................................................................ 52
2.3. Kết luận ........................................................................................................ 52
Chương 3. Website trường ĐH Công nghệ phiên bản tiếng Anh trên thiết bị di
động…………………………………………………………………………………53
3.1. Giao diện ...................................................................................................... 53
3.2. Cài đặt .......................................................................................................... 54
3.2.1. Cài đặt multisite .................................................................................. 54
3.2.2. Tạo trang chủ ...................................................................................... 55
3.3. Kết quả ......................................................................................................... 55
1
LỜI MỞ ĐẦU
Ngày nay, điện thoại di động đã trở nên phổ biến, với sự phát triển của mạng 3G
thì việc sử dụng thiết bị di động để truy cập web trở nên dễ dàng hơn bao giờ hết. Truy
cập web bằng thiết bị di động vừa tiện lợi lại vừa nhanh chóng nên nhiều người đang
chọn cách này để truy cập web. Tuy nhiên, các trang web thường được thiết kế phù
hợp với việc hiển thị trên máy tính, có màn hình rộng và hỗ trợ tối đa các tiện ích kèm
theo. Còn với thiết bị di động, với màn hình nhỏ và hầu hết không hỗ trợ Javascript
hay Flash Player thì thường gặp khó khăn trong việc hiển thị. Hơn nữa, với những
thông tin quảng cáo kèm theo sẽ khiến cho dung lượng tải về rất lớn, vừa gây độ trễ
lớn trong việc tải trang web vừa tốn kém khi mà hầu hết người dùng sử dụng gói cước
tính tiền theo dung lượng và tốc độ của mạng 3G cũng không lớn. Tất cả những điều
đó đòi hỏi phải có một phiên bản riêng của trang web dành cho thiết bị di động.
Không nằm ngoài những trường hợp trên, website trường ĐH Công nghệ phiên
bản tiếng Anh cũng chỉ hỗ trợ cho người dùng truy cập từ máy tính. Nhận thấy nhu cầu
truy cập web qua thiết bị di động ngày càng tăng, để hỗ trợ tối đa cho người dùng, cần
phải có một phiên bản dành riêng cho thiết bị di động. Chính vì vậy em đã lựa chọn và
nghiên cứu đề tài “Website trường ĐH Công nghệ phiên bản tiếng Anh trên thiết
bị di động”. Website được xây dựng dựa trên phiên bản đầy đủ dành cho desktop, sử
dụng hệ quản trị nội dung Drupal. Khoá luận của em sẽ trình bày gồm 3 chương:
Chương 1: Tổng quan về Drupal
Chương 2: Phiên bản website dùng Drupal trên thiết bị di động
Chương 3: Website trường ĐH Công nghệ phiên bản tiếng Anh trên thiết bị di
động
Em xin chân thành cảm ơn sự giúp đỡ tận tình của ThS.Phùng Chí Dũng trong
quá trình thực hiện đề tài.
2
Chương 1. Tổng quan về Drupal
1.1. Giới thiệu chung
1.1.1. Drupal là gì?
Drupal là một khung sườn phát triển phần mềm hướng module, một hệ quản trị
nội dung miễn phí và mã nguồn mở.
Cũng giống như các hệ quản trị nội dung hiện đại khác, Drupal cho phép người
quản trị hệ thống tạo và tổ chức dữ liệu, tùy chỉnh cách trình bày, tự động hóa các tác
vụ điều hành và quản lý hệ thống những. Drupal có cấu trúc lập trình rất tinh vi, dựa
trên đó, hầu hết các tác vụ phức tạp có thể được giải quyết với rất ít đoạn mã được
viết, thậm chí không cần. Đôi khi, Drupal cũng được gọi là "khung sườn phát triển ứng
dụng web", vì kiến trúc thông minh và uyển chuyển của nó.
Drupal được chạy trên rất nhiều môi trường khác nhau, bao gồm Windows, Mac
OS X, Linux, FreeBSD, OpenBSD và các môi trường hỗ trợ máy chủ
web Apache (phiên bản 1.3+) hoặc IIS (phiên bản 5+) có hỗ trợ ngôn ngữ PHP (phiên
bản 4.3.3+). Drupal kết nối với cơ sở dữ liệu MySQL hoặc PostgreSQL để lưu nội
dung và các thiết lập.
1.1.2. Lịch sử
Năm 2000, các kết nối Internet thường xuyên ở mức cao với các sinh viên trường
Đại học Antwerp, do đó, Dries Buytaert và Hans Snijder thiết lập một cầu nối không
dây giữa ký túc xá sinh viên của mình để chia sẻ kết nối modem Hans 'ADSL giữa tám
sinh viên. Đây là một việc cực kỳ xa xỉ tại thời điểm đó, nhưng vẫn có sự thiếu sót:
không có phương tiện để thảo luận hay chia sẻ những điều đơn giản.
Nó truyền cảm hứng cho Dries làm việc trên một trang web tin tức nhỏ với một
built-in hội đồng quản trị web, cho phép các nhóm bạn bè để lại mỗi ghi chú khác về
3
tình trạng của mạng, thông báo nơi họ đã ăn tối, hay để chia sẻ một số mục tin tức
đáng chú ý.
Các phần mềm không có tên cho đến ngày sau khi Dries chuyển ra sau khi tốt
nghiệp. Nhóm quyết định đưa các tuyến nội bộ trang web để họ có thể giữ liên lạc, tiếp
tục chia sẻ những phát hiện thú vị, và những đoạn tường thuật cuộc sống cá nhân của
họ. Trong khi tìm kiếm một tên miền phù hợp, Dries đặt tên miền 'drop.org' sau khi
ông thực hiện một lỗi đánh máy để xem tên “dorp.org” vẫn còn. Dorp là từ Hà Lan cho
'làng', được coi là một tên phù hợp cho các cộng đồng nhỏ.
Một khi drop.org được thành lập trên mạng, khán giả của nó đã thay đổi khi các
thành viên bắt đầu nói về các công nghệ web mới, chẳng hạn như kiểm duyệt, cung
cấp, đánh giá, và phân phối chứng thực. Drop.org từ từ biến thành một môi trường thử
nghiệm cá nhân, thúc đẩy bởi các cuộc thảo luận và dòng chảy của ý tưởng. Các cuộc
thảo luận về các công nghệ web đã được thử ra trên drop.org chính nó như là mới bổ
sung cho các phần mềm chạy các trang web. Chỉ sau đó, vào tháng 1 năm 2001, mà
Dries quyết định phát hành phần mềm phía sau drop.org như "Drupal". Mục đích là để
cho phép người khác sử dụng và mở rộng nền tảng thử nghiệm để nhiều người hơn có
thể khám phá những con đường mới để phát triển. Cái tên Drupal, phát âm là "droo-
puhl," có nguồn gốc từ cách phát âm tiếng Anh của từ tiếng Hà Lan "druppel," có
nghĩa là "thả".
1.1.3. Các tầng kỹ thuật
Mục tiêu thiết kế của Drupal bao gồm cả việc có thể chạy tốt trên các tài khoản
web hosting giá rẻ và có thể mở rộng tới các trang web phân phối lớn. Mục tiêu ban
đầu là sử dụng công nghệ phổ biến nhất, và sau này là coding cẩn thận, chặt chẽ. Các
tầng kỹ thuật của Drupal được minh họa trong hình 1-1.
Hình 1-1. Các tầng kỹ thuật của Drupal
4
Hệ điều hành nằm ở mức thấp trong tầng mà Drupal không quan tâm nhiều.
Drupal chạy tốt trên bất kỳ hệ điều hành nào có hỗ trợ PHP.
Máy chủ web được sử dụng rộng rãi nhất với Drupal là Apache, mặc dù các máy
chủ web khác (bao gồm cả Microsoft IIS) cũng có thể được sử dụng. Bởi vì lịch sử lâu
dài của Drupal với Apache, Drupal với file .htaccess được bảo mật khi cài đặt
Drupal. Clean URLs-có nghĩa là loại bỏ những dấu hỏi, dấu và, hoặc ký tự đặc biệt
khác bằng cách sử dụng thành phần mod_rewrite của Apache. Điều này đặc biệt quan
trọng bởi vì khi di chuyển từ một hệ thống quản lý nội dung hoặc từ các tập tin tĩnh,
các URL của nội dung không cần phải thay đổi. Clean URL có sẵn trên các máy chủ
web khác bằng cách sử dụng khả năng ghi lại URL của web server.
Giao diện Drupal với các lớp tiếp theo của stack (cơ sở dữ liệu) thông qua một
lớp cơ sở dữ liệu nhỏ. Lớp này xử lý các truy vấn SQL để có thể sử dụng cơ sở dữ liệu
các nhà cung cấp khác nhau mà không cần viết lại code. Các cơ sở dữ liệu thử nghiệm
rộng rãi nhất là MySQL và PostgreSQL, mặc dù hỗ trợ cho Microsoft SQL Server và
Oracle đang tăng lên.
Drupal được viết bằng PHP. Vì PHP là một ngôn ngữ dễ học, có rất nhiều
chương trình PHP được viết bởi người mới bắt đầu. Chất lượng code của người mới
bắt đầu đã khiến cho PHP mất uy tín. Hơn nữa, PHP cũng có thể được sử dụng để viết
code. Tất cả code của nhân Drupal đều tuân thủ nghiêm ngặt các tiêu chuẩn code và
được xem xét kỹ lưỡng qua quá trình mã nguồn mở. Đối với Drupal, rất dễ dàng học
PHP vì có một cộng đồng luôn sẵn sàng giúp đỡ những người mới bắt đầu. Và những
người mới bắt đầu nhận được thông tin phản hồi từ cộng đồng giúp nâng cao kỹ năng
của họ.
1.1.4. Chức năng
1.1.4.1. Chức năng chung
Collaborative Book - Giúp thiết lập một "quyển sách" và cho phép nhiều người
cùng đóng gói nội dung, tổ chức dữ liệu.
Clean URL - Drupal dùng mod_rewrite của Apache để tạo các URL thân thiện
với cả các bộ máy tìm kiếm và người dùng.
Module - Các module đóng gói từ cộng đồng mở rộng tính năng của nhân
Drupal.
Online help - Hệ thống trợ giúp trực tuyến ngay trên trang web.
5
Open source - Mã nguồn của Drupal hoàn toàn miễn phí dưới giấy phép
GNU/GPL 2.
Cá nhân hóa - Có sẵn ngay trong nhân Drupal. Cả nội dung lẫn cách trình bày
đều có thể cá nhân hóa theo các tiêu chuẩn được người dùng đặt ra.
Hệ thống phân quyền theo vai trò (role based) - Có thể tạo ra các vai trò mang
các quyền hạn khác nhau, sau đó gán những vai trò này cho người dùng.
Tìm kiếm - Mọi nội dung đều được đánh chỉ mục và có thể tìm kiếm bởi
module tìm kiếm tích hợp sẵn.
1.1.4.2. Quản lý thành viên
Xác thực người dùng - Người dùng có thể đăng kí và xác thực tại trang web,
hoặc thông qua các nguồn xác thực khác như Jabber, Blogger, LiveJournal hoặc một
site Drupal khác hoặc máy chủ LDAP.
1.1.4.3. Quản trị nội dung
Poll - Module bầu chọn của Drupal cho phép người dùng tạo các bầu chọn và
gắn vào các trang khác nhau.
Khuôn mẫu (template) - Hệ thống khuôn mẫu của Drupal phân tách nội dung
với cách trình bày. Khuôn mẫu được xây dựng trên PHP và HTML chuẩn, có
nghĩa là không cần phải học một ngôn ngữ khuôn mẫu (templating language)
nào cả.
Bình luận theo luồng - Mô hình bình luận theo luồng mạnh mẽ của Drupal cho
phép bình luận bất cứ nội dung nào. Các bình luận có chia cấp như ở một nhóm
tin (newsgroup) hoặc diễn đàn.
Điều khiển phiên bản - Hệ thống điều khiển phiên bản của Drupal cho phép lưu
giữ thông tin của các lần cập nhật (ai, cái gì, khi nào). Có thể dễ dàng quay lại
(roll-back) một phiên bản trước đó.
1.1.4.4. Blogging
Hệ thống blog đa người dùng - Mỗi người dùng đã ghi danh trong hệ thống đều
có thể viết blog.
Hỗ trợ Blog API - Cho phép cập nhật nội dung bằng nhiều công cụ khác nhau,
thậm chí không cần dùng đến trình duyệt web.
Content syndication - Xuất nội dung theo dạng RDF/RSS.
6
News aggregator - Giúp đọc thông tin từ các website khác.
Permalink - Tất cả các nội dung trong Drupal đều có một URL cố định, giúp
người dùng có thể dễ dàng liên kết đến mà không sợ nó thay đổi về sau.
1.1.4.5. Nền tảng
Apache hoặc IIS, Unix/Linux/BSD/Solaris/Windows/Mac OS X đều được hỗ
trợ - Drupal ngay từ đầu đã được xây dựng để tương thích nhiều nền tảng.
Độc lập với cơ sở dữ liệu - Mặc dù đa số dùng MySQL, nhưng không phải tất
cả. Drupal được xây dựng trên lớp CSDL trừu tượng (database abstraction layer
- DAL), hỗ trợ cả MySQL lẫn PostgreSQL. Để hỗ trợ các CSDL riêng của
mình, người dùng chỉ việc viết phần back-end hiện thực hóa 14 hàm của DAL.
Đa ngôn ngữ - Nền tảng Drupal sẵn sàng cho việc xây dựng một website đa
ngôn ngữ.
1.1.4.6. Quản trị và phân tích
Phân tích, Theo dõi và Thống kê
Ghi nhật kí và báo cáo - Các hoạt động quan trọng trên hệ thống đều được ghi
lại, giúp người quản trị có thể xem lại sau đó.
Hệ thống quản trị trên web - Tất cả có thể được quản lí qua trình duyệt web.
1.1.4.7. Tính năng cộng đồng
Diễn đàn - Diễn đàn thảo luận.
Blog - Hệ thống blog đa người dùng.
1.1.4.8. Hiệu năng và khả năng mở rộng
Caching - Cơ chế đệm dữ liệu giúp giảm số truy vấn CSDL, tăng hiệu năng và
giảm tải server. Hệ thống này đã từng được thử nghiệm cho thấy chúng hoạt
động rất tốt dưới hiệu ứng "slashdot" (lưu lượng tăng đột biến do trang web
được giới thiệu ở một website lớn).
Nén CSS - Drupal hỗ trợ chức năng gom nhóm các tập tin CSS lại thành một
tập tin nhất, đồng thời cũng loại bỏ các ghi chú bên trong. Khi trình duyệt thực
hiện chỉ cần thực hiện một yêu cầu để lấy về một tập tin CSS duy nhất.
Nén Javascript - Từ phiên bản 6.x Drupal còn cho phép gom nhóm và nén các
tập tin Javascript.
7
1.1.5. Nguyên tắc
Modular và extensible. Mục tiêu của Drupal và cung cấp một nhân gọn, mạnh
để sẵn sàng mở rộng thông qua các module tự tạo.
Mã nguồn chất lượng. Chất lượng cao, trình bày đẹp, ghi chú đầy dủ.
Tuân thủ chuẩn. Drupal hỗ trợ các chuẩn cũ và mới, trong đó có HTML và
CSS.
Đòi hỏi ít tài nguyên. Để đạt hiệu quả cao nhất, Drupal khuyến khích các mã
lệnh tiết kiệm (thí dụ như dùng ít truy vấn CSDL). Drupal cũng chỉ cần rất ít
đòi hỏi về server, chỉ yêu cầu những cấu hình phổ biến. Cụ thể là Drupal cần
hoạt động trơn tru với Apache, PHP và MySQL hoặc Postgresql.
Mã nguồn mở. Drupal dựa trên triết lí mã nguồn mở về sự phát triển cộng tác
của phần mềm tự do. Drupal xây dựng bằng mã mở, bản thân là mã mở và hỗ
trợ các dự án mã mở. Cụ thể là Drupal được xây dựng trên ngôn ngữ mở PHP,
hỗ trợ các CSDL mã mở là MySQL và Postgresql.
Dễ dùng. Dễ dùng đối với nhà phát triển, nhà quản lí và người dùng.
Cộng tác. Hỗ trợ các hệ thống chia sẻ thông tin.
1.2. Các khái niệm cơ bản
1.2.1. Nhân
Một framework đơn giản tạo nên nhân Drupal. Đây là những gì nhận được khi tải
Drupal về từ drupal.org. Nhân chịu trách nhiệm cung cấp các chức năng cơ bản sẽ
được sử dụng để hỗ trợ các bộ phận khác của hệ thống.
Nhân bao gồm code cho phép hệ thống Drupal khởi động khi nó nhận được một
yêu cầu, một thư viện các chức năng phổ biến thường xuyên được sử dụng với Drupal,
và các module cung cấp chức năng cơ bản như quản lý người dùng, phân loại, và
templating như thể hiện trong Hình 1-2.
8
Hình 1-2. Tổng quan về nhân Drupal
1.2.2. Block
Block là đoạn văn bản hoặc các chức năng thường nằm ngoài khu vực nội dung
chính của một trang web, chẳng hạn như trong các sidebar trái hoặc phảis, trong
header, footer, vv. Chặn quyền truy cập và vị trí được kiểm soát trong giao diện
admin, đơn giản hóa công việc của các nhà phát triển khi tạo block. Các trang chặn cấu
hình được đặt ở Administer > Site building > Blocks
(
Block có một tiêu đề và mô tả và được sử dụng chủ yếu cho việc quảng cáo, code
snippet, và các chỉ số trạng thái, không phải cho phần chính thức của nội dung, do đó,
khối không phải là node và không tuân theo các quy tắc của node. Các node có quyền
kiểm soát sửa đổi, có thể comment cho nó, RSS feed, và các taxonomy term; chúng
thường được dành riêng cho các phần nội dung beefier của một trang web.
Regions là các phần của trang web nơi các block được đặt. Region được tạo ra và
cài đặt bởi giao diện (trong file .info của giao diện) và không được xác định bởi các
block API. Block không được gán vào region nào thì không được hiển thị.
Block có các tùy chọn để kiểm soát những người có thể nhìn thấy chúng và
những trang mà nó được hiển thị. Nếu các module điều tiết được kích hoạt, các block
9
không cần thiết cũng có thể được thiết lập để tắt tự động trong thời kỳ lưu lượng truy
cập cao.
Block được định nghĩa hoặc thông qua giao diện web của Drupal (các block tùy
biến) hoặc lập